2019-11-15 16:38:56 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2019-11-19 12:57:16 +00:00
|
|
|
"net/http"
|
2020-02-21 18:49:21 +00:00
|
|
|
_ "net/http/pprof"
|
2019-11-19 12:57:16 +00:00
|
|
|
"os"
|
|
|
|
|
2020-01-08 19:10:57 +00:00
|
|
|
logging "github.com/ipfs/go-log/v2"
|
2019-11-16 19:51:54 +00:00
|
|
|
"golang.org/x/xerrors"
|
2019-11-15 16:38:56 +00:00
|
|
|
"gopkg.in/urfave/cli.v2"
|
2019-11-19 12:57:16 +00:00
|
|
|
|
|
|
|
"github.com/filecoin-project/lotus/build"
|
|
|
|
lcli "github.com/filecoin-project/lotus/cli"
|
2019-11-15 16:38:56 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var log = logging.Logger("chainwatch")
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
logging.SetLogLevel("*", "INFO")
|
|
|
|
|
|
|
|
log.Info("Starting chainwatch")
|
|
|
|
|
|
|
|
local := []*cli.Command{
|
|
|
|
runCmd,
|
2019-11-18 20:11:43 +00:00
|
|
|
dotCmd,
|
2019-11-15 16:38:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
app := &cli.App{
|
|
|
|
Name: "lotus-chainwatch",
|
|
|
|
Usage: "Devnet token distribution utility",
|
2019-12-11 22:00:39 +00:00
|
|
|
Version: build.UserVersion,
|
2019-11-15 16:38:56 +00:00
|
|
|
Flags: []cli.Flag{
|
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "repo",
|
|
|
|
EnvVars: []string{"LOTUS_PATH"},
|
|
|
|
Value: "~/.lotus", // TODO: Consider XDG_DATA_HOME
|
|
|
|
},
|
2019-12-05 11:58:19 +00:00
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "db",
|
|
|
|
EnvVars: []string{"LOTUS_DB"},
|
2019-12-10 23:42:36 +00:00
|
|
|
Value: "",
|
2019-12-05 11:58:19 +00:00
|
|
|
},
|
2019-11-15 16:38:56 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
Commands: local,
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := app.Run(os.Args); err != nil {
|
2019-11-16 19:51:54 +00:00
|
|
|
log.Warnf("%+v", err)
|
2019-11-15 16:38:56 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var runCmd = &cli.Command{
|
|
|
|
Name: "run",
|
|
|
|
Usage: "Start lotus chainwatch",
|
|
|
|
Flags: []cli.Flag{
|
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "front",
|
|
|
|
Value: "127.0.0.1:8418",
|
|
|
|
},
|
2020-02-21 18:49:49 +00:00
|
|
|
&cli.IntFlag{
|
|
|
|
Name: "max-batch",
|
|
|
|
Value: 1000,
|
|
|
|
},
|
2019-11-15 16:38:56 +00:00
|
|
|
},
|
|
|
|
Action: func(cctx *cli.Context) error {
|
|
|
|
api, closer, err := lcli.GetFullNodeAPI(cctx)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer closer()
|
|
|
|
ctx := lcli.ReqContext(cctx)
|
|
|
|
|
|
|
|
v, err := api.Version(ctx)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-03-09 18:18:30 +00:00
|
|
|
log.Infof("Remote version: %s", v.Version)
|
|
|
|
|
2020-02-21 18:49:49 +00:00
|
|
|
maxBatch := cctx.Int("max-batch")
|
|
|
|
|
2019-12-05 11:58:19 +00:00
|
|
|
st, err := openStorage(cctx.String("db"))
|
2019-11-15 16:38:56 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer st.close()
|
|
|
|
|
2020-02-21 18:49:49 +00:00
|
|
|
runSyncer(ctx, api, st, maxBatch)
|
2019-11-15 16:38:56 +00:00
|
|
|
|
2019-11-16 19:47:06 +00:00
|
|
|
h, err := newHandler(api, st)
|
|
|
|
if err != nil {
|
2019-11-16 19:51:54 +00:00
|
|
|
return xerrors.Errorf("handler setup: %w", err)
|
2019-11-16 19:47:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
http.Handle("/", h)
|
|
|
|
|
|
|
|
fmt.Printf("Open http://%s\n", cctx.String("front"))
|
|
|
|
|
2019-11-15 16:38:56 +00:00
|
|
|
go func() {
|
|
|
|
<-ctx.Done()
|
|
|
|
os.Exit(0)
|
|
|
|
}()
|
|
|
|
|
|
|
|
return http.ListenAndServe(cctx.String("front"), nil)
|
|
|
|
},
|
|
|
|
}
|