blob: fbbb4ef2948ad14ee5390341216c50e5c4227605 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package mongo
import (
"context"
"strconv"
"time"
"github.com/go-chassis/cari/rbac"
"go.mongodb.org/mongo-driver/bson"
"github.com/apache/servicecomb-service-center/datasource"
"github.com/apache/servicecomb-service-center/datasource/mongo/client"
"github.com/apache/servicecomb-service-center/datasource/mongo/client/model"
mutil "github.com/apache/servicecomb-service-center/datasource/mongo/util"
"github.com/apache/servicecomb-service-center/pkg/log"
"github.com/apache/servicecomb-service-center/pkg/util"
)
type RoleManager struct {
}
func (ds *RoleManager) CreateRole(ctx context.Context, r *rbac.Role) error {
exist, err := ds.RoleExist(ctx, r.Name)
if err != nil {
log.Error("failed to query role", err)
return err
}
if exist {
return datasource.ErrRoleDuplicated
}
r.ID = util.GenerateUUID()
r.CreateTime = strconv.FormatInt(time.Now().Unix(), 10)
r.UpdateTime = r.CreateTime
_, err = client.GetMongoClient().Insert(ctx, model.CollectionRole, r)
if err != nil {
if client.IsDuplicateKey(err) {
return datasource.ErrRoleDuplicated
}
return err
}
log.Info("succeed to create new role: " + r.ID)
return nil
}
func (ds *RoleManager) RoleExist(ctx context.Context, name string) (bool, error) {
filter := mutil.NewFilter(mutil.RoleName(name))
count, err := client.GetMongoClient().Count(ctx, model.CollectionRole, filter)
if err != nil {
return false, err
}
if count == 0 {
return false, nil
}
return true, nil
}
func (ds *RoleManager) GetRole(ctx context.Context, name string) (*rbac.Role, error) {
filter := mutil.NewFilter(mutil.RoleName(name))
result, err := client.GetMongoClient().FindOne(ctx, model.CollectionRole, filter)
if err != nil {
return nil, err
}
if result.Err() != nil {
return nil, datasource.ErrRoleNotExist
}
var role rbac.Role
err = result.Decode(&role)
if err != nil {
log.Error("failed to decode role", err)
return nil, err
}
return &role, nil
}
func (ds *RoleManager) ListRole(ctx context.Context) ([]*rbac.Role, int64, error) {
filter := mutil.NewFilter()
cursor, err := client.GetMongoClient().Find(ctx, model.CollectionRole, filter)
if err != nil {
return nil, 0, err
}
var roles []*rbac.Role
defer cursor.Close(ctx)
for cursor.Next(ctx) {
var role rbac.Role
err = cursor.Decode(&role)
if err != nil {
log.Error("failed to decode role", err)
continue
}
roles = append(roles, &role)
}
return roles, int64(len(roles)), nil
}
func (ds *RoleManager) DeleteRole(ctx context.Context, name string) (bool, error) {
n, err := client.Count(ctx, model.CollectionAccount, bson.M{"roles": bson.M{"$in": []string{name}}})
if err != nil {
return false, err
}
if n > 0 {
return false, datasource.ErrRoleBindingExist
}
filter := mutil.NewFilter(mutil.RoleName(name))
result, err := client.DeleteDoc(ctx, model.CollectionRole, filter)
if err != nil {
return false, err
}
if result.DeletedCount == 0 {
return false, nil
}
return true, nil
}
func (ds *RoleManager) UpdateRole(ctx context.Context, name string, role *rbac.Role) error {
filter := mutil.NewFilter(mutil.RoleName(name))
setFilter := mutil.NewFilter(
mutil.ID(role.ID),
mutil.RoleName(role.Name),
mutil.Perms(role.Perms),
mutil.RoleUpdateTime(strconv.FormatInt(time.Now().Unix(), 10)),
)
updateFilter := mutil.NewFilter(mutil.Set(setFilter))
_, err := client.GetMongoClient().Update(ctx, model.CollectionRole, filter, updateFilter)
if err != nil {
return err
}
return nil
}