package main import ( "fmt" "net/http" 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" cmds "github.com/jbenet/go-ipfs/commands" cmdsHttp "github.com/jbenet/go-ipfs/commands/http" "github.com/jbenet/go-ipfs/core" commands "github.com/jbenet/go-ipfs/core/commands2" daemon "github.com/jbenet/go-ipfs/daemon2" ) var daemonCmd = &cmds.Command{ Options: []cmds.Option{}, Help: "run a network-connected ipfs node", // TODO adjust copy Subcommands: map[string]*cmds.Command{}, Run: daemonFunc, } func daemonFunc(res cmds.Response, req cmds.Request) { ctx := req.Context() lock, err := daemon.Lock(ctx.ConfigRoot) if err != nil { res.SetError(fmt.Errorf("Couldn't obtain lock. Is another daemon already running?"), cmds.ErrNormal) return } defer lock.Close() node, err := core.NewIpfsNode(ctx.Config, true) if err != nil { res.SetError(err, cmds.ErrNormal) return } ctx.Node = node addr, err := ma.NewMultiaddr(ctx.Config.Addresses.API) if err != nil { res.SetError(err, cmds.ErrNormal) return } _, host, err := manet.DialArgs(addr) if err != nil { res.SetError(err, cmds.ErrNormal) return } handler := cmdsHttp.NewHandler(*ctx, commands.Root) http.Handle(cmdsHttp.ApiPath+"/", handler) fmt.Printf("API server listening on '%s'\n", host) err = http.ListenAndServe(host, nil) if err != nil { res.SetError(err, cmds.ErrNormal) return } }