Skip to content
Snippets Groups Projects
Select Git revision
21 results Searching

index.ts

Blame
  • core.go 5.77 KiB
    /*
    Package core implements the IpfsNode object and related methods.
    
    Packages underneath core/ provide a (relatively) stable, low-level API
    to carry out most IPFS-related tasks.  For more details on the other
    interfaces and how core/... fits into the bigger IPFS picture, see:
    
      $ godoc github.com/ipfs/go-ipfs
    */
    package core
    
    import (
    	"context"
    	"io"
    
    	"github.com/ipfs/go-filestore"
    	"github.com/ipfs/go-ipfs-pinner"
    
    	bserv "github.com/ipfs/go-blockservice"
    	bstore "github.com/ipfs/go-ipfs-blockstore"
    	exchange "github.com/ipfs/go-ipfs-exchange-interface"
    	"github.com/ipfs/go-ipfs-provider"
    	ipld "github.com/ipfs/go-ipld-format"
    	logging "github.com/ipfs/go-log"
    	mfs "github.com/ipfs/go-mfs"
    	resolver "github.com/ipfs/go-path/resolver"
    	goprocess "github.com/jbenet/goprocess"
    	autonat "github.com/libp2p/go-libp2p-autonat-svc"
    	connmgr "github.com/libp2p/go-libp2p-core/connmgr"
    	ic "github.com/libp2p/go-libp2p-core/crypto"
    	p2phost "github.com/libp2p/go-libp2p-core/host"
    	metrics "github.com/libp2p/go-libp2p-core/metrics"
    	peer "github.com/libp2p/go-libp2p-core/peer"
    	pstore "github.com/libp2p/go-libp2p-core/peerstore"
    	routing "github.com/libp2p/go-libp2p-core/routing"
    	dht "github.com/libp2p/go-libp2p-kad-dht"
    	pubsub "github.com/libp2p/go-libp2p-pubsub"
    	psrouter "github.com/libp2p/go-libp2p-pubsub-router"
    	record "github.com/libp2p/go-libp2p-record"
    	"github.com/libp2p/go-libp2p/p2p/discovery"
    	p2pbhost "github.com/libp2p/go-libp2p/p2p/host/basic"
    
    	"github.com/ipfs/go-ipfs/core/bootstrap"
    	"github.com/ipfs/go-ipfs/core/node"
    	"github.com/ipfs/go-ipfs/core/node/libp2p"
    	"github.com/ipfs/go-ipfs/fuse/mount"
    	"github.com/ipfs/go-ipfs/namesys"
    	ipnsrp "github.com/ipfs/go-ipfs/namesys/republisher"
    	"github.com/ipfs/go-ipfs/p2p"
    	"github.com/ipfs/go-ipfs/repo"
    )
    
    var log = logging.Logger("core")
    
    // IpfsNode is IPFS Core module. It represents an IPFS instance.
    type IpfsNode struct {
    
    	// Self
    	Identity peer.ID // the local node's identity
    
    	Repo repo.Repo
    
    	// Local node
    	Pinning         pin.Pinner             // the pinning manager
    	Mounts          Mounts                 `optional:"true"` // current mount state, if any.
    	PrivateKey      ic.PrivKey             `optional:"true"` // the local node's private Key
    	PNetFingerprint libp2p.PNetFingerprint `optional:"true"` // fingerprint of private network
    
    	// Services
    	Peerstore       pstore.Peerstore     `optional:"true"` // storage for other Peer instances
    	Blockstore      bstore.GCBlockstore  // the block store (lower level)
    	Filestore       *filestore.Filestore `optional:"true"` // the filestore blockstore
    	BaseBlocks      node.BaseBlocks      // the raw blockstore, no filestore wrapping
    	GCLocker        bstore.GCLocker      // the locker used to protect the blockstore during gc
    	Blocks          bserv.BlockService   // the block service, get/add blocks.
    	DAG             ipld.DAGService      // the merkle dag service, get/add objects.
    	Resolver        *resolver.Resolver   // the path resolution system
    	Reporter        metrics.Reporter     `optional:"true"`
    	Discovery       discovery.Service    `optional:"true"`
    	FilesRoot       *mfs.Root
    	RecordValidator record.Validator
    
    	// Online
    	PeerHost     p2phost.Host        `optional:"true"` // the network host (server+client)
    	Bootstrapper io.Closer           `optional:"true"` // the periodic bootstrapper
    	Routing      routing.Routing     `optional:"true"` // the routing system. recommend ipfs-dht
    	Exchange     exchange.Interface  // the block exchange + strategy (bitswap)
    	Namesys      namesys.NameSystem  // the name system, resolves paths to hashes
    	Provider     provider.System     // the value provider system
    	IpnsRepub    *ipnsrp.Republisher `optional:"true"`
    
    	AutoNAT  *autonat.AutoNATService    `optional:"true"`
    	PubSub   *pubsub.PubSub             `optional:"true"`
    	PSRouter *psrouter.PubsubValueStore `optional:"true"`
    	DHT      *dht.IpfsDHT               `optional:"true"`
    	P2P      *p2p.P2P                   `optional:"true"`
    
    	Process goprocess.Process
    	ctx     context.Context
    
    	stop func() error
    
    	// Flags
    	IsOnline bool `optional:"true"` // Online is set when networking is enabled.
    	IsDaemon bool `optional:"true"` // Daemon is set when running on a long-running daemon.
    }
    
    // Mounts defines what the node's mount state is. This should
    // perhaps be moved to the daemon or mount. It's here because
    // it needs to be accessible across daemon requests.
    type Mounts struct {
    	Ipfs mount.Mount
    	Ipns mount.Mount
    }
    
    // Close calls Close() on the App object
    func (n *IpfsNode) Close() error {
    	return n.stop()
    }
    
    // Context returns the IpfsNode context
    func (n *IpfsNode) Context() context.Context {
    	if n.ctx == nil {
    		n.ctx = context.TODO()
    	}
    	return n.ctx
    }
    
    // Bootstrap will set and call the IpfsNodes bootstrap function.
    func (n *IpfsNode) Bootstrap(cfg bootstrap.BootstrapConfig) error {
    	// TODO what should return value be when in offlineMode?
    	if n.Routing == nil {
    		return nil
    	}
    
    	if n.Bootstrapper != nil {
    		n.Bootstrapper.Close() // stop previous bootstrap process.
    	}
    
    	// if the caller did not specify a bootstrap peer function, get the
    	// freshest bootstrap peers from config. this responds to live changes.
    	if cfg.BootstrapPeers == nil {
    		cfg.BootstrapPeers = func() []peer.AddrInfo {
    			ps, err := n.loadBootstrapPeers()
    			if err != nil {
    				log.Warning("failed to parse bootstrap peers from config")
    				return nil
    			}
    			return ps
    		}
    	}
    
    	var err error
    	n.Bootstrapper, err = bootstrap.Bootstrap(n.Identity, n.PeerHost, n.Routing, cfg)
    	return err
    }
    
    func (n *IpfsNode) loadBootstrapPeers() ([]peer.AddrInfo, error) {
    	cfg, err := n.Repo.Config()
    	if err != nil {
    		return nil, err
    	}
    
    	return cfg.BootstrapPeers()
    }
    
    type ConstructPeerHostOpts struct {
    	AddrsFactory      p2pbhost.AddrsFactory
    	DisableNatPortMap bool
    	DisableRelay      bool
    	EnableRelayHop    bool
    	ConnectionManager connmgr.ConnManager
    }