mirror of
https://source.quilibrium.com/quilibrium/ceremonyclient.git
synced 2025-01-26 23:55:18 +00:00
feat: add balance flag to CLI (#38)
This commit is contained in:
parent
46f9014df2
commit
69213f6c61
12
README.md
12
README.md
@ -21,7 +21,7 @@ If you do not, or have already run the above, run:
|
|||||||
|
|
||||||
In order to find the peer id of a running node, execute the following command from the `node/` folder:
|
In order to find the peer id of a running node, execute the following command from the `node/` folder:
|
||||||
|
|
||||||
GOEXPERIMENT=arenas go run ./... --peer-id
|
GOEXPERIMENT=arenas go run ./... -peer-id
|
||||||
|
|
||||||
The peer id will be printed to stdout.
|
The peer id will be printed to stdout.
|
||||||
|
|
||||||
@ -36,6 +36,16 @@ Please note: this interface, while read-only, is unauthenticated and not rate-
|
|||||||
limited. It is recommended that you only enable if you are properly controlling
|
limited. It is recommended that you only enable if you are properly controlling
|
||||||
access via firewall or only query via localhost.
|
access via firewall or only query via localhost.
|
||||||
|
|
||||||
|
## Token Balance
|
||||||
|
|
||||||
|
In order to query the token balance of a running node, execute the following command from the `node/` folder:
|
||||||
|
|
||||||
|
GOEXPERIMENT=arenas go run ./... -balance
|
||||||
|
|
||||||
|
The confirmed token balance will be printed to stdout in QUILs.
|
||||||
|
|
||||||
|
Note that this feature requires that [gRPC support](#experimental--grpcrest-support) is enabled.
|
||||||
|
|
||||||
## Purpose
|
## Purpose
|
||||||
|
|
||||||
The ceremony application provides a secure reference string (SRS) from which
|
The ceremony application provides a secure reference string (SRS) from which
|
||||||
|
@ -110,16 +110,11 @@ func (m model) Update(msg tea.Msg) (tea.Model, tea.Cmd) {
|
|||||||
if m.conn.GetState() == connectivity.Ready {
|
if m.conn.GetState() == connectivity.Ready {
|
||||||
if m.lastChecked < (time.Now().UnixMilli() - 10_000) {
|
if m.lastChecked < (time.Now().UnixMilli() - 10_000) {
|
||||||
m.lastChecked = time.Now().UnixMilli()
|
m.lastChecked = time.Now().UnixMilli()
|
||||||
info, err := m.client.GetTokenInfo(
|
|
||||||
context.Background(),
|
tokenBalance, err := FetchTokenBalance(m.client)
|
||||||
&protobufs.GetTokenInfoRequest{},
|
|
||||||
)
|
|
||||||
if err == nil {
|
if err == nil {
|
||||||
conversionFactor, _ := new(big.Int).SetString("1DCD65000", 16)
|
m.owned = tokenBalance.Owned
|
||||||
m.owned = new(big.Int).SetBytes(info.OwnedTokens)
|
m.unconfirmedOwned = tokenBalance.UnconfirmedOwned
|
||||||
m.owned.Div(m.owned, conversionFactor)
|
|
||||||
m.unconfirmedOwned = new(big.Int).SetBytes(info.UnconfirmedOwnedTokens)
|
|
||||||
m.unconfirmedOwned.Div(m.unconfirmedOwned, conversionFactor)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -781,12 +776,13 @@ func consoleModel(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Runs the DB console
|
var defaultGrpcAddress = "localhost:8337"
|
||||||
func (c *DBConsole) Run() {
|
|
||||||
grpcWarn := true
|
// Connect to the node via GRPC
|
||||||
addr := "localhost:8337"
|
func ConnectToNode(nodeConfig *config.Config) (*grpc.ClientConn, error) {
|
||||||
if c.nodeConfig.ListenGRPCMultiaddr != "" {
|
addr := defaultGrpcAddress
|
||||||
ma, err := multiaddr.NewMultiaddr(c.nodeConfig.ListenGRPCMultiaddr)
|
if nodeConfig.ListenGRPCMultiaddr != "" {
|
||||||
|
ma, err := multiaddr.NewMultiaddr(nodeConfig.ListenGRPCMultiaddr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
@ -795,10 +791,9 @@ func (c *DBConsole) Run() {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
grpcWarn = false
|
|
||||||
}
|
}
|
||||||
|
|
||||||
conn, err := grpc.Dial(
|
return grpc.Dial(
|
||||||
addr,
|
addr,
|
||||||
grpc.WithTransportCredentials(
|
grpc.WithTransportCredentials(
|
||||||
insecure.NewCredentials(),
|
insecure.NewCredentials(),
|
||||||
@ -808,11 +803,46 @@ func (c *DBConsole) Run() {
|
|||||||
grpc.MaxCallRecvMsgSize(600*1024*1024),
|
grpc.MaxCallRecvMsgSize(600*1024*1024),
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
type TokenBalance struct {
|
||||||
|
Owned *big.Int
|
||||||
|
UnconfirmedOwned *big.Int
|
||||||
|
}
|
||||||
|
|
||||||
|
func FetchTokenBalance(client protobufs.NodeServiceClient) (TokenBalance, error) {
|
||||||
|
info, err := client.GetTokenInfo(
|
||||||
|
context.Background(),
|
||||||
|
&protobufs.GetTokenInfoRequest{},
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
|
return TokenBalance{}, errors.Wrap(err, "error getting token info")
|
||||||
|
}
|
||||||
|
|
||||||
|
conversionFactor, _ := new(big.Int).SetString("1DCD65000", 16)
|
||||||
|
|
||||||
|
owned := new(big.Int).SetBytes(info.OwnedTokens)
|
||||||
|
owned.Div(owned, conversionFactor)
|
||||||
|
|
||||||
|
unconfirmedOwned := new(big.Int).SetBytes(info.UnconfirmedOwnedTokens)
|
||||||
|
unconfirmedOwned.Div(unconfirmedOwned, conversionFactor)
|
||||||
|
|
||||||
|
return TokenBalance{
|
||||||
|
Owned: owned,
|
||||||
|
UnconfirmedOwned: unconfirmedOwned,
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Runs the DB console
|
||||||
|
func (c *DBConsole) Run() {
|
||||||
|
conn, err := ConnectToNode(c.nodeConfig)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
defer conn.Close()
|
defer conn.Close()
|
||||||
|
|
||||||
|
grpcWarn := c.nodeConfig.ListenGRPCMultiaddr == ""
|
||||||
|
|
||||||
p := tea.NewProgram(consoleModel(conn, c.nodeConfig, grpcWarn))
|
p := tea.NewProgram(consoleModel(conn, c.nodeConfig, grpcWarn))
|
||||||
if _, err := p.Run(); err != nil {
|
if _, err := p.Run(); err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
|
44
node/main.go
44
node/main.go
@ -10,6 +10,7 @@ import (
|
|||||||
"os"
|
"os"
|
||||||
"os/signal"
|
"os/signal"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
"source.quilibrium.com/quilibrium/monorepo/node/protobufs"
|
||||||
"syscall"
|
"syscall"
|
||||||
|
|
||||||
"github.com/libp2p/go-libp2p/core/crypto"
|
"github.com/libp2p/go-libp2p/core/crypto"
|
||||||
@ -28,17 +29,21 @@ var (
|
|||||||
filepath.Join(".", ".config"),
|
filepath.Join(".", ".config"),
|
||||||
"the configuration directory",
|
"the configuration directory",
|
||||||
)
|
)
|
||||||
importPrivKey = flag.String(
|
balance = flag.Bool(
|
||||||
"import-priv-key",
|
"balance",
|
||||||
"",
|
false,
|
||||||
"creates a new config using a specific key from the phase one ceremony",
|
"print the node's confirmed token balance to stdout and exit",
|
||||||
)
|
)
|
||||||
dbConsole = flag.Bool(
|
dbConsole = flag.Bool(
|
||||||
"db-console",
|
"db-console",
|
||||||
false,
|
false,
|
||||||
"starts the node in database console mode",
|
"starts the node in database console mode",
|
||||||
)
|
)
|
||||||
|
importPrivKey = flag.String(
|
||||||
|
"import-priv-key",
|
||||||
|
"",
|
||||||
|
"creates a new config using a specific key from the phase one ceremony",
|
||||||
|
)
|
||||||
peerId = flag.Bool(
|
peerId = flag.Bool(
|
||||||
"peer-id",
|
"peer-id",
|
||||||
false,
|
false,
|
||||||
@ -49,6 +54,35 @@ var (
|
|||||||
func main() {
|
func main() {
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
|
||||||
|
if *balance {
|
||||||
|
config, err := config.LoadConfig(*configDirectory, "")
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
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("Confirmed balance:", balance.Owned, "QUIL")
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
if *peerId {
|
if *peerId {
|
||||||
config, err := config.LoadConfig(*configDirectory, "")
|
config, err := config.LoadConfig(*configDirectory, "")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Loading…
Reference in New Issue
Block a user