reuse existing metadata storage

Signed-off-by: Jörn Friedrich Dreyer <jfd@butonic.de>
This commit is contained in:
Jörn Friedrich Dreyer
2021-12-03 10:11:19 +00:00
parent 31bf29cb26
commit 550b0bbfea
2 changed files with 13 additions and 14 deletions

View File

@@ -35,7 +35,6 @@ type CS3Repo struct {
tm token.Manager
storageProvider provider.ProviderAPIClient
metadataStorage metadatastorage.MetadataStorage
space *provider.StorageSpace
}
// NewCS3Repo creates a new cs3 repo
@@ -104,13 +103,13 @@ func (r *CS3Repo) Init() (err error) {
case err != nil:
return err
case cssr.Status.Code == v1beta11.Code_CODE_OK:
// continue
case cssr.Status.Code != v1beta11.Code_CODE_ALREADY_EXISTS:
// continue
r.metadataStorage.SpaceRoot = cssr.StorageSpace.Root
case cssr.Status.Code == v1beta11.Code_CODE_ALREADY_EXISTS:
// TODO make CreateStorageSpace return existing space?
r.metadataStorage.SpaceRoot = &provider.ResourceId{StorageId: r.cfg.ServiceUser.UUID, OpaqueId: r.cfg.ServiceUser.UUID}
default:
return errtypes.NewErrtypeFromStatus(cssr.Status)
}
r.metadataStorage.SpaceRoot = cssr.StorageSpace.Root
return nil
}
@@ -154,7 +153,7 @@ func (r CS3Repo) LoadAccounts(ctx context.Context, a *[]*proto.Account) (err err
res, err := r.storageProvider.ListContainer(ctx, &provider.ListContainerRequest{
Ref: &provider.Reference{
ResourceId: r.space.Root,
ResourceId: r.metadataStorage.SpaceRoot,
Path: utils.MakeRelativePath(accountsFolder),
},
})
@@ -195,7 +194,7 @@ func (r CS3Repo) DeleteAccount(ctx context.Context, id string) (err error) {
resp, err := r.storageProvider.Delete(ctx, &provider.DeleteRequest{
Ref: &provider.Reference{
ResourceId: r.space.Root,
ResourceId: r.metadataStorage.SpaceRoot,
Path: utils.MakeRelativePath(filepath.Join("/", accountsFolder, id)),
},
})
@@ -251,7 +250,7 @@ func (r CS3Repo) LoadGroups(ctx context.Context, g *[]*proto.Group) (err error)
res, err := r.storageProvider.ListContainer(ctx, &provider.ListContainerRequest{
Ref: &provider.Reference{
ResourceId: r.space.Root,
ResourceId: r.metadataStorage.SpaceRoot,
Path: utils.MakeRelativePath(groupsFolder),
},
})
@@ -292,7 +291,7 @@ func (r CS3Repo) DeleteGroup(ctx context.Context, id string) (err error) {
resp, err := r.storageProvider.Delete(ctx, &provider.DeleteRequest{
Ref: &provider.Reference{
ResourceId: r.space.Root,
ResourceId: r.metadataStorage.SpaceRoot,
Path: utils.MakeRelativePath(filepath.Join(groupsFolder, id)),
},
})
@@ -345,7 +344,7 @@ func (r CS3Repo) groupURL(id string) string {
}
func (r CS3Repo) makeRootDirIfNotExist(ctx context.Context, folder string) error {
return MakeDirIfNotExist(ctx, r.storageProvider, r.space.Root, folder)
return MakeDirIfNotExist(ctx, r.storageProvider, r.metadataStorage.SpaceRoot, folder)
}
// MakeDirIfNotExist will create a root node in the metadata storage. Requires an authenticated context.

View File

@@ -585,8 +585,8 @@ func DefaultConfig() *Config {
EnableMedialSearch: false,
},
OCDav: OCDav{
WebdavNamespace: "/home/",
DavFilesNamespace: "/users/",
WebdavNamespace: "/users/{{.Id.OpaqueId}}",
DavFilesNamespace: "/users",
},
Archiver: Archiver{
MaxNumFiles: 10000,
@@ -751,7 +751,7 @@ func DefaultConfig() *Config {
ArchiverPrefix: "archiver",
DatagatewayPrefix: "data",
Favorites: false,
OCDavInsecure: false,
OCDavInsecure: true,
OCDavPrefix: "",
OCSPrefix: "ocs",
OCSSharePrefix: "/Shares",
@@ -782,7 +782,7 @@ func DefaultConfig() *Config {
EtagCacheTTL: 0,
},
StorageRegistry: StorageRegistry{
Driver: "static",
Driver: "spaces",
HomeProvider: "/home",
JSON: "",
},