|
- package reqbuilder
-
- import (
- "strconv"
-
- "gitlink.org.cn/cloudream/common/pkgs/distlock"
- cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
- "gitlink.org.cn/cloudream/storage/common/pkgs/distlock/lockprovider"
- )
-
- type ShardStoreLockReqBuilder struct {
- *LockRequestBuilder
- }
-
- func (b *LockRequestBuilder) Shard() *ShardStoreLockReqBuilder {
- return &ShardStoreLockReqBuilder{LockRequestBuilder: b}
- }
- func (b *ShardStoreLockReqBuilder) Buzy(stgID cdssdk.StorageID) *ShardStoreLockReqBuilder {
- b.locks = append(b.locks, distlock.Lock{
- Path: b.makePath(stgID),
- Name: lockprovider.IPFSBuzyLock,
- Target: *lockprovider.NewStringLockTarget(),
- })
- return b
- }
-
- func (b *ShardStoreLockReqBuilder) GC(stgID cdssdk.StorageID) *ShardStoreLockReqBuilder {
- b.locks = append(b.locks, distlock.Lock{
- Path: b.makePath(stgID),
- Name: lockprovider.IPFSGCLock,
- Target: *lockprovider.NewStringLockTarget(),
- })
- return b
- }
-
- func (b *ShardStoreLockReqBuilder) makePath(hubID cdssdk.StorageID) []string {
- return []string{lockprovider.IPFSLockPathPrefix, strconv.FormatInt(int64(hubID), 10)}
- }
|