daemon.go 1.38 KB
Newer Older
1 2 3
package main

import (
4
	"fmt"
5 6
	"net/http"

7 8
	ma "github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-multiaddr"
	manet "github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-multiaddr/net"
9

10 11
	cmds "github.com/jbenet/go-ipfs/commands"
	cmdsHttp "github.com/jbenet/go-ipfs/commands/http"
12
	"github.com/jbenet/go-ipfs/core"
13
	daemon "github.com/jbenet/go-ipfs/daemon2"
14 15
)

16
var daemonCmd = &cmds.Command{
17 18 19 20 21 22
	Options:     []cmds.Option{},
	Help:        "TODO",
	Subcommands: map[string]*cmds.Command{},
	Run:         daemonFunc,
}

23
func daemonFunc(res cmds.Response, req cmds.Request) {
24
	ctx := req.Context()
25

26
	lk, err := daemon.Lock(ctx.ConfigRoot)
27
	if err != nil {
28
		res.SetError(fmt.Errorf("Couldn't obtain lock. Is another daemon already running?"), cmds.ErrNormal)
29 30
		return
	}
31
	defer lk.Close()
32

33
	node, err := core.NewIpfsNode(ctx.Config, true)
34
	if err != nil {
35
		res.SetError(err, cmds.ErrNormal)
36 37
		return
	}
38
	ctx.Node = node
39

40
	addr, err := ma.NewMultiaddr(ctx.Config.Addresses.API)
41 42 43 44 45 46 47 48 49 50 51
	if err != nil {
		res.SetError(err, cmds.ErrNormal)
		return
	}

	_, host, err := manet.DialArgs(addr)
	if err != nil {
		res.SetError(err, cmds.ErrNormal)
		return
	}

52
	handler := cmdsHttp.Handler{*ctx}
53
	http.Handle(cmdsHttp.ApiPath+"/", handler)
54 55 56

	fmt.Printf("API server listening on '%s'\n", host)

57
	err = http.ListenAndServe(host, nil)
58 59 60 61 62
	if err != nil {
		res.SetError(err, cmds.ErrNormal)
		return
	}
}