2020-05-19 13:22:38 +00:00
|
|
|
import libstatus
|
2020-05-21 17:51:07 +00:00
|
|
|
import core
|
2020-05-19 13:22:38 +00:00
|
|
|
import json
|
|
|
|
import utils
|
2020-05-21 18:52:41 +00:00
|
|
|
import accounts/constants
|
2020-05-21 19:59:09 +00:00
|
|
|
import nimcrypto
|
2020-05-20 17:11:30 +00:00
|
|
|
import os
|
2020-05-21 19:44:07 +00:00
|
|
|
import uuids
|
2020-05-19 13:22:38 +00:00
|
|
|
|
2020-05-21 17:51:07 +00:00
|
|
|
proc queryAccounts*(): string =
|
|
|
|
var payload = %* {
|
|
|
|
"jsonrpc": "2.0",
|
|
|
|
"method": "eth_accounts",
|
|
|
|
"params": [
|
|
|
|
[]
|
|
|
|
]
|
|
|
|
}
|
|
|
|
var response = callPrivateRPC($payload)
|
|
|
|
echo response
|
|
|
|
result = parseJson(response)["result"][0].getStr()
|
|
|
|
|
2020-05-19 13:22:38 +00:00
|
|
|
proc generateAddresses*(): string =
|
|
|
|
let multiAccountConfig = %* {
|
|
|
|
"n": 5,
|
|
|
|
"mnemonicPhraseLength": 12,
|
|
|
|
"bip39Passphrase": "",
|
|
|
|
"paths": ["m/43'/60'/1581'/0'/0", "m/44'/60'/0'/0/0"]
|
|
|
|
}
|
|
|
|
result = $libstatus.multiAccountGenerateAndDeriveAddresses($multiAccountConfig)
|
|
|
|
|
|
|
|
proc generateAlias*(publicKey: string): string =
|
|
|
|
result = $libstatus.generateAlias(publicKey.toGoString)
|
2020-05-20 17:11:30 +00:00
|
|
|
|
2020-05-21 21:41:27 +00:00
|
|
|
proc generateIdenticon*(publicKey: string): string =
|
|
|
|
result = $libstatus.identicon(publicKey.toGoString)
|
|
|
|
|
2020-05-20 17:11:30 +00:00
|
|
|
proc ensureDir(dirname: string) =
|
|
|
|
if not existsDir(dirname):
|
|
|
|
# removeDir(dirname)
|
|
|
|
createDir(dirname)
|
|
|
|
|
|
|
|
proc initNodeAccounts*() =
|
|
|
|
const datadir = "./data/"
|
|
|
|
const keystoredir = "./data/keystore/"
|
|
|
|
const nobackupdir = "./noBackup/"
|
|
|
|
|
|
|
|
ensureDir(datadir)
|
|
|
|
ensureDir(keystoredir)
|
|
|
|
ensureDir(nobackupdir)
|
|
|
|
|
|
|
|
discard $libstatus.initKeystore(keystoredir);
|
|
|
|
discard $libstatus.openAccounts(datadir);
|
2020-05-21 17:51:07 +00:00
|
|
|
|
2020-05-21 18:52:41 +00:00
|
|
|
proc saveAccountAndLogin*(multiAccounts: JsonNode, alias: string, identicon: string, accountData: string, password: string, configJSON: string, settingsJSON: string): JsonNode =
|
2020-05-21 19:59:09 +00:00
|
|
|
let hashedPassword = "0x" & $keccak_256.digest(password)
|
2020-05-21 18:52:41 +00:00
|
|
|
let subaccountData = %* [
|
|
|
|
{
|
|
|
|
"public-key": multiAccounts[constants.PATH_DEFAULT_WALLET]["publicKey"],
|
|
|
|
"address": multiAccounts[constants.PATH_DEFAULT_WALLET]["address"],
|
|
|
|
"color": "#4360df",
|
|
|
|
"wallet": true,
|
|
|
|
"path": constants.PATH_DEFAULT_WALLET,
|
|
|
|
"name": "Status account"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"public-key": multiAccounts[constants.PATH_WHISPER]["publicKey"],
|
|
|
|
"address": multiAccounts[constants.PATH_WHISPER]["address"],
|
|
|
|
"name": alias,
|
|
|
|
"photo-path": identicon,
|
|
|
|
"path": constants.PATH_WHISPER,
|
|
|
|
"chat": true
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
2020-05-21 19:59:09 +00:00
|
|
|
var savedResult = $libstatus.saveAccountAndLogin(accountData, hashedPassword, settingsJSON, configJSON, $subaccountData)
|
2020-05-21 18:52:41 +00:00
|
|
|
let parsedSavedResult = savedResult.parseJson
|
|
|
|
|
|
|
|
if parsedSavedResult["error"].getStr == "":
|
|
|
|
echo "Account saved succesfully"
|
|
|
|
subaccountData
|
|
|
|
|
2020-05-21 19:13:49 +00:00
|
|
|
proc generateMultiAccounts*(account: JsonNode, password: string): JsonNode =
|
2020-05-21 19:59:09 +00:00
|
|
|
let hashedPassword = "0x" & $keccak_256.digest(password)
|
2020-05-21 17:51:07 +00:00
|
|
|
let multiAccount = %* {
|
2020-05-21 19:13:49 +00:00
|
|
|
"accountID": account["id"].getStr,
|
|
|
|
"paths": ["m/44'/60'/0'/0", "m/43'/60'/1581'", "m/43'/60'/1581'/0'/0", "m/44'/60'/0'/0/0"],
|
2020-05-21 19:59:09 +00:00
|
|
|
"password": hashedPassword
|
2020-05-21 17:51:07 +00:00
|
|
|
}
|
2020-05-21 19:13:49 +00:00
|
|
|
var response = $libstatus.multiAccountStoreDerivedAccounts($multiAccount);
|
|
|
|
result = response.parseJson
|
|
|
|
|
2020-05-21 19:54:25 +00:00
|
|
|
proc getAccountData*(account: JsonNode, alias: string, identicon: string): JsonNode =
|
|
|
|
result = %* {
|
|
|
|
"name": alias,
|
|
|
|
"address": account["address"].getStr,
|
|
|
|
"photo-path": identicon,
|
|
|
|
"key-uid": account["keyUid"].getStr,
|
|
|
|
"keycard-pairing": nil
|
|
|
|
}
|
|
|
|
|
2020-05-21 19:44:07 +00:00
|
|
|
proc getAccountSettings*(account: JsonNode, alias: string, identicon: string, multiAccounts: JsonNode, defaultNetworks: JsonNode): JsonNode =
|
|
|
|
result = %* {
|
|
|
|
"key-uid": account["keyUid"].getStr,
|
|
|
|
"mnemonic": account["mnemonic"].getStr,
|
|
|
|
"public-key": multiAccounts[constants.PATH_WHISPER]["publicKey"].getStr,
|
|
|
|
"name": alias,
|
|
|
|
"address": account["address"].getStr,
|
|
|
|
"eip1581-address": multiAccounts[constants.PATH_EIP_1581]["address"].getStr,
|
|
|
|
"dapps-address": multiAccounts[constants.PATH_DEFAULT_WALLET]["address"].getStr,
|
|
|
|
"wallet-root-address": multiAccounts[constants.PATH_WALLET_ROOT]["address"].getStr,
|
|
|
|
"preview-privacy?": true,
|
|
|
|
"signing-phrase": generateSigningPhrase(3),
|
|
|
|
"log-level": "INFO",
|
|
|
|
"latest-derived-path": 0,
|
|
|
|
"networks/networks": defaultNetworks,
|
|
|
|
"currency": "usd",
|
|
|
|
"photo-path": identicon,
|
|
|
|
"waku-enabled": true,
|
|
|
|
"wallet/visible-tokens": {
|
|
|
|
"mainnet": ["SNT"]
|
|
|
|
},
|
|
|
|
"appearance": 0,
|
|
|
|
"networks/current-network": "mainnet_rpc",
|
|
|
|
"installation-id": $genUUID()
|
|
|
|
}
|
|
|
|
|
2020-05-21 20:15:44 +00:00
|
|
|
proc setupAccount*(account: JsonNode, password: string): string =
|
|
|
|
let multiAccounts = generateMultiAccounts(account, password)
|
2020-05-21 19:13:49 +00:00
|
|
|
|
2020-05-21 20:15:44 +00:00
|
|
|
let whisperPubKey = account["derived"][constants.PATH_WHISPER]["publicKey"].getStr
|
|
|
|
let alias = $libstatus.generateAlias(whisperPubKey.toGoString)
|
|
|
|
let identicon = $libstatus.identicon(whisperPubKey.toGoString)
|
2020-05-21 17:51:07 +00:00
|
|
|
|
2020-05-21 20:15:44 +00:00
|
|
|
let accountData = getAccountData(account, alias, identicon)
|
|
|
|
var settingsJSON = getAccountSettings(account, alias, identicon, multiAccounts, constants.DEFAULT_NETWORKS)
|
2020-05-21 17:51:07 +00:00
|
|
|
|
2020-05-21 20:15:44 +00:00
|
|
|
$saveAccountAndLogin(multiAccounts, alias, identicon, $accountData, password, $constants.NODE_CONFIG, $settingsJSON)
|