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)
 | |
| 	}
 | |
| }
 |