Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type GVGPickFilter ¶
type GVGPickFilter interface { // CheckFamily returns true when match pick request condition. CheckFamily(familyID uint32) bool // CheckGVG returns true when match pick request condition. CheckGVG(gvgMeta *GlobalVirtualGroupMeta) bool }
GVGPickFilter is used to check sp pick condition.
type GenerateGVGSecondarySPsPolicy ¶
type GenerateGVGSecondarySPsPolicy interface { // AddCandidateSP is used to add candidate sp. AddCandidateSP(spID uint32) // GenerateGVGSecondarySPs returns gvg secondary sp list. GenerateGVGSecondarySPs() ([]uint32, error) }
GenerateGVGSecondarySPsPolicy is used to generate gvg secondary sp list.
type GlobalVirtualGroupMeta ¶
type GlobalVirtualGroupMeta struct { ID uint32 FamilyID uint32 PrimarySPID uint32 SecondarySPIDs []uint32 // TODO: refine it, current proto is not compatible // SecondarySPs []*sptypes.StorageProvider SecondarySPEndpoints []string UsedStorageSize uint64 StakingStorageSize uint64 // init by staking deposit / staking price }
GlobalVirtualGroupMeta defines global virtual group meta which is used by sp.
type NewVirtualGroupManager ¶
type NewVirtualGroupManager = func(selfOperatorAddress string, chainClient consensus.Consensus) (VirtualGroupManager, error)
NewVirtualGroupManager is the virtual group manager init api.
type SPPickFilter ¶
type SPPickFilter interface { // Check returns true when match pick request condition. Check(spID uint32) bool }
SPPickFilter is used to check sp pick condition.
type VirtualGroupFamilyMeta ¶
type VirtualGroupFamilyMeta struct { ID uint32 PrimarySPID uint32 FamilyUsedStorageSize uint64 // init by gvgMap FamilyStakingStorageSize uint64 // init by gvgMap GVGMap map[uint32]*GlobalVirtualGroupMeta }
VirtualGroupFamilyMeta defines virtual group family meta which is used by sp.
type VirtualGroupManager ¶
type VirtualGroupManager interface { // PickVirtualGroupFamily pick a virtual group family(If failed to pick, // new VGF will be automatically created on the chain) in get create bucket approval workflow. PickVirtualGroupFamily() (*VirtualGroupFamilyMeta, error) // PickGlobalVirtualGroup picks a global virtual group(If failed to pick, // new GVG will be created by primary SP) in replicate/seal object workflow. PickGlobalVirtualGroup(vgfID uint32) (*GlobalVirtualGroupMeta, error) // PickGlobalVirtualGroupForBucketMigrate picks a global virtual group(If failed to pick, // new GVG will be created by primary SP) in replicate/seal object workflow. PickGlobalVirtualGroupForBucketMigrate(filter GVGPickFilter) (*GlobalVirtualGroupMeta, error) // ForceRefreshMeta is used to query metadata service and refresh the virtual group manager meta. // if pick func returns ErrStaledMetadata, the caller need force refresh from metadata and retry pick. ForceRefreshMeta() error // GenerateGlobalVirtualGroupMeta is used to generate a new global virtual group meta, the caller need send a tx to chain. GenerateGlobalVirtualGroupMeta(genPolicy GenerateGVGSecondarySPsPolicy) (*GlobalVirtualGroupMeta, error) // PickSPByFilter picks sp which is match pick filter condition. PickSPByFilter(filter SPPickFilter) (*sptypes.StorageProvider, error) // QuerySPByID returns sp proto. QuerySPByID(spID uint32) (*sptypes.StorageProvider, error) }
VirtualGroupManager is used to provide virtual group api.
Click to show internal directories.
Click to hide internal directories.