|
@ -21,6 +21,8 @@ type VirtualFilerStore interface { |
|
|
DeleteHardLink(ctx context.Context, hardLinkId HardLinkId) error |
|
|
DeleteHardLink(ctx context.Context, hardLinkId HardLinkId) error |
|
|
DeleteOneEntry(ctx context.Context, entry *Entry) error |
|
|
DeleteOneEntry(ctx context.Context, entry *Entry) error |
|
|
AddPathSpecificStore(path string, storeId string, store FilerStore) |
|
|
AddPathSpecificStore(path string, storeId string, store FilerStore) |
|
|
|
|
|
OnBucketCreation(bucket string) |
|
|
|
|
|
OnBucketDeletion(bucket string) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
type FilerStoreWrapper struct { |
|
|
type FilerStoreWrapper struct { |
|
@ -40,6 +42,27 @@ func NewFilerStoreWrapper(store FilerStore) *FilerStoreWrapper { |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func (fsw *FilerStoreWrapper) OnBucketCreation(bucket string) { |
|
|
|
|
|
for _, store := range fsw.storeIdToStore { |
|
|
|
|
|
if ba, ok := store.(BucketAware); ok { |
|
|
|
|
|
ba.OnBucketCreation(bucket) |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
if ba, ok := fsw.defaultStore.(BucketAware); ok { |
|
|
|
|
|
ba.OnBucketCreation(bucket) |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
func (fsw *FilerStoreWrapper) OnBucketDeletion(bucket string) { |
|
|
|
|
|
for _, store := range fsw.storeIdToStore { |
|
|
|
|
|
if ba, ok := store.(BucketAware); ok { |
|
|
|
|
|
ba.OnBucketDeletion(bucket) |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
if ba, ok := fsw.defaultStore.(BucketAware); ok { |
|
|
|
|
|
ba.OnBucketDeletion(bucket) |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
func (fsw *FilerStoreWrapper) AddPathSpecificStore(path string, storeId string, store FilerStore) { |
|
|
func (fsw *FilerStoreWrapper) AddPathSpecificStore(path string, storeId string, store FilerStore) { |
|
|
fsw.storeIdToStore[storeId] = NewFilerStorePathTranlator(path, store) |
|
|
fsw.storeIdToStore[storeId] = NewFilerStorePathTranlator(path, store) |
|
|
err := fsw.pathToStore.Put([]byte(path), storeId) |
|
|
err := fsw.pathToStore.Put([]byte(path), storeId) |
|
|