Some checks are pending
Build SimApp / build (amd64) (push) Waiting to run
Build SimApp / build (arm64) (push) Waiting to run
CodeQL / Analyze (push) Waiting to run
Build & Push / build (push) Waiting to run
Run Gosec / Gosec (push) Waiting to run
Lint / golangci-lint (push) Waiting to run
Checks dependencies and mocks generation / Check go mod tidy (push) Waiting to run
Checks dependencies and mocks generation / Check up to date mocks (push) Waiting to run
System Tests / setup (push) Waiting to run
System Tests / test-system (push) Blocked by required conditions
System Tests / test-system-legacy (push) Blocked by required conditions
Tests / Code Coverage / split-test-files (push) Waiting to run
Tests / Code Coverage / tests (00) (push) Blocked by required conditions
Tests / Code Coverage / tests (01) (push) Blocked by required conditions
Tests / Code Coverage / tests (02) (push) Blocked by required conditions
Tests / Code Coverage / tests (03) (push) Blocked by required conditions
Tests / Code Coverage / test-integration (push) Waiting to run
Tests / Code Coverage / test-e2e (push) Waiting to run
Tests / Code Coverage / repo-analysis (push) Blocked by required conditions
Tests / Code Coverage / test-sim-nondeterminism (push) Waiting to run
Tests / Code Coverage / test-clientv2 (push) Waiting to run
Tests / Code Coverage / test-core (push) Waiting to run
Tests / Code Coverage / test-depinject (push) Waiting to run
Tests / Code Coverage / test-errors (push) Waiting to run
Tests / Code Coverage / test-math (push) Waiting to run
Tests / Code Coverage / test-schema (push) Waiting to run
Tests / Code Coverage / test-collections (push) Waiting to run
Tests / Code Coverage / test-cosmovisor (push) Waiting to run
Tests / Code Coverage / test-confix (push) Waiting to run
Tests / Code Coverage / test-store (push) Waiting to run
Tests / Code Coverage / test-log (push) Waiting to run
Tests / Code Coverage / test-x-tx (push) Waiting to run
Tests / Code Coverage / test-x-nft (push) Waiting to run
Tests / Code Coverage / test-x-circuit (push) Waiting to run
Tests / Code Coverage / test-x-feegrant (push) Waiting to run
Tests / Code Coverage / test-x-evidence (push) Waiting to run
Tests / Code Coverage / test-x-upgrade (push) Waiting to run
Tests / Code Coverage / test-tools-benchmark (push) Waiting to run
82 lines
2.2 KiB
Go
82 lines
2.2 KiB
Go
package keys
|
|
|
|
import (
|
|
"bufio"
|
|
"fmt"
|
|
"os"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
"git.cw.tr/mukan-network/mukan-sdk/client"
|
|
"git.cw.tr/mukan-network/mukan-sdk/client/flags"
|
|
"git.cw.tr/mukan-network/mukan-sdk/client/input"
|
|
"git.cw.tr/mukan-network/mukan-sdk/crypto/hd"
|
|
"git.cw.tr/mukan-network/mukan-sdk/version"
|
|
)
|
|
|
|
// ImportKeyCommand imports private keys from a keyfile.
|
|
func ImportKeyCommand() *cobra.Command {
|
|
return &cobra.Command{
|
|
Use: "import <name> <keyfile>",
|
|
Short: "Import private keys into the local keybase",
|
|
Long: "Import a ASCII armored private key into the local keybase.",
|
|
Args: cobra.ExactArgs(2),
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
clientCtx, err := client.GetClientQueryContext(cmd)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
name := args[0]
|
|
if err := checkName(name); err != nil {
|
|
return err
|
|
}
|
|
buf := bufio.NewReader(clientCtx.Input)
|
|
|
|
armor, err := os.ReadFile(args[1])
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
passphrase, err := input.GetPassword("Enter passphrase to decrypt your key:", buf)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return clientCtx.Keyring.ImportPrivKey(name, string(armor), passphrase)
|
|
},
|
|
}
|
|
}
|
|
|
|
func ImportKeyHexCommand() *cobra.Command {
|
|
cmd := &cobra.Command{
|
|
Use: "import-hex <name> [hex]",
|
|
Short: "Import private keys into the local keybase",
|
|
Long: fmt.Sprintf("Import hex encoded private key into the local keybase.\nSupported key-types can be obtained with:\n%s list-key-types", version.AppName),
|
|
Args: cobra.RangeArgs(1, 2),
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
clientCtx, err := client.GetClientQueryContext(cmd)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
name := args[0]
|
|
if err := checkName(name); err != nil {
|
|
return err
|
|
}
|
|
|
|
keyType, _ := cmd.Flags().GetString(flags.FlagKeyType)
|
|
var hexKey string
|
|
if len(args) == 2 {
|
|
hexKey = args[1]
|
|
} else {
|
|
buf := bufio.NewReader(clientCtx.Input)
|
|
hexKey, err = input.GetPassword("Enter hex private key:", buf)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return clientCtx.Keyring.ImportPrivKeyHex(name, hexKey, keyType)
|
|
},
|
|
}
|
|
cmd.Flags().String(flags.FlagKeyType, string(hd.Secp256k1Type), "private key signing algorithm kind")
|
|
return cmd
|
|
}
|