ipfs.go 2.8 KB
Newer Older
Brian Tiger Chow's avatar
Brian Tiger Chow committed
1 2 3 4
package main

import (
	"fmt"
5
	"io"
Brian Tiger Chow's avatar
Brian Tiger Chow committed
6 7 8
	"os"
	"runtime/pprof"

9
	cmds "github.com/jbenet/go-ipfs/commands"
10 11
	cmdsCli "github.com/jbenet/go-ipfs/commands/cli"
	cmdsHttp "github.com/jbenet/go-ipfs/commands/http"
12
	"github.com/jbenet/go-ipfs/config"
13
	"github.com/jbenet/go-ipfs/core/commands"
14
	"github.com/jbenet/go-ipfs/daemon"
Brian Tiger Chow's avatar
Brian Tiger Chow committed
15 16 17 18 19 20 21
	u "github.com/jbenet/go-ipfs/util"
)

// log is the command logger
var log = u.Logger("cmd/ipfs")

func main() {
22
	args := os.Args[1:]
23
	root := Root
24

25
	req, err := cmdsCli.Parse(args, root)
Brian Tiger Chow's avatar
Brian Tiger Chow committed
26
	if err != nil {
27
		fmt.Println(err)
Brian Tiger Chow's avatar
Brian Tiger Chow committed
28 29 30
		os.Exit(1)
	}

31
	// if the CLI-specific root doesn't contain the command, use the general root
32
	if len(req.Path()) == 0 {
33 34
		root = commands.Root
		req, err = cmdsCli.Parse(args, root)
35 36 37 38
		if err != nil {
			fmt.Println(err)
			os.Exit(1)
		}
Brian Tiger Chow's avatar
Brian Tiger Chow committed
39 40
	}

41 42
	cmd, err := root.Get(req.Path())
	if err != nil {
43 44 45
		fmt.Println(err)
		os.Exit(1)
	}
Brian Tiger Chow's avatar
Brian Tiger Chow committed
46

47 48 49 50 51
	options, err := getOptions(req, root)
	if err != nil {
		fmt.Println(err)
		os.Exit(1)
	}
52

53
	if debug, found := options.Option("debug"); found && debug.(bool) {
54
		u.Debug = true
Brian Tiger Chow's avatar
Brian Tiger Chow committed
55

56 57 58 59 60 61 62 63 64 65 66
		// if debugging, setup profiling.
		if u.Debug {
			ofi, err := os.Create("cpu.prof")
			if err != nil {
				fmt.Println(err)
				return
			}
			pprof.StartCPUProfile(ofi)
			defer ofi.Close()
			defer pprof.StopCPUProfile()
		}
Brian Tiger Chow's avatar
Brian Tiger Chow committed
67 68
	}

69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
	configPath, err := getConfigRoot(options)
	if err != nil {
		fmt.Println(err)
		os.Exit(1)
	}

	conf, err := getConfig(configPath)
	if err != nil {
		fmt.Println(err)
		os.Exit(1)
	}

	ctx := req.Context()
	ctx.ConfigRoot = configPath
	ctx.Config = conf

85
	var res cmds.Response
86
	if root == Root {
87
		res = root.Call(req)
88

89
	} else {
90
		if daemon.Locked(configPath) {
91 92 93 94 95 96 97 98 99 100
			res, err = cmdsHttp.Send(req)
			if err != nil {
				fmt.Println(err)
				os.Exit(1)
			}

		} else {
			// TODO: spin up node
			res = root.Call(req)
		}
101
	}
Brian Tiger Chow's avatar
Brian Tiger Chow committed
102

103 104
	if res.Error() != nil {
		fmt.Println(res.Error().Error())
Brian Tiger Chow's avatar
Brian Tiger Chow committed
105

106 107 108 109
		if cmd.Help != "" && res.Error().Code == cmds.ErrClient {
			// TODO: convert from markdown to ANSI terminal format?
			fmt.Println(cmd.Help)
		}
Brian Tiger Chow's avatar
Brian Tiger Chow committed
110

111
		os.Exit(1)
Brian Tiger Chow's avatar
Brian Tiger Chow committed
112 113
	}

114
	_, err = io.Copy(os.Stdout, res)
Brian Tiger Chow's avatar
Brian Tiger Chow committed
115
	if err != nil {
116
		fmt.Println(err.Error())
Brian Tiger Chow's avatar
Brian Tiger Chow committed
117 118
	}
}
119

120
func getOptions(req cmds.Request, root *cmds.Command) (cmds.Request, error) {
121 122 123 124 125 126 127 128 129 130 131 132
	tempReq := cmds.NewRequest(req.Path(), req.Options(), nil, nil)

	options, err := root.GetOptions(tempReq.Path())
	if err != nil {
		return nil, err
	}

	err = tempReq.ConvertOptions(options)
	if err != nil {
		return nil, err
	}

133 134 135
	return tempReq, nil
}

136
func getConfigRoot(req cmds.Request) (string, error) {
137 138 139 140 141 142 143 144 145
	if opt, found := req.Option("config"); found {
		return opt.(string), nil
	}

	configPath, err := config.PathRoot()
	if err != nil {
		return "", err
	}
	return configPath, nil
146
}
Matt Bell's avatar
Matt Bell committed
147 148 149 150 151 152 153 154 155

func getConfig(path string) (*config.Config, error) {
	configFile, err := config.Filename(path)
	if err != nil {
		return nil, err
	}

	return config.Load(configFile)
}