core.go 1.78 KB
Newer Older
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
1 2
package core

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
3
import (
Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
4 5
	"fmt"
	ds "github.com/jbenet/datastore.go"
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
6
	blocks "github.com/jbenet/go-ipfs/blocks"
Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
7
	config "github.com/jbenet/go-ipfs/config"
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
8
	merkledag "github.com/jbenet/go-ipfs/merkledag"
Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
9
	peer "github.com/jbenet/go-ipfs/peer"
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
10
	u "github.com/jbenet/go-ipfs/util"
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
11 12
)

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
13
// IPFS Core module. It represents an IPFS instance.
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
14 15
type IpfsNode struct {

Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
16 17
	// the node's configuration
	Config *config.Config
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
18

Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
19 20
	// the local node's identity
	Identity *peer.Peer
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
21

Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
22 23
	// the book of other nodes (a map of Peer instances)
	PeerBook *peer.PeerBook
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
24

Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
25 26
	// the local datastore
	Datastore ds.Datastore
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
27

Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
28 29
	// the network message stream
	// Network *netmux.Netux
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
30

Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
31 32
	// the routing system. recommend ipfs-dht
	// Routing *routing.Routing
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
33

Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
34 35
	// the block exchange + strategy (bitswap)
	// BitSwap *bitswap.BitSwap
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
36

Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
37
	// the block service, get/add blocks.
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
38
	Blocks *blocks.BlockService
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
39

Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
40 41
	// the path resolution system
	// Resolver *resolver.PathResolver
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
42

Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
43 44
	// the name system, resolves paths to hashes
	// Namesys *namesys.Namesys
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
45 46 47
}

func NewIpfsNode(cfg *config.Config) (*IpfsNode, error) {
Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
48 49 50 51 52 53 54 55 56
	if cfg == nil {
		return nil, fmt.Errorf("configuration required.")
	}

	d, err := makeDatastore(cfg.Datastore)
	if err != nil {
		return nil, err
	}

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
57 58 59 60 61
	bs, err := blocks.NewBlockService(d)
	if err != nil {
		return nil, err
	}

Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
62 63 64 65
	n := &IpfsNode{
		Config:    cfg,
		PeerBook:  &peer.PeerBook{},
		Datastore: d,
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
66
		Blocks:    bs,
Juan Batiz-Benet's avatar
go fmt  
Juan Batiz-Benet committed
67 68 69
	}

	return n, nil
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
70
}
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
71 72 73 74 75 76 77 78 79 80 81 82 83 84

func (n *IpfsNode) AddDagNode(nd *merkledag.Node) (u.Key, error) {
	d, err := nd.Encoded(false)
	if err != nil {
		return "", err
	}

	b, err := blocks.NewBlock(d)
	if err != nil {
		return "", err
	}

	return n.Blocks.AddBlock(b)
}
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
85 86 87 88 89 90 91 92 93

func (n *IpfsNode) GetDagNode(k u.Key) (*merkledag.Node, error) {
	b, err := n.Blocks.GetBlock(k)
	if err != nil {
		return nil, err
	}

	return merkledag.Decoded(b.Data)
}