Checks whether the wallet has just been created and has not yet had a password set.
Calling set_password
will transition the wallet to the locked state.
bool graphene::wallet::wallet_api::is_new()const
{% tabs %} {% tab title="Return" %} True if the wallet is new. {% endtab %} {% endtabs %}
Checks whether the wallet is locked (is unable to use its private keys).
This state can be changed by calling lock()
or unlock()
bool graphene::wallet::wallet_api::is_locked()const
{% tabs %} {% tab title="Return" %} True if the wallet is locked {% endtab %} {% endtabs %}
Locks the wallet immediately.
void graphene::wallet::wallet_api::lock()
Unlocks the wallet.
The wallet remain unlocked until the lock
is called or the program exits.
When used in command line, if typed “unlock” without a password followed, the user will be prompted to input a password without echo.
void graphene::wallet::wallet_api::unlock(
string password)
{% tabs %} {% tab title="Parameters" %}
password
: the password previously set withset_password()
{% endtab %} {% endtabs %}
Sets a new password on the wallet.
The wallet must be either ‘new’ or ‘unlocked’ to execute this command.
When used in command line, if typed “set_password” without a password followed, the user will be prompted to input a password without echo.
void graphene::wallet::wallet_api::set_password(
string password)
{% tabs %} {% tab title="Parameters" %}
password
: a new password {% endtab %} {% endtabs %}
Dumps all private keys owned by the wallet.
The keys are printed in WIF format. You can import these keys into another wallet using import_key()
map<public_key_type, string> graphene::wallet::wallet_api::dump_private_keys()
{% tabs %} {% tab title="Return" %} A _**_map containing the private keys, indexed by their public key {% endtab %} {% endtabs %}
Imports the private key for an existing account.
The private key must match either an owner key or an active key for the named account.
See also **dump_private_keys()
bool graphene::wallet::wallet_api::import_key(
string account_name_or_id,
string wif_key)
{% tabs %} {% tab title="Parameters" %}
account_name_or_id
: the account owning the keywif_key
: the private key in WIF format {% endtab %}
{% tab title="Return" %} true if the key was imported {% endtab %} {% endtabs %}
Imports accounts from a BitShares 0.x wallet file. Current wallet file must be unlocked to perform the import.
map<string, bool> graphene::wallet::wallet_api::import_accounts(
string filename,
string password)
{% tabs %} {% tab title="Parameters" %}
filename
: the BitShares 0.x wallet file to importpassword
: the password to encrypt the BitShares 0.x wallet file {% endtab %}
{% tab title="Return" %} A map containing the accounts found and whether imported. {% endtab %} {% endtabs %}
Imports from a BitShares 0.x wallet file, find keys that were bound to a given account name on the BitShares 0.x chain, rebind them to an account name on the 2.0 chain. Current wallet file must be unlocked to perform the import.
bool graphene::wallet::wallet_api::import_account_keys(
string filename,
string password,
string src_account_name,
string dest_account_name)
{% tabs %} {% tab title="First Tab" %}
filename
: the BitShares 0.x wallet file to importpassword
: the password to encrypt the BitShares 0.x wallet filesrc_account_name
: name of the account on BitShares 0.x chaindest_account_name
: name of the account on BitShares 2.0 chain, can be same or different tosrc_account_name
{% endtab %}
{% tab title="Return" %} Whether the import has succeeded {% endtab %} {% endtabs %}
This call will construct transaction(s) that will claim all balances controlled by wif_keys and deposit them into the given account.
vector<signed_transaction> graphene::wallet::wallet_api::import_balance(
string account_name_or_id,
const vector<string> &wif_keys,
bool broadcast)
{% tabs %} {% tab title="Parameters" %}
account_name_or_id
: name or ID of an account that to claim balances towif_keys
: private WIF keys of balance objects to claim balances frombroadcast
: true to broadcast the transaction on the network {% endtab %} {% endtabs %}
Suggests a safe brain key to use for creating your account. create_account_with_brain_key()
requires you to specify a ‘brain key’, a long passphrase that provides enough entropy to generate cryptographic keys.
This function will suggest a suitably random string that should be easy to write down (and, with effort, memorize).
brain_key_info graphene::wallet::wallet_api::suggest_brain_key()const
{% tabs %} {% tab title="Return" %} A suggested brain_key {% endtab %} {% endtabs %}
This method is used to convert a JSON transaction to its transacting ID.
transaction_id_type graphene::wallet::wallet_api::get_transaction_id(
const signed_transaction &trx)const
{% tabs %} {% tab title="Parameters" %}
trx
: a JSON transaction {% endtab %}
{% tab title="Return" %} The ID (hash) of the transaction. {% endtab %} {% endtabs %}
Get the WIF private key corresponding to a public key. The private key must already be in the wallet.
string graphene::wallet::wallet_api::get_private_key(
public_key_type pubkey)const
{% tabs %} {% tab title="Parameters" %}
pubkey
: a public key in Base58 format {% endtab %}
{% tab title="Return" %} The WIF private key {% endtab %} {% endtabs %}
Loads a specified Graphene wallet.
The current wallet is closed before the new wallet is loaded.
{% hint style="danger" %}
Important: This does not change the filename that will be used for future wallet writes, so this may cause you to overwrite your original wallet unless you also call set_wallet_filename()
{% endhint %}
bool graphene::wallet::wallet_api::load_wallet_file(
string wallet_filename = "")
{% tabs %} {% tab title="Parameters" %}
wallet_filename
: the filename of the wallet JSON file to load. Ifwallet_filename
is empty, it reloads the existing wallet file. {% endtab %}
{% tab title="Return" %} True if the specified wallet is loaded. {% endtab %} {% endtabs %}
Transforms a brain key to reduce the chance of errors when re-entering the key from memory.
This takes a user-supplied brain key and normalizes it into the form used for generating private keys. In particular, this upper-cases all ASCII characters and collapses multiple spaces into one.
string graphene::wallet::wallet_api::normalize_brain_key(
string s)const
{% tabs %} {% tab title="Parameters" %}
s
: the brain key as supplied by the user {% endtab %}
{% tab title="Return" %} The brain key in its normalized form. {% endtab %} {% endtabs %}
Saves the current wallet to the given filename.
{% hint style="danger" %}
Important: This does not change the wallet filename that will be used for future writes, so think of this function as ‘Save a Copy As…’ instead of ‘Save As…’. Use set_wallet_filename()
to make the filename persist.
{% endhint %}
void graphene::wallet::wallet_api::save_wallet_file(
string wallet_filename = "")
{% tabs %} {% tab title="Parameters" %}
wallet_filename
: the filename of the new wallet JSON file to create or overwrite. Ifwallet_filename
is empty, save to the current filename. {% endtab %} {% endtabs %}