Newer
Older
package rbac
import (
"code.fbi.h-da.de/danet/gosdn/controller/interfaces/rbac"
"code.fbi.h-da.de/danet/gosdn/controller/nucleus/database"
"code.fbi.h-da.de/danet/gosdn/controller/nucleus/errors"
"code.fbi.h-da.de/danet/gosdn/controller/store"
"github.com/google/uuid"
log "github.com/sirupsen/logrus"
"go.mongodb.org/mongo-driver/bson"
"go.mongodb.org/mongo-driver/bson/primitive"
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
)
// DatabaseRoleStore is used to store roles in database
type DatabaseRoleStore struct {
roleStoreName string
}
// Add adds a Role.
func (s *DatabaseRoleStore) Add(roleToAdd rbac.Role) error {
client, ctx, cancel := database.GetMongoConnection()
defer cancel()
defer client.Disconnect(ctx)
_, err := client.Database(database.DatabaseName).
Collection(s.roleStoreName).
InsertOne(ctx, roleToAdd)
if err != nil {
if mongo.IsDuplicateKeyError(err) {
return nil
}
return errors.ErrCouldNotCreate{Identifier: roleToAdd.ID(), Type: roleToAdd, Err: err}
}
return nil
}
// Delete deletes a Role.
func (s *DatabaseRoleStore) Delete(roleToDelete rbac.Role) error {
client, ctx, cancel := database.GetMongoConnection()
defer cancel()
defer client.Disconnect(ctx)
_, err := client.Database(database.DatabaseName).
Collection(s.roleStoreName).
DeleteOne(ctx, bson.D{primitive.E{Key: "_id", Value: roleToDelete.ID().String()}})
if err != nil {
return errors.ErrCouldNotDelete{Identifier: roleToDelete.ID(), Type: roleToDelete, Err: err}
}
return nil
}
// Get takes a Roles's UUID or name and returns the Role. If the requested
// Role does not exist an error is returned.
func (s *DatabaseRoleStore) Get(query store.Query) (rbac.LoadedRole, error) {
var loadedRole rbac.LoadedRole
if query.ID != uuid.Nil {
loadedRole, err := s.getByID(query.ID)
if err != nil {
Fabian Seidl
committed
return loadedRole, err
}
return loadedRole, nil
}
loadedRole, err := s.getByName(query.Name)
if err != nil {
Fabian Seidl
committed
return loadedRole, err
}
return loadedRole, nil
}
func (s *DatabaseRoleStore) getByID(idOfRole uuid.UUID) (rbac.LoadedRole, error) {
var loadedRole rbac.LoadedRole
client, ctx, cancel := database.GetMongoConnection()
defer cancel()
defer client.Disconnect(ctx)
db := client.Database(database.DatabaseName)
collection := db.Collection(s.roleStoreName)
result := collection.FindOne(ctx, bson.D{primitive.E{Key: "_id", Value: idOfRole.String()}})
if result == nil {
Fabian Seidl
committed
return loadedRole, errors.ErrCouldNotFind{ID: idOfRole}
}
err := result.Decode(&loadedRole)
if err != nil {
log.Printf("Failed marshalling %v", err)
return loadedRole, errors.ErrCouldNotMarshall{Identifier: idOfRole, Type: loadedRole, Err: err}
}
return loadedRole, nil
}
func (s *DatabaseRoleStore) getByName(nameOfRole string) (rbac.LoadedRole, error) {
var loadedRole rbac.LoadedRole
client, ctx, cancel := database.GetMongoConnection()
defer cancel()
defer client.Disconnect(ctx)
db := client.Database(database.DatabaseName)
collection := db.Collection(s.roleStoreName)
result := collection.FindOne(ctx, bson.D{primitive.E{Key: "rolename", Value: nameOfRole}})
if result == nil {
Fabian Seidl
committed
return loadedRole, errors.ErrCouldNotFind{Name: nameOfRole}
}
err := result.Decode(&loadedRole)
if err != nil {
log.Printf("Failed marshalling %v", err)
return loadedRole, errors.ErrCouldNotMarshall{Identifier: nameOfRole, Type: loadedRole, Err: err}
}
return loadedRole, nil
}
// GetAll returns all Roles.
func (s *DatabaseRoleStore) GetAll() ([]rbac.LoadedRole, error) {
var loadedRoles []rbac.LoadedRole
client, ctx, cancel := database.GetMongoConnection()
defer cancel()
defer client.Disconnect(ctx)
db := client.Database(database.DatabaseName)
collection := db.Collection(s.roleStoreName)
cursor, err := collection.Find(ctx, bson.D{})
if err != nil {
return nil, err
}
defer cursor.Close(ctx)
err = cursor.All(ctx, &loadedRoles)
if err != nil {
log.Printf("Failed marshalling %v", err)
return nil, errors.ErrCouldNotMarshall{Type: loadedRoles, Err: err}
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
}
return loadedRoles, nil
}
// Update updates the role
func (s *DatabaseRoleStore) Update(roleToUpdate rbac.Role) error {
var updatedLoadedRole rbac.LoadedRole
client, ctx, cancel := database.GetMongoConnection()
defer cancel()
defer client.Disconnect(ctx)
update := bson.D{primitive.E{Key: "$set", Value: roleToUpdate}}
upsert := false
after := options.After
opt := options.FindOneAndUpdateOptions{
Upsert: &upsert,
ReturnDocument: &after,
}
err := client.Database(database.DatabaseName).
Collection(s.roleStoreName).
FindOneAndUpdate(
ctx, bson.M{"_id": roleToUpdate.ID().String()}, update, &opt).
Decode(&updatedLoadedRole)
if err != nil {
log.Printf("Could not update Role: %v", err)
return errors.ErrCouldNotUpdate{Identifier: roleToUpdate.ID(), Type: roleToUpdate, Err: err}