Some checks failed
Docs Deploy / build_and_deploy (push) Has been cancelled
Generate Docs / cli (push) Has been cancelled
Generate Config Doc / cli (push) Has been cancelled
Go formatting / go-formatting (push) Has been cancelled
Check links / markdown-link-check (push) Has been cancelled
Integration / pre-test (push) Has been cancelled
Integration / test on (push) Has been cancelled
Integration / status (push) Has been cancelled
Lint / Lint Go code (push) Has been cancelled
Test / test (ubuntu-latest) (push) Has been cancelled
81 lines
2 KiB
Go
81 lines
2 KiB
Go
package ignitecmd
|
|
|
|
import (
|
|
"os"
|
|
|
|
"github.com/cosmos/go-bip39"
|
|
"github.com/spf13/cobra"
|
|
|
|
"git.cw.tr/mukan-network/mukan-ignite/ignite/pkg/cliui"
|
|
"git.cw.tr/mukan-network/mukan-ignite/ignite/pkg/cliui/bubbleconfirm"
|
|
"git.cw.tr/mukan-network/mukan-ignite/ignite/pkg/cosmosaccount"
|
|
"git.cw.tr/mukan-network/mukan-ignite/ignite/pkg/errors"
|
|
)
|
|
|
|
const flagSecret = "secret"
|
|
|
|
func NewAccountImport() *cobra.Command {
|
|
c := &cobra.Command{
|
|
Use: "import [name]",
|
|
Short: "Import an account by using a mnemonic or a private key",
|
|
Args: cobra.ExactArgs(1),
|
|
RunE: accountImportHandler,
|
|
}
|
|
|
|
c.Flags().String(flagSecret, "", "Your mnemonic or path to your private key (use interactive mode instead to securely pass your mnemonic)")
|
|
c.Flags().AddFlagSet(flagSetAccountImport())
|
|
c.Flags().AddFlagSet(flagSetCoinType())
|
|
|
|
return c
|
|
}
|
|
|
|
func accountImportHandler(cmd *cobra.Command, args []string) error {
|
|
var (
|
|
name = args[0]
|
|
secret, _ = cmd.Flags().GetString(flagSecret)
|
|
session = cliui.New(cliui.StartSpinnerWithText(statusImporting))
|
|
)
|
|
defer session.End()
|
|
|
|
if secret == "" {
|
|
session.StopSpinner()
|
|
|
|
if err := bubbleconfirm.Ask(
|
|
bubbleconfirm.NewQuestion("Your mnemonic or path to your private key", &secret, bubbleconfirm.Required())); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
var passphrase string
|
|
if !bip39.IsMnemonicValid(secret) {
|
|
var err error
|
|
passphrase, err = getPassphrase(cmd)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
privKey, err := os.ReadFile(secret)
|
|
if os.IsNotExist(err) {
|
|
return errors.New("mnemonic is not valid or private key not found at path")
|
|
}
|
|
if err != nil {
|
|
return err
|
|
}
|
|
secret = string(privKey)
|
|
}
|
|
|
|
ca, err := cosmosaccount.New(
|
|
cosmosaccount.WithKeyringBackend(getKeyringBackend(cmd)),
|
|
cosmosaccount.WithHome(getKeyringDir(cmd)),
|
|
cosmosaccount.WithCoinType(getCoinType(cmd)),
|
|
)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if _, err := ca.Import(name, secret, passphrase); err != nil {
|
|
return err
|
|
}
|
|
|
|
return session.Printf("Account %q imported.\n", name)
|
|
}
|