2023-10-14 04:05:44 +00:00
|
|
|
|
//go:build !js && !wasm
|
|
|
|
|
|
2023-08-21 03:50:38 +00:00
|
|
|
|
package main
|
|
|
|
|
|
|
|
|
|
import (
|
2024-03-01 07:12:31 +00:00
|
|
|
|
"crypto/rand"
|
|
|
|
|
"encoding/binary"
|
2023-08-21 03:50:38 +00:00
|
|
|
|
"encoding/hex"
|
|
|
|
|
"flag"
|
|
|
|
|
"fmt"
|
2023-09-25 02:43:35 +00:00
|
|
|
|
"io/fs"
|
2024-02-19 00:28:29 +00:00
|
|
|
|
"log"
|
2023-08-21 03:50:38 +00:00
|
|
|
|
"os"
|
|
|
|
|
"os/signal"
|
2023-09-25 02:43:35 +00:00
|
|
|
|
"path/filepath"
|
2024-03-01 07:12:31 +00:00
|
|
|
|
"runtime"
|
2024-02-19 00:28:29 +00:00
|
|
|
|
"runtime/pprof"
|
2024-03-24 08:11:58 +00:00
|
|
|
|
"strconv"
|
2023-08-21 03:50:38 +00:00
|
|
|
|
"syscall"
|
2024-02-19 00:28:29 +00:00
|
|
|
|
"time"
|
2023-08-21 03:50:38 +00:00
|
|
|
|
|
2024-03-01 07:12:31 +00:00
|
|
|
|
"go.uber.org/zap"
|
|
|
|
|
"google.golang.org/protobuf/proto"
|
2024-02-14 07:11:12 +00:00
|
|
|
|
"source.quilibrium.com/quilibrium/monorepo/node/protobufs"
|
2024-03-01 07:12:31 +00:00
|
|
|
|
"source.quilibrium.com/quilibrium/monorepo/node/utils"
|
2024-02-14 07:11:12 +00:00
|
|
|
|
|
2023-08-21 03:50:38 +00:00
|
|
|
|
"github.com/libp2p/go-libp2p/core/crypto"
|
|
|
|
|
"github.com/libp2p/go-libp2p/core/peer"
|
2024-03-01 07:12:31 +00:00
|
|
|
|
"github.com/pbnjay/memory"
|
2023-08-21 03:50:38 +00:00
|
|
|
|
"github.com/pkg/errors"
|
2023-09-03 23:47:09 +00:00
|
|
|
|
"source.quilibrium.com/quilibrium/monorepo/node/app"
|
2023-08-21 03:50:38 +00:00
|
|
|
|
"source.quilibrium.com/quilibrium/monorepo/node/config"
|
2024-03-01 07:12:31 +00:00
|
|
|
|
qcrypto "source.quilibrium.com/quilibrium/monorepo/node/crypto"
|
2024-02-13 07:04:56 +00:00
|
|
|
|
"source.quilibrium.com/quilibrium/monorepo/node/crypto/kzg"
|
2023-10-09 04:52:19 +00:00
|
|
|
|
"source.quilibrium.com/quilibrium/monorepo/node/rpc"
|
2023-08-21 03:50:38 +00:00
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
var (
|
2023-09-09 23:45:47 +00:00
|
|
|
|
configDirectory = flag.String(
|
|
|
|
|
"config",
|
2024-01-03 07:31:42 +00:00
|
|
|
|
filepath.Join(".", ".config"),
|
2023-09-09 23:45:47 +00:00
|
|
|
|
"the configuration directory",
|
|
|
|
|
)
|
2024-01-29 21:11:40 +00:00
|
|
|
|
balance = flag.Bool(
|
|
|
|
|
"balance",
|
|
|
|
|
false,
|
|
|
|
|
"print the node's confirmed token balance to stdout and exit",
|
2023-09-09 23:45:47 +00:00
|
|
|
|
)
|
|
|
|
|
dbConsole = flag.Bool(
|
|
|
|
|
"db-console",
|
|
|
|
|
false,
|
|
|
|
|
"starts the node in database console mode",
|
|
|
|
|
)
|
2024-01-29 21:11:40 +00:00
|
|
|
|
importPrivKey = flag.String(
|
|
|
|
|
"import-priv-key",
|
|
|
|
|
"",
|
|
|
|
|
"creates a new config using a specific key from the phase one ceremony",
|
|
|
|
|
)
|
2024-01-04 22:48:00 +00:00
|
|
|
|
peerId = flag.Bool(
|
|
|
|
|
"peer-id",
|
|
|
|
|
false,
|
|
|
|
|
"print the peer id to stdout from the config and exit",
|
|
|
|
|
)
|
2024-03-23 20:26:57 +00:00
|
|
|
|
cpuprofile = flag.String(
|
|
|
|
|
"cpuprofile",
|
|
|
|
|
"",
|
|
|
|
|
"write cpu profile to file",
|
|
|
|
|
)
|
2024-02-19 00:28:29 +00:00
|
|
|
|
memprofile = flag.String(
|
|
|
|
|
"memprofile",
|
|
|
|
|
"",
|
|
|
|
|
"write memory profile after 20m to this file",
|
|
|
|
|
)
|
2024-03-24 08:11:58 +00:00
|
|
|
|
nodeInfo = flag.Bool(
|
|
|
|
|
"node-info",
|
|
|
|
|
false,
|
|
|
|
|
"print node related information",
|
|
|
|
|
)
|
2023-08-21 03:50:38 +00:00
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
|
flag.Parse()
|
|
|
|
|
|
2024-02-19 00:28:29 +00:00
|
|
|
|
if *memprofile != "" {
|
|
|
|
|
go func() {
|
|
|
|
|
for {
|
2024-02-20 07:59:03 +00:00
|
|
|
|
time.Sleep(5 * time.Minute)
|
2024-02-19 00:28:29 +00:00
|
|
|
|
f, err := os.Create(*memprofile)
|
|
|
|
|
if err != nil {
|
|
|
|
|
log.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
pprof.WriteHeapProfile(f)
|
|
|
|
|
f.Close()
|
|
|
|
|
}
|
|
|
|
|
}()
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-23 20:26:57 +00:00
|
|
|
|
if *cpuprofile != "" {
|
|
|
|
|
f, err := os.Create(*cpuprofile)
|
|
|
|
|
if err != nil {
|
|
|
|
|
log.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
pprof.StartCPUProfile(f)
|
|
|
|
|
defer pprof.StopCPUProfile()
|
|
|
|
|
}
|
|
|
|
|
|
2024-01-29 21:11:40 +00:00
|
|
|
|
if *balance {
|
|
|
|
|
config, err := config.LoadConfig(*configDirectory, "")
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-24 08:11:58 +00:00
|
|
|
|
printBalance(config)
|
2024-01-29 21:11:40 +00:00
|
|
|
|
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
2024-01-04 22:48:00 +00:00
|
|
|
|
if *peerId {
|
|
|
|
|
config, err := config.LoadConfig(*configDirectory, "")
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
printPeerID(config.P2P)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
2023-08-21 03:50:38 +00:00
|
|
|
|
if *importPrivKey != "" {
|
|
|
|
|
config, err := config.LoadConfig(*configDirectory, *importPrivKey)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
printPeerID(config.P2P)
|
|
|
|
|
fmt.Println("Import completed, you are ready for the launch.")
|
|
|
|
|
return
|
|
|
|
|
}
|
2024-03-24 08:11:58 +00:00
|
|
|
|
|
|
|
|
|
if *nodeInfo {
|
|
|
|
|
config, err := config.LoadConfig(*configDirectory, "")
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
printNodeInfo(config)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
2023-08-21 03:50:38 +00:00
|
|
|
|
done := make(chan os.Signal, 1)
|
|
|
|
|
signal.Notify(done, syscall.SIGINT, syscall.SIGTERM)
|
|
|
|
|
|
2023-11-27 02:51:46 +00:00
|
|
|
|
if !*dbConsole {
|
|
|
|
|
printLogo()
|
|
|
|
|
printVersion()
|
|
|
|
|
fmt.Println(" ")
|
|
|
|
|
}
|
2023-08-21 03:50:38 +00:00
|
|
|
|
|
2023-09-03 23:47:09 +00:00
|
|
|
|
nodeConfig, err := config.LoadConfig(*configDirectory, "")
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
2023-09-25 02:43:35 +00:00
|
|
|
|
clearIfTestData(*configDirectory, nodeConfig)
|
|
|
|
|
|
2023-09-09 23:45:47 +00:00
|
|
|
|
if *dbConsole {
|
|
|
|
|
console, err := app.NewDBConsole(nodeConfig)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
console.Run()
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
2023-09-25 02:43:35 +00:00
|
|
|
|
fmt.Println("Loading ceremony state and starting node...")
|
2024-02-13 07:04:56 +00:00
|
|
|
|
kzg.Init()
|
2023-09-25 02:43:35 +00:00
|
|
|
|
|
2024-03-01 07:12:31 +00:00
|
|
|
|
report := RunSelfTestIfNeeded(*configDirectory, nodeConfig)
|
|
|
|
|
|
|
|
|
|
node, err := app.NewNode(nodeConfig, report)
|
2023-09-03 23:47:09 +00:00
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
2023-10-09 04:52:19 +00:00
|
|
|
|
|
2024-03-08 05:05:04 +00:00
|
|
|
|
repair(*configDirectory, node)
|
|
|
|
|
|
2023-10-09 04:52:19 +00:00
|
|
|
|
if nodeConfig.ListenGRPCMultiaddr != "" {
|
|
|
|
|
srv, err := rpc.NewRPCServer(
|
|
|
|
|
nodeConfig.ListenGRPCMultiaddr,
|
|
|
|
|
nodeConfig.ListenRestMultiaddr,
|
|
|
|
|
node.GetLogger(),
|
|
|
|
|
node.GetClockStore(),
|
2023-10-28 02:23:55 +00:00
|
|
|
|
node.GetKeyManager(),
|
2023-10-09 04:52:19 +00:00
|
|
|
|
node.GetPubSub(),
|
2024-03-04 03:20:24 +00:00
|
|
|
|
node.GetMasterClock(),
|
2023-10-09 04:52:19 +00:00
|
|
|
|
node.GetExecutionEngines(),
|
|
|
|
|
)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
|
err := srv.Start()
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
}()
|
|
|
|
|
}
|
|
|
|
|
|
2023-09-03 23:47:09 +00:00
|
|
|
|
node.Start()
|
|
|
|
|
|
|
|
|
|
<-done
|
|
|
|
|
node.Stop()
|
2023-08-21 03:50:38 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-03-01 07:12:31 +00:00
|
|
|
|
func RunSelfTestIfNeeded(
|
|
|
|
|
configDir string,
|
|
|
|
|
nodeConfig *config.Config,
|
|
|
|
|
) *protobufs.SelfTestReport {
|
|
|
|
|
logger, _ := zap.NewProduction()
|
|
|
|
|
|
|
|
|
|
cores := runtime.GOMAXPROCS(0)
|
|
|
|
|
memory := memory.TotalMemory()
|
2024-03-14 07:18:14 +00:00
|
|
|
|
d, err := os.Stat(filepath.Join(configDir, "store"))
|
|
|
|
|
if d == nil {
|
|
|
|
|
err := os.Mkdir(filepath.Join(configDir, "store"), 0755)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-01 07:12:31 +00:00
|
|
|
|
f, err := os.Stat(filepath.Join(configDir, "SELF_TEST"))
|
|
|
|
|
|
|
|
|
|
if f != nil {
|
|
|
|
|
if f.Size() != 0 {
|
|
|
|
|
report := &protobufs.SelfTestReport{}
|
|
|
|
|
|
|
|
|
|
selfTestBytes, err := os.ReadFile(filepath.Join(configDir, "SELF_TEST"))
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err = proto.Unmarshal(selfTestBytes, report)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if report.Cores == uint32(cores) &&
|
|
|
|
|
binary.BigEndian.Uint64(report.Memory) == memory {
|
|
|
|
|
return report
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
logger.Info("no self-test report found, generating")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
report := &protobufs.SelfTestReport{}
|
|
|
|
|
difficulty := nodeConfig.Engine.Difficulty
|
|
|
|
|
if difficulty == 0 {
|
|
|
|
|
difficulty = 10000
|
|
|
|
|
}
|
|
|
|
|
report.Difficulty = difficulty
|
|
|
|
|
|
|
|
|
|
frameProver := qcrypto.NewWesolowskiFrameProver(logger)
|
|
|
|
|
|
|
|
|
|
logger.Info("generating difficulty metric")
|
|
|
|
|
|
|
|
|
|
start := time.Now().UnixMilli()
|
|
|
|
|
_, err = frameProver.ProveMasterClockFrame(
|
|
|
|
|
&protobufs.ClockFrame{
|
|
|
|
|
Filter: []byte{0x00},
|
|
|
|
|
FrameNumber: 0,
|
|
|
|
|
Timestamp: 0,
|
|
|
|
|
Difficulty: difficulty,
|
|
|
|
|
ParentSelector: []byte{0x00},
|
|
|
|
|
Input: make([]byte, 516),
|
|
|
|
|
Output: make([]byte, 516),
|
|
|
|
|
},
|
|
|
|
|
0,
|
|
|
|
|
difficulty,
|
|
|
|
|
)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
end := time.Now().UnixMilli()
|
|
|
|
|
report.DifficultyMetric = end - start
|
|
|
|
|
|
|
|
|
|
logger.Info("generating entropy for commit/proof sizes")
|
|
|
|
|
|
|
|
|
|
p16bytes := make([]byte, 1024)
|
|
|
|
|
p128bytes := make([]byte, 8192)
|
|
|
|
|
p1024bytes := make([]byte, 65536)
|
|
|
|
|
p65536bytes := make([]byte, 4194304)
|
|
|
|
|
rand.Read(p16bytes)
|
|
|
|
|
rand.Read(p128bytes)
|
|
|
|
|
rand.Read(p1024bytes)
|
|
|
|
|
rand.Read(p65536bytes)
|
|
|
|
|
kzgProver := kzg.DefaultKZGProver()
|
|
|
|
|
|
|
|
|
|
p16, _ := kzgProver.BytesToPolynomial(p16bytes)
|
|
|
|
|
p128, _ := kzgProver.BytesToPolynomial(p128bytes)
|
|
|
|
|
p1024, _ := kzgProver.BytesToPolynomial(p1024bytes)
|
|
|
|
|
p65536, _ := kzgProver.BytesToPolynomial(p65536bytes)
|
|
|
|
|
|
|
|
|
|
logger.Info("generating 16 degree commitment metric")
|
|
|
|
|
start = time.Now().UnixMilli()
|
|
|
|
|
c16, err := kzgProver.Commit(p16)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
end = time.Now().UnixMilli()
|
|
|
|
|
report.Commit_16Metric = end - start
|
|
|
|
|
|
|
|
|
|
logger.Info("generating 128 degree commitment metric")
|
|
|
|
|
start = time.Now().UnixMilli()
|
|
|
|
|
c128, err := kzgProver.Commit(p128)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
end = time.Now().UnixMilli()
|
|
|
|
|
report.Commit_128Metric = end - start
|
|
|
|
|
|
|
|
|
|
logger.Info("generating 1024 degree commitment metric")
|
|
|
|
|
start = time.Now().UnixMilli()
|
|
|
|
|
c1024, err := kzgProver.Commit(p1024)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
end = time.Now().UnixMilli()
|
|
|
|
|
report.Commit_1024Metric = end - start
|
|
|
|
|
|
|
|
|
|
logger.Info("generating 65536 degree commitment metric")
|
|
|
|
|
start = time.Now().UnixMilli()
|
|
|
|
|
c65536, err := kzgProver.Commit(p65536)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
end = time.Now().UnixMilli()
|
|
|
|
|
report.Commit_65536Metric = end - start
|
|
|
|
|
|
|
|
|
|
logger.Info("generating 16 degree proof metric")
|
|
|
|
|
start = time.Now().UnixMilli()
|
|
|
|
|
_, err = kzgProver.Prove(p16, c16, p16[0])
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
end = time.Now().UnixMilli()
|
|
|
|
|
report.Proof_16Metric = end - start
|
|
|
|
|
|
|
|
|
|
logger.Info("generating 128 degree proof metric")
|
|
|
|
|
start = time.Now().UnixMilli()
|
|
|
|
|
_, err = kzgProver.Prove(p128, c128, p128[0])
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
end = time.Now().UnixMilli()
|
|
|
|
|
report.Proof_128Metric = end - start
|
|
|
|
|
|
|
|
|
|
logger.Info("generating 1024 degree proof metric")
|
|
|
|
|
start = time.Now().UnixMilli()
|
|
|
|
|
_, err = kzgProver.Prove(p1024, c1024, p1024[0])
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
end = time.Now().UnixMilli()
|
|
|
|
|
report.Proof_1024Metric = end - start
|
|
|
|
|
|
|
|
|
|
logger.Info("generating 65536 degree proof metric")
|
|
|
|
|
start = time.Now().UnixMilli()
|
|
|
|
|
_, err = kzgProver.Prove(p65536, c65536, p65536[0])
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
end = time.Now().UnixMilli()
|
|
|
|
|
report.Proof_65536Metric = end - start
|
|
|
|
|
|
|
|
|
|
report.Cores = uint32(cores)
|
|
|
|
|
report.Memory = binary.BigEndian.AppendUint64([]byte{}, memory)
|
|
|
|
|
disk := utils.GetDiskSpace(nodeConfig.DB.Path)
|
|
|
|
|
report.Storage = binary.BigEndian.AppendUint64([]byte{}, disk)
|
|
|
|
|
logger.Info("writing report")
|
|
|
|
|
|
|
|
|
|
// tag: dusk – capabilities report in v1.5
|
|
|
|
|
reportBytes, err := proto.Marshal(report)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err = os.WriteFile(
|
|
|
|
|
filepath.Join(configDir, "SELF_TEST"),
|
|
|
|
|
reportBytes,
|
|
|
|
|
fs.FileMode(0600),
|
|
|
|
|
)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return report
|
|
|
|
|
}
|
|
|
|
|
|
2023-09-25 02:43:35 +00:00
|
|
|
|
func clearIfTestData(configDir string, nodeConfig *config.Config) {
|
|
|
|
|
_, err := os.Stat(filepath.Join(configDir, "RELEASE_VERSION"))
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
fmt.Println("Clearing test data...")
|
|
|
|
|
err := os.RemoveAll(nodeConfig.DB.Path)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
versionFile, err := os.OpenFile(
|
|
|
|
|
filepath.Join(configDir, "RELEASE_VERSION"),
|
|
|
|
|
os.O_CREATE|os.O_RDWR,
|
2024-02-29 06:02:49 +00:00
|
|
|
|
fs.FileMode(0600),
|
2023-09-25 02:43:35 +00:00
|
|
|
|
)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_, err = versionFile.Write([]byte{0x01, 0x00, 0x00})
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err = versionFile.Close()
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-08 05:05:04 +00:00
|
|
|
|
func repair(configDir string, node *app.Node) {
|
|
|
|
|
_, err := os.Stat(filepath.Join(configDir, "REPAIR"))
|
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
|
node.RunRepair()
|
|
|
|
|
|
|
|
|
|
repairFile, err := os.OpenFile(
|
|
|
|
|
filepath.Join(configDir, "REPAIR"),
|
|
|
|
|
os.O_CREATE|os.O_RDWR,
|
|
|
|
|
fs.FileMode(0600),
|
|
|
|
|
)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_, err = repairFile.Write([]byte{0x00, 0x00, 0x01})
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err = repairFile.Close()
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-24 08:11:58 +00:00
|
|
|
|
func printBalance(config *config.Config) {
|
|
|
|
|
if config.ListenGRPCMultiaddr == "" {
|
|
|
|
|
_, _ = fmt.Fprintf(os.Stderr, "gRPC Not Enabled, Please Configure\n")
|
|
|
|
|
os.Exit(1)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
conn, err := app.ConnectToNode(config)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
defer conn.Close()
|
|
|
|
|
|
|
|
|
|
client := protobufs.NewNodeServiceClient(conn)
|
|
|
|
|
|
|
|
|
|
balance, err := app.FetchTokenBalance(client)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fmt.Println("Owned balance:", balance.Owned, "QUIL")
|
|
|
|
|
fmt.Println("Unconfirmed balance:", balance.UnconfirmedOwned, "QUIL")
|
|
|
|
|
}
|
|
|
|
|
|
2023-08-21 03:50:38 +00:00
|
|
|
|
func printPeerID(p2pConfig *config.P2PConfig) {
|
|
|
|
|
peerPrivKey, err := hex.DecodeString(p2pConfig.PeerPrivKey)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(errors.Wrap(err, "error unmarshaling peerkey"))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
privKey, err := crypto.UnmarshalEd448PrivateKey(peerPrivKey)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(errors.Wrap(err, "error unmarshaling peerkey"))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pub := privKey.GetPublic()
|
|
|
|
|
id, err := peer.IDFromPublicKey(pub)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(errors.Wrap(err, "error getting peer id"))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fmt.Println("Peer ID: " + id.String())
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-24 08:11:58 +00:00
|
|
|
|
func printNodeInfo(cfg *config.Config) {
|
|
|
|
|
if cfg.ListenGRPCMultiaddr == "" {
|
|
|
|
|
_, _ = fmt.Fprintf(os.Stderr, "gRPC Not Enabled, Please Configure\n")
|
|
|
|
|
os.Exit(1)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
printPeerID(cfg.P2P)
|
|
|
|
|
|
|
|
|
|
conn, err := app.ConnectToNode(cfg)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
defer conn.Close()
|
|
|
|
|
|
|
|
|
|
client := protobufs.NewNodeServiceClient(conn)
|
|
|
|
|
|
|
|
|
|
nodeInfo, err := app.FetchNodeInfo(client)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fmt.Println("Version: " + config.FormatVersion(nodeInfo.Version))
|
|
|
|
|
|
|
|
|
|
fmt.Println("Max Fame: " + strconv.FormatUint(nodeInfo.GetMaxFrame(), 10))
|
|
|
|
|
|
|
|
|
|
printBalance(cfg)
|
|
|
|
|
}
|
|
|
|
|
|
2023-08-21 03:50:38 +00:00
|
|
|
|
func printLogo() {
|
|
|
|
|
fmt.Println(" %#########")
|
|
|
|
|
fmt.Println(" #############################")
|
|
|
|
|
fmt.Println(" ########################################&")
|
|
|
|
|
fmt.Println(" ###############################################")
|
|
|
|
|
fmt.Println(" &#####################% %######################")
|
|
|
|
|
fmt.Println(" ################# #################")
|
|
|
|
|
fmt.Println(" ############### ###############")
|
|
|
|
|
fmt.Println(" ############# ##############")
|
|
|
|
|
fmt.Println(" ############# ############&")
|
|
|
|
|
fmt.Println(" ############ ############")
|
|
|
|
|
fmt.Println(" ########### ########## &###########")
|
|
|
|
|
fmt.Println(" ########### ############## ###########")
|
|
|
|
|
fmt.Println(" ########### ############## ##########&")
|
|
|
|
|
fmt.Println(" ########## ############## ##########")
|
|
|
|
|
fmt.Println("%########## ########## ##########")
|
2024-03-01 07:12:31 +00:00
|
|
|
|
fmt.Println("########## ##########")
|
2023-08-21 03:50:38 +00:00
|
|
|
|
fmt.Println("########## &#########")
|
2024-03-01 07:12:31 +00:00
|
|
|
|
fmt.Println("########## ####### ####### ##########")
|
|
|
|
|
fmt.Println("%######### &######################### ##########")
|
2023-08-21 03:50:38 +00:00
|
|
|
|
fmt.Println(" ########## ##############% ############## &##########")
|
2024-03-01 07:12:31 +00:00
|
|
|
|
fmt.Println(" ' ' &############## ############### ##########")
|
|
|
|
|
fmt.Println(" ' ' ############### ##############% ###########")
|
|
|
|
|
fmt.Println(" ' '. ########## ############### ########")
|
|
|
|
|
fmt.Println(" '. . ##### ##############% ####")
|
|
|
|
|
fmt.Println(" ' '. ###############")
|
|
|
|
|
fmt.Println(" '. '.. ##############%")
|
|
|
|
|
fmt.Println(" '. '-. ###############")
|
|
|
|
|
fmt.Println(" '-. ''-.. .. ##############%")
|
|
|
|
|
fmt.Println(" '-. ''---............----' '. ###############")
|
|
|
|
|
fmt.Println(" '-.. '. ############")
|
|
|
|
|
fmt.Println(" ''-.. ..' ########")
|
|
|
|
|
fmt.Println(" ''---.. ...---'' ##")
|
|
|
|
|
fmt.Println(" ''----------''")
|
2023-08-21 03:50:38 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func printVersion() {
|
|
|
|
|
fmt.Println(" ")
|
2024-03-13 01:29:40 +00:00
|
|
|
|
fmt.Println(" Quilibrium Node - v" + config.GetVersionString() + " – Sunset")
|
2023-08-21 03:50:38 +00:00
|
|
|
|
}
|