65f3c1b46f
This changes the CI build to store the git commit and date into package internal/version instead of package main. Doing this essentially merges our two ways of tracking the go-ethereum version into a single place, achieving two objectives: - Bad block reports, which use version.Info(), will now have the git commit information even when geth is built in an environment such as launchpad.net where git access is unavailable. - For geth builds created by `go build ./cmd/geth` (i.e. not using `go run build/ci.go install`), git information stored by the go tool is now used in the p2p node name as well as in `geth version` and `geth version-check`.
97 lines
2.7 KiB
Go
97 lines
2.7 KiB
Go
// Copyright 2019 The go-ethereum Authors
|
|
// This file is part of go-ethereum.
|
|
//
|
|
// go-ethereum is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// go-ethereum is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with go-ethereum. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
// checkpoint-admin is a utility that can be used to query checkpoint information
|
|
// and register stable checkpoints into an oracle contract.
|
|
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
|
|
"github.com/ethereum/go-ethereum/common/fdlimit"
|
|
"github.com/ethereum/go-ethereum/internal/flags"
|
|
"github.com/ethereum/go-ethereum/log"
|
|
"github.com/urfave/cli/v2"
|
|
)
|
|
|
|
var app = flags.NewApp("ethereum checkpoint helper tool")
|
|
|
|
func init() {
|
|
app.Commands = []*cli.Command{
|
|
commandStatus,
|
|
commandDeploy,
|
|
commandSign,
|
|
commandPublish,
|
|
}
|
|
app.Flags = []cli.Flag{
|
|
oracleFlag,
|
|
nodeURLFlag,
|
|
}
|
|
}
|
|
|
|
// Commonly used command line flags.
|
|
var (
|
|
indexFlag = &cli.Int64Flag{
|
|
Name: "index",
|
|
Usage: "Checkpoint index (query latest from remote node if not specified)",
|
|
}
|
|
hashFlag = &cli.StringFlag{
|
|
Name: "hash",
|
|
Usage: "Checkpoint hash (query latest from remote node if not specified)",
|
|
}
|
|
oracleFlag = &cli.StringFlag{
|
|
Name: "oracle",
|
|
Usage: "Checkpoint oracle address (query from remote node if not specified)",
|
|
}
|
|
thresholdFlag = &cli.Int64Flag{
|
|
Name: "threshold",
|
|
Usage: "Minimal number of signatures required to approve a checkpoint",
|
|
}
|
|
nodeURLFlag = &cli.StringFlag{
|
|
Name: "rpc",
|
|
Value: "http://localhost:8545",
|
|
Usage: "The rpc endpoint of a local or remote geth node",
|
|
}
|
|
clefURLFlag = &cli.StringFlag{
|
|
Name: "clef",
|
|
Value: "http://localhost:8550",
|
|
Usage: "The rpc endpoint of clef",
|
|
}
|
|
signerFlag = &cli.StringFlag{
|
|
Name: "signer",
|
|
Usage: "Signer address for clef signing",
|
|
}
|
|
signersFlag = &cli.StringFlag{
|
|
Name: "signers",
|
|
Usage: "Comma separated accounts of trusted checkpoint signers",
|
|
}
|
|
signaturesFlag = &cli.StringFlag{
|
|
Name: "signatures",
|
|
Usage: "Comma separated checkpoint signatures to submit",
|
|
}
|
|
)
|
|
|
|
func main() {
|
|
log.Root().SetHandler(log.LvlFilterHandler(log.LvlInfo, log.StreamHandler(os.Stderr, log.TerminalFormat(true))))
|
|
fdlimit.Raise(2048)
|
|
|
|
if err := app.Run(os.Args); err != nil {
|
|
fmt.Fprintln(os.Stderr, err)
|
|
os.Exit(1)
|
|
}
|
|
}
|