forked from TrueCloudLab/neoneo-go
cli: add nep11 balance
command
This commit is contained in:
parent
3742e38399
commit
3eefda7f1a
2 changed files with 115 additions and 2 deletions
|
@ -1,12 +1,37 @@
|
||||||
package wallet
|
package wallet
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"math/big"
|
||||||
|
|
||||||
|
"github.com/nspcc-dev/neo-go/cli/flags"
|
||||||
|
"github.com/nspcc-dev/neo-go/cli/options"
|
||||||
|
"github.com/nspcc-dev/neo-go/pkg/encoding/address"
|
||||||
|
"github.com/nspcc-dev/neo-go/pkg/encoding/fixedn"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/smartcontract/manifest"
|
"github.com/nspcc-dev/neo-go/pkg/smartcontract/manifest"
|
||||||
|
"github.com/nspcc-dev/neo-go/pkg/wallet"
|
||||||
"github.com/urfave/cli"
|
"github.com/urfave/cli"
|
||||||
)
|
)
|
||||||
|
|
||||||
func newNEP11Commands() []cli.Command {
|
func newNEP11Commands() []cli.Command {
|
||||||
|
tokenID := cli.StringFlag{
|
||||||
|
Name: "id",
|
||||||
|
Usage: "Token ID",
|
||||||
|
}
|
||||||
|
|
||||||
|
balanceFlags := make([]cli.Flag, len(baseBalanceFlags))
|
||||||
|
copy(balanceFlags, baseBalanceFlags)
|
||||||
|
balanceFlags = append(balanceFlags, tokenID)
|
||||||
|
balanceFlags = append(balanceFlags, options.RPC...)
|
||||||
return []cli.Command{
|
return []cli.Command{
|
||||||
|
{
|
||||||
|
Name: "balance",
|
||||||
|
Usage: "get address balance",
|
||||||
|
UsageText: "balance --wallet <path> --rpc-endpoint <node> [--timeout <time>] [--address <address>] --token <hash-or-name> [--id <token-id>]",
|
||||||
|
Action: getNEP11Balance,
|
||||||
|
Flags: balanceFlags,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
Name: "import",
|
Name: "import",
|
||||||
Usage: "import NEP11 token to a wallet",
|
Usage: "import NEP11 token to a wallet",
|
||||||
|
@ -49,3 +74,88 @@ func printNEP11Info(ctx *cli.Context) error {
|
||||||
func removeNEP11Token(ctx *cli.Context) error {
|
func removeNEP11Token(ctx *cli.Context) error {
|
||||||
return removeNEPToken(ctx, manifest.NEP11StandardName)
|
return removeNEPToken(ctx, manifest.NEP11StandardName)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func getNEP11Balance(ctx *cli.Context) error {
|
||||||
|
var accounts []*wallet.Account
|
||||||
|
|
||||||
|
wall, err := openWallet(ctx.String("wallet"))
|
||||||
|
if err != nil {
|
||||||
|
return cli.NewExitError(fmt.Errorf("bad wallet: %w", err), 1)
|
||||||
|
}
|
||||||
|
defer wall.Close()
|
||||||
|
|
||||||
|
addrFlag := ctx.Generic("address").(*flags.Address)
|
||||||
|
if addrFlag.IsSet {
|
||||||
|
addrHash := addrFlag.Uint160()
|
||||||
|
acc := wall.GetAccount(addrHash)
|
||||||
|
if acc == nil {
|
||||||
|
return cli.NewExitError(fmt.Errorf("can't find account for the address: %s", address.Uint160ToString(addrHash)), 1)
|
||||||
|
}
|
||||||
|
accounts = append(accounts, acc)
|
||||||
|
} else {
|
||||||
|
if len(wall.Accounts) == 0 {
|
||||||
|
return cli.NewExitError(errors.New("no accounts in the wallet"), 1)
|
||||||
|
}
|
||||||
|
accounts = wall.Accounts
|
||||||
|
}
|
||||||
|
|
||||||
|
gctx, cancel := options.GetTimeoutContext(ctx)
|
||||||
|
defer cancel()
|
||||||
|
|
||||||
|
c, err := options.GetRPCClient(gctx, ctx)
|
||||||
|
if err != nil {
|
||||||
|
return cli.NewExitError(err, 1)
|
||||||
|
}
|
||||||
|
|
||||||
|
name := ctx.String("token")
|
||||||
|
if name == "" {
|
||||||
|
return cli.NewExitError("token hash or name should be specified", 1)
|
||||||
|
}
|
||||||
|
token, err := getMatchingToken(ctx, wall, name, manifest.NEP11StandardName)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintln(ctx.App.ErrWriter, "Can't find matching token in the wallet. Querying RPC-node for token info.")
|
||||||
|
tokenHash, err := flags.ParseAddress(name)
|
||||||
|
if err != nil {
|
||||||
|
return cli.NewExitError(fmt.Sprintf("valid token adress or hash in LE should be specified for RPC-node request: %s", err.Error()), 1)
|
||||||
|
}
|
||||||
|
token, err = c.NEP11TokenInfo(tokenHash)
|
||||||
|
if err != nil {
|
||||||
|
return cli.NewExitError(err.Error(), 1)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tokenID := ctx.String("id")
|
||||||
|
for k, acc := range accounts {
|
||||||
|
addrHash, err := address.StringToUint160(acc.Address)
|
||||||
|
if err != nil {
|
||||||
|
return cli.NewExitError(fmt.Errorf("invalid account address: %w", err), 1)
|
||||||
|
}
|
||||||
|
|
||||||
|
if k != 0 {
|
||||||
|
fmt.Fprintln(ctx.App.Writer)
|
||||||
|
}
|
||||||
|
fmt.Fprintf(ctx.App.Writer, "Account %s\n", acc.Address)
|
||||||
|
|
||||||
|
var amount int64
|
||||||
|
if tokenID == "" {
|
||||||
|
amount, err = c.NEP11BalanceOf(token.Hash, addrHash)
|
||||||
|
} else {
|
||||||
|
amount, err = c.NEP11DBalanceOf(token.Hash, addrHash, tokenID)
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
amountStr := fixedn.ToString(big.NewInt(amount), int(token.Decimals))
|
||||||
|
|
||||||
|
format := "%s: %s (%s)\n"
|
||||||
|
formatArgs := []interface{}{token.Symbol, token.Name, token.Hash.StringLE()}
|
||||||
|
if tokenID != "" {
|
||||||
|
format = "%s: %s (%s, %s)\n"
|
||||||
|
formatArgs = append(formatArgs, tokenID)
|
||||||
|
}
|
||||||
|
fmt.Fprintf(ctx.App.Writer, format, formatArgs...)
|
||||||
|
fmt.Fprintf(ctx.App.Writer, "\tAmount : %s\n", amountStr)
|
||||||
|
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
|
@ -28,14 +28,14 @@ var (
|
||||||
Name: "gas",
|
Name: "gas",
|
||||||
Usage: "Amount of GAS to attach to a tx",
|
Usage: "Amount of GAS to attach to a tx",
|
||||||
}
|
}
|
||||||
balanceFlags = append([]cli.Flag{
|
baseBalanceFlags = []cli.Flag{
|
||||||
walletPathFlag,
|
walletPathFlag,
|
||||||
tokenFlag,
|
tokenFlag,
|
||||||
flags.AddressFlag{
|
flags.AddressFlag{
|
||||||
Name: "address, a",
|
Name: "address, a",
|
||||||
Usage: "Address to use",
|
Usage: "Address to use",
|
||||||
},
|
},
|
||||||
}, options.RPC...)
|
}
|
||||||
importFlags = append([]cli.Flag{
|
importFlags = append([]cli.Flag{
|
||||||
walletPathFlag,
|
walletPathFlag,
|
||||||
flags.AddressFlag{
|
flags.AddressFlag{
|
||||||
|
@ -64,6 +64,9 @@ var (
|
||||||
)
|
)
|
||||||
|
|
||||||
func newNEP17Commands() []cli.Command {
|
func newNEP17Commands() []cli.Command {
|
||||||
|
balanceFlags := make([]cli.Flag, len(baseBalanceFlags))
|
||||||
|
copy(balanceFlags, baseBalanceFlags)
|
||||||
|
balanceFlags = append(balanceFlags, options.RPC...)
|
||||||
return []cli.Command{
|
return []cli.Command{
|
||||||
{
|
{
|
||||||
Name: "balance",
|
Name: "balance",
|
||||||
|
|
Loading…
Reference in a new issue