init.go 2.58 KB
Newer Older
1 2 3 4
package config

import (
	"encoding/base64"
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
5
	"errors"
6
	"fmt"
7
	"io"
8

9 10
	ci "gx/ipfs/QmSN2ELGRp4T9kjqiSsSNJRUeR9JKXzQEgwe1HH3tdSGbC/go-libp2p/p2p/crypto"
	peer "gx/ipfs/QmSN2ELGRp4T9kjqiSsSNJRUeR9JKXzQEgwe1HH3tdSGbC/go-libp2p/p2p/peer"
11 12
)

13 14
func Init(out io.Writer, nBitsForKeypair int) (*Config, error) {
	identity, err := identityConfig(out, nBitsForKeypair)
15 16 17 18 19 20 21 22 23
	if err != nil {
		return nil, err
	}

	bootstrapPeers, err := DefaultBootstrapPeers()
	if err != nil {
		return nil, err
	}

24
	snr, err := initSNRConfig()
25 26 27 28
	if err != nil {
		return nil, err
	}

29 30 31 32 33 34 35 36
	conf := &Config{

		// setup the node's default addresses.
		// Note: two swarm listen addrs, one tcp, one utp.
		Addresses: Addresses{
			Swarm: []string{
				"/ip4/0.0.0.0/tcp/4001",
				// "/ip4/0.0.0.0/udp/4002/utp", // disabled for now.
37
				"/ip6/::/tcp/4001",
38
			},
39 40
			API:     "/ip4/127.0.0.1/tcp/5001",
			Gateway: "/ip4/127.0.0.1/tcp/8080",
41 42
		},

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
43 44 45
		Bootstrap:        BootstrapPeerStrings(bootstrapPeers),
		SupernodeRouting: *snr,
		Identity:         identity,
Jeromy's avatar
Jeromy committed
46 47 48 49
		Discovery: Discovery{MDNS{
			Enabled:  true,
			Interval: 10,
		}},
50 51 52 53 54 55 56

		// setup the node mount points.
		Mounts: Mounts{
			IPFS: "/ipfs",
			IPNS: "/ipns",
		},

57 58 59 60
		Ipns: Ipns{
			ResolveCacheSize: 128,
		},

61 62 63
		// tracking ipfs version used to generate the init folder and adding
		// update checker default setting.
		Version: VersionDefaultValue(),
64 65 66

		Gateway: Gateway{
			RootRedirect: "",
67
			Writable:     false,
68
			PathPrefixes: []string{},
69
		},
70 71 72 73 74 75 76 77 78 79 80
	}

	return conf, nil
}

func datastoreConfig() (*Datastore, error) {
	dspath, err := DataStorePath("")
	if err != nil {
		return nil, err
	}
	return &Datastore{
rht's avatar
rht committed
81 82 83 84 85
		Path:               dspath,
		Type:               "leveldb",
		StorageMax:         "10GB",
		StorageGCWatermark: 90, // 90%
		GCPeriod:           "1h",
86 87 88 89
	}, nil
}

// identityConfig initializes a new identity.
90
func identityConfig(out io.Writer, nbits int) (Identity, error) {
91 92 93 94 95 96
	// TODO guard higher up
	ident := Identity{}
	if nbits < 1024 {
		return ident, errors.New("Bitsize less than 1024 is considered unsafe.")
	}

97
	fmt.Fprintf(out, "generating %v-bit RSA keypair...", nbits)
98 99 100 101
	sk, pk, err := ci.GenerateKeyPair(ci.RSA, nbits)
	if err != nil {
		return ident, err
	}
102
	fmt.Fprintf(out, "done\n")
103 104 105 106 107 108 109 110 111 112 113 114 115 116

	// currently storing key unencrypted. in the future we need to encrypt it.
	// TODO(security)
	skbytes, err := sk.Bytes()
	if err != nil {
		return ident, err
	}
	ident.PrivKey = base64.StdEncoding.EncodeToString(skbytes)

	id, err := peer.IDFromPublicKey(pk)
	if err != nil {
		return ident, err
	}
	ident.PeerID = id.Pretty()
117
	fmt.Fprintf(out, "peer identity: %s\n", ident.PeerID)
118 119
	return ident, nil
}