Documentation ¶
Overview ¶
Package coreapi provides direct access to the core commands in IPFS. If you are embedding IPFS directly in your Go program, this package is the public interface you should use to read and write files or otherwise control IPFS.
If you are running IPFS as a separate process, you should use `go-ipfs-api` to work with it via HTTP. As we finalize the interfaces here, `go-ipfs-api` will transparently adopt them so you can use the same code with either package.
**NOTE: this package is experimental.** `go-ipfs` has mainly been developed as a standalone application and library-style use of this package is still new. Interfaces here aren't yet completely stable.
Index ¶
- func NewCoreAPI(n *core.IpfsNode, opts ...options.ApiOption) (coreiface.CoreAPI, error)
- func PinLsAll(ctx context.Context, typeStr string, pin pin.Pinner, dag ipld.DAGService) (chan coreiface.Pin, chan error)
- type BlockAPI
- func (api *BlockAPI) Get(ctx context.Context, p path.Path) (io.Reader, error)
- func (api *BlockAPI) Push(ctx context.Context, num uint32, peer peer.ID, c cid.Cid) error
- func (api *BlockAPI) Put(ctx context.Context, src io.Reader, opts ...caopts.BlockPutOption) (coreiface.BlockStat, error)
- func (api *BlockAPI) Rm(ctx context.Context, p path.Path, opts ...caopts.BlockRmOption) error
- func (api *BlockAPI) Stat(ctx context.Context, p path.Path) (coreiface.BlockStat, error)
- type BlockStat
- type CoreAPI
- func (api *CoreAPI) Block() coreiface.BlockAPI
- func (api *CoreAPI) Dag() coreiface.APIDagService
- func (api *CoreAPI) Dht() coreiface.DhtAPI
- func (api *CoreAPI) Key() coreiface.KeyAPI
- func (api *CoreAPI) Name() coreiface.NameAPI
- func (api *CoreAPI) Object() coreiface.ObjectAPI
- func (api *CoreAPI) Pin() coreiface.PinAPI
- func (api *CoreAPI) PubSub() coreiface.PubSubAPI
- func (api *CoreAPI) ResolveNode(ctx context.Context, p path.Path) (ipld.Node, error)
- func (api *CoreAPI) ResolvePath(ctx context.Context, p path.Path) (path.Resolved, error)
- func (api *CoreAPI) Swarm() coreiface.SwarmAPI
- func (api *CoreAPI) Unixfs() coreiface.UnixfsAPI
- func (api *CoreAPI) WithOptions(opts ...options.ApiOption) (coreiface.CoreAPI, error)
- type DhtAPI
- func (api *DhtAPI) FindPeer(ctx context.Context, p peer.ID) (peer.AddrInfo, error)
- func (api *DhtAPI) FindProviders(ctx context.Context, p path.Path, opts ...caopts.DhtFindProvidersOption) (<-chan peer.AddrInfo, error)
- func (api *DhtAPI) Provide(ctx context.Context, path path.Path, opts ...caopts.DhtProvideOption) error
- type KeyAPI
- func (api *KeyAPI) Generate(ctx context.Context, name string, opts ...caopts.KeyGenerateOption) (coreiface.Key, error)
- func (api *KeyAPI) List(ctx context.Context) ([]coreiface.Key, error)
- func (api *KeyAPI) Remove(ctx context.Context, name string) (coreiface.Key, error)
- func (api *KeyAPI) Rename(ctx context.Context, oldName string, newName string, ...) (coreiface.Key, bool, error)
- func (api *KeyAPI) Self(ctx context.Context) (coreiface.Key, error)
- type Link
- type NameAPI
- func (api *NameAPI) Publish(ctx context.Context, p path.Path, opts ...caopts.NamePublishOption) (coreiface.IpnsEntry, error)
- func (api *NameAPI) Resolve(ctx context.Context, name string, opts ...caopts.NameResolveOption) (path.Path, error)
- func (api *NameAPI) Search(ctx context.Context, name string, opts ...caopts.NameResolveOption) (<-chan coreiface.IpnsResult, error)
- type Node
- type ObjectAPI
- func (api *ObjectAPI) AddLink(ctx context.Context, base ipath.Path, name string, child ipath.Path, ...) (ipath.Resolved, error)
- func (api *ObjectAPI) AppendData(ctx context.Context, path ipath.Path, r io.Reader) (ipath.Resolved, error)
- func (api *ObjectAPI) Data(ctx context.Context, path ipath.Path) (io.Reader, error)
- func (api *ObjectAPI) Diff(ctx context.Context, before ipath.Path, after ipath.Path) ([]coreiface.ObjectChange, error)
- func (api *ObjectAPI) Get(ctx context.Context, path ipath.Path) (ipld.Node, error)
- func (api *ObjectAPI) Links(ctx context.Context, path ipath.Path) ([]*ipld.Link, error)
- func (api *ObjectAPI) New(ctx context.Context, opts ...caopts.ObjectNewOption) (ipld.Node, error)
- func (api *ObjectAPI) Put(ctx context.Context, src io.Reader, opts ...caopts.ObjectPutOption) (ipath.Resolved, error)
- func (api *ObjectAPI) RmLink(ctx context.Context, base ipath.Path, link string) (ipath.Resolved, error)
- func (api *ObjectAPI) SetData(ctx context.Context, path ipath.Path, r io.Reader) (ipath.Resolved, error)
- func (api *ObjectAPI) Stat(ctx context.Context, path ipath.Path) (*coreiface.ObjectStat, error)
- type PinAPI
- func (api *PinAPI) Add(ctx context.Context, p path.Path, opts ...caopts.PinAddOption) error
- func (api *PinAPI) Ls(ctx context.Context, opts ...caopts.PinLsOption) ([]coreiface.Pin, error)
- func (api *PinAPI) Rm(ctx context.Context, p path.Path, opts ...caopts.PinRmOption) error
- func (api *PinAPI) Update(ctx context.Context, from path.Path, to path.Path, ...) error
- func (api *PinAPI) Verify(ctx context.Context) (<-chan coreiface.PinStatus, error)
- type ProviderAPI
- type PubSubAPI
- func (api *PubSubAPI) Ls(ctx context.Context) ([]string, error)
- func (api *PubSubAPI) Peers(ctx context.Context, opts ...caopts.PubSubPeersOption) ([]peer.ID, error)
- func (api *PubSubAPI) Publish(ctx context.Context, topic string, data []byte) error
- func (api *PubSubAPI) Subscribe(ctx context.Context, topic string, opts ...caopts.PubSubSubscribeOption) (coreiface.PubSubSubscription, error)
- type SwarmAPI
- func (api *SwarmAPI) Connect(ctx context.Context, pi peer.AddrInfo) error
- func (api *SwarmAPI) Disconnect(ctx context.Context, addr ma.Multiaddr) error
- func (api *SwarmAPI) KnownAddrs(context.Context) (map[peer.ID][]ma.Multiaddr, error)
- func (api *SwarmAPI) ListenAddrs(context.Context) ([]ma.Multiaddr, error)
- func (api *SwarmAPI) LocalAddrs(context.Context) ([]ma.Multiaddr, error)
- func (api *SwarmAPI) Peers(context.Context) ([]coreiface.ConnectionInfo, error)
- type UnixfsAPI
- func (api *UnixfsAPI) Add(ctx context.Context, files files.Node, opts ...options.UnixfsAddOption) (path.Resolved, error)
- func (api *UnixfsAPI) Get(ctx context.Context, p path.Path) (files.Node, error)
- func (api *UnixfsAPI) Ls(ctx context.Context, p path.Path, opts ...options.UnixfsLsOption) (<-chan coreiface.DirEntry, error)
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func NewCoreAPI ¶
NewCoreAPI creates new instance of IPFS CoreAPI backed by go-ipfs Node.
Types ¶
type BlockAPI ¶
type BlockAPI CoreAPI
type CoreAPI ¶
type CoreAPI struct {
// contains filtered or unexported fields
}
func (*CoreAPI) Block ¶
Block returns the BlockAPI interface implementation backed by the go-ipfs node
func (*CoreAPI) Dag ¶
func (api *CoreAPI) Dag() coreiface.APIDagService
Dag returns the DagAPI interface implementation backed by the go-ipfs node
func (*CoreAPI) Object ¶
Object returns the ObjectAPI interface implementation backed by the go-ipfs node
func (*CoreAPI) PubSub ¶
PubSub returns the PubSubAPI interface implementation backed by the go-ipfs node
func (*CoreAPI) ResolveNode ¶
ResolveNode resolves the path `p` using Unixfs resolver, gets and returns the resolved Node.
func (*CoreAPI) ResolvePath ¶
ResolvePath resolves the path `p` using Unixfs resolver, returns the resolved path.
func (*CoreAPI) Swarm ¶
Swarm returns the SwarmAPI interface implementation backed by the go-ipfs node
type KeyAPI ¶
type KeyAPI CoreAPI
func (*KeyAPI) Generate ¶
func (api *KeyAPI) Generate(ctx context.Context, name string, opts ...caopts.KeyGenerateOption) (coreiface.Key, error)
Generate generates new key, stores it in the keystore under the specified name and returns a base58 encoded multihash of its public key.
type NameAPI ¶
type NameAPI CoreAPI
func (*NameAPI) Publish ¶
func (api *NameAPI) Publish(ctx context.Context, p path.Path, opts ...caopts.NamePublishOption) (coreiface.IpnsEntry, error)
Publish announces new IPNS name and returns the new IPNS entry.
type ObjectAPI ¶
type ObjectAPI CoreAPI
func (*ObjectAPI) AppendData ¶
type PinAPI ¶
type PinAPI CoreAPI
type SwarmAPI ¶
type SwarmAPI CoreAPI
func (*SwarmAPI) Disconnect ¶
func (*SwarmAPI) KnownAddrs ¶
func (*SwarmAPI) ListenAddrs ¶
func (*SwarmAPI) LocalAddrs ¶
type UnixfsAPI ¶
type UnixfsAPI CoreAPI
func (*UnixfsAPI) Add ¶
func (api *UnixfsAPI) Add(ctx context.Context, files files.Node, opts ...options.UnixfsAddOption) (path.Resolved, error)
Add builds a merkledag node from a reader, adds it to the blockstore, and returns the key representing that node.