mukan-ignite/ignite/cmd/account_import.go
Mukan Erkin Törük c32551b6f7
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
refactor: replace all github.com upstream refs with git.cw.tr/mukan-network
2026-05-11 03:36:24 +03:00

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)
}