lotus/api/api.go

160 lines
5.0 KiB
Go
Raw Normal View History

package api
import (
"context"
2019-07-08 21:01:15 +00:00
2019-07-25 00:55:19 +00:00
"github.com/libp2p/go-libp2p-core/network"
2019-07-24 00:09:34 +00:00
"github.com/libp2p/go-libp2p-core/peer"
2019-07-09 15:19:27 +00:00
"github.com/filecoin-project/go-lotus/chain"
2019-07-11 02:36:43 +00:00
"github.com/filecoin-project/go-lotus/chain/address"
"github.com/filecoin-project/go-lotus/chain/store"
2019-07-18 20:26:04 +00:00
"github.com/filecoin-project/go-lotus/chain/types"
2019-07-09 15:19:27 +00:00
sectorbuilder "github.com/filecoin-project/go-sectorbuilder"
2019-07-12 09:59:18 +00:00
"github.com/ipfs/go-cid"
2019-07-15 14:14:54 +00:00
"github.com/ipfs/go-filestore"
)
2019-07-02 13:05:43 +00:00
// Version provides various build-time information
type Version struct {
Version string
// APIVersion is a binary encoded semver version of the remote implementing
// this api
//
// See APIVersion in build/version.go
APIVersion uint32
// TODO: git commit / os / genesis cid?
}
2019-07-12 10:44:01 +00:00
type Import struct {
Status filestore.Status
Key cid.Cid
FilePath string
Size uint64
}
2019-07-17 06:05:11 +00:00
type MsgWait struct {
InBlock cid.Cid
Receipt types.MessageReceipt
}
2019-08-02 03:51:34 +00:00
type BlockMessages struct {
BlsMessages []*types.Message
SecpkMessages []*types.SignedMessage
}
type SectorInfo struct {
SectorID uint64
CommD []byte
CommR []byte
}
2019-08-10 01:54:45 +00:00
type ActorState struct {
Balance types.BigInt
State interface{}
}
2019-07-24 00:09:34 +00:00
type Common interface {
2019-07-23 17:27:45 +00:00
// Auth
AuthVerify(ctx context.Context, token string) ([]string, error)
AuthNew(ctx context.Context, perms []string) ([]byte, error)
2019-07-24 00:09:34 +00:00
// network
2019-07-25 00:55:19 +00:00
NetConnectedness(context.Context, peer.ID) (network.Connectedness, error)
2019-07-24 00:09:34 +00:00
NetPeers(context.Context) ([]peer.AddrInfo, error)
NetConnect(context.Context, peer.AddrInfo) error
NetAddrsListen(context.Context) (peer.AddrInfo, error)
2019-07-25 00:55:19 +00:00
NetDisconnect(context.Context, peer.ID) error
2019-07-24 00:09:34 +00:00
// ID returns peerID of libp2p node backing this API
ID(context.Context) (peer.ID, error)
// Version provides information about API provider
Version(context.Context) (Version, error)
}
// FullNode API is a low-level interface to the Filecoin network full node
type FullNode interface {
Common
// chain
ChainNotify(context.Context) (<-chan *store.HeadChange, error)
2019-07-26 04:54:22 +00:00
ChainHead(context.Context) (*types.TipSet, error) // TODO: check serialization
2019-07-09 15:19:27 +00:00
ChainSubmitBlock(ctx context.Context, blk *chain.BlockMsg) error // TODO: check serialization
2019-07-26 04:54:22 +00:00
ChainGetRandomness(context.Context, *types.TipSet) ([]byte, error)
2019-07-17 06:05:11 +00:00
ChainWaitMsg(context.Context, cid.Cid) (*MsgWait, error)
ChainGetBlock(context.Context, cid.Cid) (*types.BlockHeader, error)
2019-08-02 03:51:34 +00:00
ChainGetBlockMessages(context.Context, cid.Cid) (*BlockMessages, error)
ChainGetBlockReceipts(context.Context, cid.Cid) ([]*types.MessageReceipt, error)
2019-08-10 01:54:45 +00:00
ChainGetActor(ctx context.Context, actor address.Address, ts *types.TipSet) (*types.Actor, error)
ChainReadState(ctx context.Context, act *types.Actor, ts *types.TipSet) (*ActorState, error)
2019-07-31 16:54:28 +00:00
// if tipset is nil, we'll use heaviest
ChainCall(context.Context, *types.Message, *types.TipSet) (*types.MessageReceipt, error)
// messages
2019-07-26 04:54:22 +00:00
MpoolPending(context.Context, *types.TipSet) ([]*types.SignedMessage, error)
MpoolPush(context.Context, *types.SignedMessage) error
2019-07-31 07:13:49 +00:00
MpoolGetNonce(context.Context, address.Address) (uint64, error)
2019-07-24 00:09:34 +00:00
// FullNodeStruct
// miner
2019-07-11 02:36:43 +00:00
MinerStart(context.Context, address.Address) error
2019-07-26 04:54:22 +00:00
MinerCreateBlock(context.Context, address.Address, *types.TipSet, []types.Ticket, types.ElectionProof, []*types.SignedMessage) (*chain.BlockMsg, error)
// // UX ?
// wallet
2019-07-13 00:41:32 +00:00
WalletNew(context.Context, string) (address.Address, error)
2019-08-08 17:29:23 +00:00
WalletHas(context.Context, address.Address) (bool, error)
2019-07-13 00:41:32 +00:00
WalletList(context.Context) ([]address.Address, error)
2019-07-18 20:26:04 +00:00
WalletBalance(context.Context, address.Address) (types.BigInt, error)
WalletSign(context.Context, address.Address, []byte) (*types.Signature, error)
2019-08-09 15:59:12 +00:00
WalletSignMessage(context.Context, address.Address, *types.Message) (*types.SignedMessage, error)
WalletDefaultAddress(context.Context) (address.Address, error)
// Other
2019-07-12 09:59:18 +00:00
// ClientImport imports file under the specified path into filestore
ClientImport(ctx context.Context, path string) (cid.Cid, error)
2019-08-07 20:06:10 +00:00
ClientStartDeal(ctx context.Context, data cid.Cid, miner address.Address, price types.BigInt, blocksDuration uint64) (*cid.Cid, error)
2019-08-01 17:12:41 +00:00
2019-07-12 09:59:18 +00:00
// ClientUnimport removes references to the specified file from filestore
//ClientUnimport(path string)
// ClientListImports lists imported files and their root CIDs
2019-07-12 10:44:01 +00:00
ClientListImports(ctx context.Context) ([]Import, error)
2019-07-12 09:59:18 +00:00
//ClientListAsks() []Ask
StateMinerSectors(context.Context, address.Address) ([]*SectorInfo, error)
StateMinerProvingSet(context.Context, address.Address) ([]*SectorInfo, error)
2019-07-24 00:09:34 +00:00
}
// Full API is a low-level interface to the Filecoin network storage miner node
type StorageMiner interface {
Common
2019-07-27 01:54:03 +00:00
2019-08-10 01:54:45 +00:00
ActorAddresses(context.Context) ([]address.Address, error)
2019-07-27 01:54:03 +00:00
// Temp api for testing
StoreGarbageData(context.Context) (uint64, error)
// Get the status of a given sector by ID
SectorsStatus(context.Context, uint64) (sectorbuilder.SectorSealingStatus, error)
// List all staged sectors
SectorsStagedList(context.Context) ([]sectorbuilder.StagedSectorMetadata, error)
// Seal all staged sectors
SectorsStagedSeal(context.Context) error
}