lotus/api/api_storage.go

97 lines
2.1 KiB
Go
Raw Normal View History

2019-11-01 12:01:16 +00:00
package api
import (
"context"
2019-11-01 13:58:48 +00:00
"fmt"
2019-11-01 12:01:16 +00:00
"github.com/filecoin-project/lotus/chain/address"
"github.com/filecoin-project/lotus/lib/sectorbuilder"
)
2019-11-01 13:58:48 +00:00
// alias because cbor-gen doesn't like non-alias types
type SectorState = uint64
2019-11-01 12:01:16 +00:00
const (
2019-11-01 13:58:48 +00:00
UndefinedSectorState SectorState = iota
2019-11-01 12:01:16 +00:00
Empty // TODO: Is this useful
Packing // sector not in sealStore, and not on chain
Unsealed // sealing / queued
PreCommitting // on chain pre-commit
PreCommitted // waiting for seed
Committing
2019-11-01 13:58:48 +00:00
Proving
SectorNoUpdate = UndefinedSectorState
2019-11-01 12:01:16 +00:00
)
2019-11-01 13:58:48 +00:00
func SectorStateStr(s SectorState) string {
switch s {
case UndefinedSectorState:
return "UndefinedSectorState"
case Empty:
return "Empty"
case Packing:
return "Packing"
case Unsealed:
return "Unsealed"
case PreCommitting:
return "PreCommitting"
case PreCommitted:
return "PreCommitted"
case Committing:
return "Committing"
case Proving:
return "Proving"
}
return fmt.Sprintf("<Unknown %d>", s)
}
2019-11-01 12:01:16 +00:00
// StorageMiner is a low-level interface to the Filecoin network storage miner node
type StorageMiner interface {
Common
ActorAddress(context.Context) (address.Address, error)
ActorSectorSize(context.Context, address.Address) (uint64, error)
2019-11-01 12:01:16 +00:00
// Temp api for testing
StoreGarbageData(context.Context) error
// Get the status of a given sector by ID
2019-11-08 18:15:13 +00:00
SectorsStatus(context.Context, uint64) (SectorInfo, error)
2019-11-01 12:01:16 +00:00
// List all staged sectors
SectorsList(context.Context) ([]uint64, error)
SectorsRefs(context.Context) (map[string][]SealedRef, error)
2019-11-08 18:15:13 +00:00
2019-11-21 16:23:42 +00:00
WorkerStats(context.Context) (sectorbuilder.WorkerStats, error)
2019-11-21 00:52:59 +00:00
// WorkerQueue registers a remote worker
WorkerQueue(context.Context) (<-chan sectorbuilder.WorkerTask, error)
WorkerDone(ctx context.Context, task uint64, res sectorbuilder.SealRes) error
2019-11-08 18:15:13 +00:00
}
type SectorInfo struct {
SectorID uint64
State SectorState
CommD []byte
CommR []byte
Proof []byte
Deals []uint64
Ticket sectorbuilder.SealTicket
Seed sectorbuilder.SealSeed
2019-11-01 12:01:16 +00:00
}
type SealedRef struct {
Piece string
Offset uint64
2019-11-06 12:22:08 +00:00
Size uint64
}
type SealedRefs struct {
Refs []SealedRef
2019-11-01 12:01:16 +00:00
}