mirror of
https://github.com/opencloud-eu/opencloud.git
synced 2026-01-26 14:38:45 -06:00
* the default language added to the setting service Co-authored-by: Martin <github@diemattels.at> --------- Co-authored-by: Roman Perekhod <rperekhod@owncloud.com> Co-authored-by: Martin <github@diemattels.at>
78 lines
3.0 KiB
Go
78 lines
3.0 KiB
Go
package settings
|
|
|
|
import (
|
|
"errors"
|
|
|
|
cs3permissions "github.com/cs3org/go-cs3apis/cs3/permissions/v1beta1"
|
|
settingsmsg "github.com/owncloud/ocis/v2/protogen/gen/ocis/messages/settings/v0"
|
|
settingssvc "github.com/owncloud/ocis/v2/protogen/gen/ocis/services/settings/v0"
|
|
"github.com/owncloud/ocis/v2/services/settings/pkg/config"
|
|
)
|
|
|
|
var (
|
|
// Registry uses the strategy pattern as a registry
|
|
Registry = map[string]RegisterFunc{}
|
|
|
|
// ErrPermissionNotFound defines a new error for when a permission was not found
|
|
//
|
|
// Deprecated use the more generic ErrNotFound
|
|
ErrPermissionNotFound = errors.New("permission not found")
|
|
|
|
// ErrNotFound is the error to use when a resource was not found.
|
|
ErrNotFound = errors.New("not found")
|
|
)
|
|
|
|
// RegisterFunc stores store constructors
|
|
type RegisterFunc func(*config.Config) Manager
|
|
|
|
//go:generate mockery --name=Manager
|
|
|
|
// ServiceHandler combines handlers interfaces
|
|
type ServiceHandler interface {
|
|
settingssvc.BundleServiceHandler
|
|
settingssvc.ValueServiceHandler
|
|
settingssvc.RoleServiceHandler
|
|
settingssvc.PermissionServiceHandler
|
|
cs3permissions.PermissionsAPIServer
|
|
}
|
|
|
|
// Manager combines service interfaces for abstraction of storage implementations
|
|
type Manager interface {
|
|
BundleManager
|
|
ValueManager
|
|
RoleAssignmentManager
|
|
PermissionManager
|
|
}
|
|
|
|
// BundleManager is a bundle service interface for abstraction of storage implementations
|
|
type BundleManager interface {
|
|
ListBundles(bundleType settingsmsg.Bundle_Type, bundleIDs []string) ([]*settingsmsg.Bundle, error)
|
|
ReadBundle(bundleID string) (*settingsmsg.Bundle, error)
|
|
WriteBundle(bundle *settingsmsg.Bundle) (*settingsmsg.Bundle, error)
|
|
ReadSetting(settingID string) (*settingsmsg.Setting, error)
|
|
AddSettingToBundle(bundleID string, setting *settingsmsg.Setting) (*settingsmsg.Setting, error)
|
|
RemoveSettingFromBundle(bundleID, settingID string) error
|
|
}
|
|
|
|
// ValueManager is a value service interface for abstraction of storage implementations
|
|
type ValueManager interface {
|
|
ListValues(bundleID, accountUUID string) ([]*settingsmsg.Value, error)
|
|
ReadValue(valueID string) (*settingsmsg.Value, error)
|
|
ReadValueByUniqueIdentifiers(accountUUID, settingID string) (*settingsmsg.Value, error)
|
|
WriteValue(value *settingsmsg.Value) (*settingsmsg.Value, error)
|
|
}
|
|
|
|
// RoleAssignmentManager is a role assignment service interface for abstraction of storage implementations
|
|
type RoleAssignmentManager interface {
|
|
ListRoleAssignments(accountUUID string) ([]*settingsmsg.UserRoleAssignment, error)
|
|
WriteRoleAssignment(accountUUID, roleID string) (*settingsmsg.UserRoleAssignment, error)
|
|
RemoveRoleAssignment(assignmentID string) error
|
|
}
|
|
|
|
// PermissionManager is a permissions service interface for abstraction of storage implementations
|
|
type PermissionManager interface {
|
|
ListPermissionsByResource(resource *settingsmsg.Resource, roleIDs []string) ([]*settingsmsg.Permission, error)
|
|
ReadPermissionByID(permissionID string, roleIDs []string) (*settingsmsg.Permission, error)
|
|
ReadPermissionByName(name string, roleIDs []string) (*settingsmsg.Permission, error)
|
|
}
|