mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-09 22:06:25 +00:00
chore(@desktop/wallet): Accounts
and WalletAccount
services updated
- new procs to a new `status-go` endpoints added: - `AddAccount` - `ImportPrivateKey` - `ImportMnemonic` - `GetRandomMnemonic` - `GetDerivedAddresses` - `GetDerivedAddressesForMnemonic` - `GetAddressDetails` - unused procs to the old `status-go` endpoints removed: - `AddAccountWatch` - `AddAccountWithMnemonic` - `AddAccountWithMnemonicPasswordVerified` - `AddAccountWithMnemonicAndPath` - `AddAccountWithMnemonicAndPathPasswordVerified` - `AddAccountWithPrivateKeyPasswordVerified` - `AddAccountWithPrivateKey` - `GenerateAccount` - `GenerateAccountPasswordVerified` - `GenerateAccountWithDerivedPath` - `GetDerivedAddressForPath` - `GetDerivedAddressesForPath` - `GetDerivedAddressesForMnemonicWithPath` - `GetDerivedAddressForPrivateKey` - `GetDerivedAddressDetails`
This commit is contained in:
parent
7b16a93cc0
commit
44e00b9538
@ -684,12 +684,12 @@ proc updateKeycardUid*(self: Controller, keyUid: string, keycardUid: string) =
|
|||||||
self.tmpKeycardUid = keycardUid
|
self.tmpKeycardUid = keycardUid
|
||||||
info "update keycard uid failed", oldKeycardUid=self.tmpKeycardUid, newKeycardUid=keycardUid
|
info "update keycard uid failed", oldKeycardUid=self.tmpKeycardUid, newKeycardUid=keycardUid
|
||||||
|
|
||||||
proc addWalletAccount*(self: Controller, name, address, path, addressAccountIsDerivedFrom, publicKey, keyUid, accountType,
|
proc addWalletAccount*(self: Controller, name, keyPairName, address, path: string, lastUsedDerivationIndex: int,
|
||||||
color, emoji: string): bool =
|
rootWalletMasterKey, publicKey, keyUid, accountType, color, emoji: string): bool =
|
||||||
if not serviceApplicable(self.walletAccountService):
|
if not serviceApplicable(self.walletAccountService):
|
||||||
return false
|
return false
|
||||||
let err = self.walletAccountService.addWalletAccount(name, address, path, addressAccountIsDerivedFrom, publicKey, keyUid,
|
let err = self.walletAccountService.addWalletAccount(password = "", doPasswordHashing = false, name, keyPairName,
|
||||||
accountType, color, emoji)
|
address, path, lastUsedDerivationIndex, rootWalletMasterKey, publicKey, keyUid, accountType, color, emoji)
|
||||||
if err.len > 0:
|
if err.len > 0:
|
||||||
info "adding wallet account failed", name=name, path=path
|
info "adding wallet account failed", name=name, path=path
|
||||||
return false
|
return false
|
||||||
|
@ -43,17 +43,21 @@ proc resolveAddresses(self: CreatingAccountNewSeedPhraseState, controller: Contr
|
|||||||
|
|
||||||
proc addAccountsToWallet(self: CreatingAccountNewSeedPhraseState, controller: Controller): bool =
|
proc addAccountsToWallet(self: CreatingAccountNewSeedPhraseState, controller: Controller): bool =
|
||||||
let kpForProcessing = controller.getKeyPairForProcessing()
|
let kpForProcessing = controller.getKeyPairForProcessing()
|
||||||
|
var index = 0
|
||||||
for account in kpForProcessing.getAccountsModel().getItems():
|
for account in kpForProcessing.getAccountsModel().getItems():
|
||||||
if not controller.addWalletAccount(name = account.getName(),
|
if not controller.addWalletAccount(name = account.getName(),
|
||||||
|
keyPairName = kpForProcessing.getName(),
|
||||||
address = account.getAddress(),
|
address = account.getAddress(),
|
||||||
path = account.getPath(),
|
path = account.getPath(),
|
||||||
addressAccountIsDerivedFrom = kpForProcessing.getDerivedFrom(),
|
lastUsedDerivationIndex = index,
|
||||||
|
rootWalletMasterKey = kpForProcessing.getDerivedFrom(),
|
||||||
publicKey = account.getPubKey(),
|
publicKey = account.getPubKey(),
|
||||||
keyUid = kpForProcessing.getKeyUid(),
|
keyUid = kpForProcessing.getKeyUid(),
|
||||||
accountType = if account.getPath() == PATH_DEFAULT_WALLET: SEED else: GENERATED,
|
accountType = SEED,
|
||||||
color = account.getColor(),
|
color = account.getColor(),
|
||||||
emoji = account.getEmoji()):
|
emoji = account.getEmoji()):
|
||||||
return false
|
return false
|
||||||
|
index.inc
|
||||||
return true
|
return true
|
||||||
|
|
||||||
proc doMigration(self: CreatingAccountNewSeedPhraseState, controller: Controller) =
|
proc doMigration(self: CreatingAccountNewSeedPhraseState, controller: Controller) =
|
||||||
|
@ -43,17 +43,21 @@ proc resolveAddresses(self: CreatingAccountOldSeedPhraseState, controller: Contr
|
|||||||
|
|
||||||
proc addAccountsToWallet(self: CreatingAccountOldSeedPhraseState, controller: Controller): bool =
|
proc addAccountsToWallet(self: CreatingAccountOldSeedPhraseState, controller: Controller): bool =
|
||||||
let kpForProcessing = controller.getKeyPairForProcessing()
|
let kpForProcessing = controller.getKeyPairForProcessing()
|
||||||
|
var index = 0
|
||||||
for account in kpForProcessing.getAccountsModel().getItems():
|
for account in kpForProcessing.getAccountsModel().getItems():
|
||||||
if not controller.addWalletAccount(name = account.getName(),
|
if not controller.addWalletAccount(name = account.getName(),
|
||||||
|
keyPairName = kpForProcessing.getName(),
|
||||||
address = account.getAddress(),
|
address = account.getAddress(),
|
||||||
path = account.getPath(),
|
path = account.getPath(),
|
||||||
addressAccountIsDerivedFrom = kpForProcessing.getDerivedFrom(),
|
lastUsedDerivationIndex = index,
|
||||||
|
rootWalletMasterKey = kpForProcessing.getDerivedFrom(),
|
||||||
publicKey = account.getPubKey(),
|
publicKey = account.getPubKey(),
|
||||||
keyUid = kpForProcessing.getKeyUid(),
|
keyUid = kpForProcessing.getKeyUid(),
|
||||||
accountType = if account.getPath() == PATH_DEFAULT_WALLET: SEED else: GENERATED,
|
accountType = SEED,
|
||||||
color = account.getColor(),
|
color = account.getColor(),
|
||||||
emoji = account.getEmoji()):
|
emoji = account.getEmoji()):
|
||||||
return false
|
return false
|
||||||
|
index.inc
|
||||||
return true
|
return true
|
||||||
|
|
||||||
proc doMigration(self: CreatingAccountOldSeedPhraseState, controller: Controller) =
|
proc doMigration(self: CreatingAccountOldSeedPhraseState, controller: Controller) =
|
||||||
|
@ -13,18 +13,22 @@ proc delete*(self: ImportingFromKeycardState) =
|
|||||||
proc addAccountsToWallet(self: ImportingFromKeycardState, controller: Controller): bool =
|
proc addAccountsToWallet(self: ImportingFromKeycardState, controller: Controller): bool =
|
||||||
let kpForProcessing = controller.getKeyPairForProcessing()
|
let kpForProcessing = controller.getKeyPairForProcessing()
|
||||||
let kpHelper = controller.getKeyPairHelper()
|
let kpHelper = controller.getKeyPairHelper()
|
||||||
|
var index = 0
|
||||||
for account in kpForProcessing.getAccountsModel().getItems():
|
for account in kpForProcessing.getAccountsModel().getItems():
|
||||||
self.addresses.add(account.getAddress())
|
self.addresses.add(account.getAddress())
|
||||||
if not controller.addWalletAccount(name = account.getName(),
|
if not controller.addWalletAccount(name = account.getName(),
|
||||||
|
keyPairName = kpForProcessing.getName(),
|
||||||
address = account.getAddress(),
|
address = account.getAddress(),
|
||||||
path = account.getPath(),
|
path = account.getPath(),
|
||||||
addressAccountIsDerivedFrom = kpForProcessing.getDerivedFrom(),
|
lastUsedDerivationIndex = index,
|
||||||
|
rootWalletMasterKey = kpForProcessing.getDerivedFrom(),
|
||||||
publicKey = account.getPubKey(),
|
publicKey = account.getPubKey(),
|
||||||
keyUid = kpForProcessing.getKeyUid(),
|
keyUid = kpForProcessing.getKeyUid(),
|
||||||
accountType = if account.getPath() == PATH_DEFAULT_WALLET: SEED else: GENERATED,
|
accountType = SEED,
|
||||||
color = account.getColor(),
|
color = account.getColor(),
|
||||||
emoji = account.getEmoji()):
|
emoji = account.getEmoji()):
|
||||||
return false
|
return false
|
||||||
|
index.inc
|
||||||
return true
|
return true
|
||||||
|
|
||||||
proc doMigration(self: ImportingFromKeycardState, controller: Controller) =
|
proc doMigration(self: ImportingFromKeycardState, controller: Controller) =
|
||||||
|
@ -18,3 +18,26 @@ const convertToKeycardAccountTask*: Task = proc(argEncoded: string) {.gcsafe, ni
|
|||||||
except Exception as e:
|
except Exception as e:
|
||||||
error "error converting profile keypair: ", message = e.msg
|
error "error converting profile keypair: ", message = e.msg
|
||||||
arg.finish("")
|
arg.finish("")
|
||||||
|
|
||||||
|
|
||||||
|
#################################################
|
||||||
|
# Async load derived addreses
|
||||||
|
#################################################
|
||||||
|
|
||||||
|
type
|
||||||
|
FetchAddressesFromNotImportedMnemonicArg* = ref object of QObjectTaskArg
|
||||||
|
mnemonic: string
|
||||||
|
paths: seq[string]
|
||||||
|
|
||||||
|
const fetchAddressesFromNotImportedMnemonicTask*: Task = proc(argEncoded: string) {.gcsafe, nimcall.} =
|
||||||
|
let arg = decode[FetchAddressesFromNotImportedMnemonicArg](argEncoded)
|
||||||
|
var output = %*{
|
||||||
|
"derivedAddress": "",
|
||||||
|
"error": ""
|
||||||
|
}
|
||||||
|
try:
|
||||||
|
let response = status_account.createAccountFromMnemonicAndDeriveAccountsForPaths(arg.mnemonic, arg.paths)
|
||||||
|
output["derivedAddresses"] = response.result
|
||||||
|
except Exception as e:
|
||||||
|
output["error"] = %* fmt"Error fetching address from not imported mnemonic: {e.msg}"
|
||||||
|
arg.finish(output)
|
@ -1,4 +1,4 @@
|
|||||||
import NimQml, os, json, sequtils, strutils, uuids, times
|
import NimQml, Tables, os, json, strformat, sequtils, strutils, uuids, times
|
||||||
import json_serialization, chronicles
|
import json_serialization, chronicles
|
||||||
|
|
||||||
import ../../../app/global/global_singleton
|
import ../../../app/global/global_singleton
|
||||||
@ -35,10 +35,15 @@ const KDF_ITERATIONS* {.intdefine.} = 256_000
|
|||||||
let TEST_PEER_ENR = getEnv("TEST_PEER_ENR").string
|
let TEST_PEER_ENR = getEnv("TEST_PEER_ENR").string
|
||||||
|
|
||||||
const SIGNAL_CONVERTING_PROFILE_KEYPAIR* = "convertingProfileKeypair"
|
const SIGNAL_CONVERTING_PROFILE_KEYPAIR* = "convertingProfileKeypair"
|
||||||
|
const SIGNAL_DERIVED_ADDRESSES_FROM_NOT_IMPORTED_MNEMONIC_FETCHED* = "derivedAddressesFromNotImportedMnemonicFetched"
|
||||||
|
|
||||||
type ResultArgs* = ref object of Args
|
type ResultArgs* = ref object of Args
|
||||||
success*: bool
|
success*: bool
|
||||||
|
|
||||||
|
type DerivedAddressesFromNotImportedMnemonicArgs* = ref object of Args
|
||||||
|
error*: string
|
||||||
|
derivations*: Table[string, DerivedAccountDetails]
|
||||||
|
|
||||||
include utils
|
include utils
|
||||||
include async_tasks
|
include async_tasks
|
||||||
|
|
||||||
@ -496,7 +501,20 @@ QtObject:
|
|||||||
except Exception as e:
|
except Exception as e:
|
||||||
error "error: ", procName="setupAccount", errName = e.name, errDesription = e.msg
|
error "error: ", procName="setupAccount", errName = e.name, errDesription = e.msg
|
||||||
|
|
||||||
|
proc createAccountFromPrivateKey*(self: Service, privateKey: string): GeneratedAccountDto =
|
||||||
|
if privateKey.len == 0:
|
||||||
|
error "empty private key"
|
||||||
|
return
|
||||||
|
try:
|
||||||
|
let response = status_account.createAccountFromPrivateKey(privateKey)
|
||||||
|
return toGeneratedAccountDto(response.result)
|
||||||
|
except Exception as e:
|
||||||
|
error "error: ", procName="createAccountFromPrivateKey", errName = e.name, errDesription = e.msg
|
||||||
|
|
||||||
proc createAccountFromMnemonic*(self: Service, mnemonic: string, paths: seq[string]): GeneratedAccountDto =
|
proc createAccountFromMnemonic*(self: Service, mnemonic: string, paths: seq[string]): GeneratedAccountDto =
|
||||||
|
if mnemonic.len == 0:
|
||||||
|
error "empty mnemonic"
|
||||||
|
return
|
||||||
try:
|
try:
|
||||||
let response = status_account.createAccountFromMnemonicAndDeriveAccountsForPaths(mnemonic, paths)
|
let response = status_account.createAccountFromMnemonicAndDeriveAccountsForPaths(mnemonic, paths)
|
||||||
return toGeneratedAccountDto(response.result)
|
return toGeneratedAccountDto(response.result)
|
||||||
@ -505,9 +523,6 @@ QtObject:
|
|||||||
|
|
||||||
proc createAccountFromMnemonic*(self: Service, mnemonic: string, includeEncryption = false, includeWhisper = false,
|
proc createAccountFromMnemonic*(self: Service, mnemonic: string, includeEncryption = false, includeWhisper = false,
|
||||||
includeRoot = false, includeDefaultWallet = false, includeEip1581 = false): GeneratedAccountDto =
|
includeRoot = false, includeDefaultWallet = false, includeEip1581 = false): GeneratedAccountDto =
|
||||||
if mnemonic.len == 0:
|
|
||||||
error "empty mnemonic"
|
|
||||||
return
|
|
||||||
var paths: seq[string]
|
var paths: seq[string]
|
||||||
if includeEncryption:
|
if includeEncryption:
|
||||||
paths.add(PATH_ENCRYPTION)
|
paths.add(PATH_ENCRYPTION)
|
||||||
@ -521,6 +536,28 @@ QtObject:
|
|||||||
paths.add(PATH_EIP_1581)
|
paths.add(PATH_EIP_1581)
|
||||||
return self.createAccountFromMnemonic(mnemonic, paths)
|
return self.createAccountFromMnemonic(mnemonic, paths)
|
||||||
|
|
||||||
|
proc fetchAddressesFromNotImportedMnemonic*(self: Service, mnemonic: string, paths: seq[string])=
|
||||||
|
let arg = FetchAddressesFromNotImportedMnemonicArg(
|
||||||
|
mnemonic: mnemonic,
|
||||||
|
paths: paths,
|
||||||
|
tptr: cast[ByteAddress](fetchAddressesFromNotImportedMnemonicTask),
|
||||||
|
vptr: cast[ByteAddress](self.vptr),
|
||||||
|
slot: "onAddressesFromNotImportedMnemonicFetched",
|
||||||
|
)
|
||||||
|
self.threadpool.start(arg)
|
||||||
|
|
||||||
|
proc onAddressesFromNotImportedMnemonicFetched*(self: Service, jsonString: string) {.slot.} =
|
||||||
|
var data = DerivedAddressesFromNotImportedMnemonicArgs()
|
||||||
|
try:
|
||||||
|
let response = parseJson(jsonString)
|
||||||
|
data.error = response["error"].getStr()
|
||||||
|
if data.error.len == 0:
|
||||||
|
data.derivations = toGeneratedAccountDto(response["derivedAddresses"]).derivedAccounts.derivations
|
||||||
|
except Exception as e:
|
||||||
|
error "error: ", procName="fetchAddressesFromNotImportedMnemonic", errName = e.name, errDesription = e.msg
|
||||||
|
data.error = e.msg
|
||||||
|
self.events.emit(SIGNAL_DERIVED_ADDRESSES_FROM_NOT_IMPORTED_MNEMONIC_FETCHED, data)
|
||||||
|
|
||||||
proc importMnemonic*(self: Service, mnemonic: string): string =
|
proc importMnemonic*(self: Service, mnemonic: string): string =
|
||||||
if mnemonic.len == 0:
|
if mnemonic.len == 0:
|
||||||
return "empty mnemonic"
|
return "empty mnemonic"
|
||||||
|
@ -2,106 +2,63 @@
|
|||||||
# Async load derivedAddreses
|
# Async load derivedAddreses
|
||||||
#################################################
|
#################################################
|
||||||
type
|
type
|
||||||
GetDerivedAddressTaskArg* = ref object of QObjectTaskArg
|
FetchAddressesArg* = ref object of QObjectTaskArg
|
||||||
|
paths: seq[string]
|
||||||
|
|
||||||
|
type
|
||||||
|
FetchDerivedAddressesTaskArg* = ref object of FetchAddressesArg
|
||||||
password: string
|
password: string
|
||||||
derivedFrom: string
|
derivedFrom: string
|
||||||
path: string
|
|
||||||
|
|
||||||
const getDerivedAddressTask*: Task = proc(argEncoded: string) {.gcsafe, nimcall.} =
|
const fetchDerivedAddressesTask*: Task = proc(argEncoded: string) {.gcsafe, nimcall.} =
|
||||||
let arg = decode[GetDerivedAddressTaskArg](argEncoded)
|
let arg = decode[FetchDerivedAddressesTaskArg](argEncoded)
|
||||||
var output = %*{
|
var output = %*{
|
||||||
"derivedAddress": "",
|
"derivedAddress": "",
|
||||||
"error": ""
|
"error": ""
|
||||||
}
|
}
|
||||||
try:
|
try:
|
||||||
let response = status_go_accounts.getDerivedAddress(arg.password, arg.derivedFrom, arg.path)
|
let response = status_go_accounts.getDerivedAddresses(arg.password, arg.derivedFrom, arg.paths)
|
||||||
output["derivedAddresses"] = response.result
|
output["derivedAddresses"] = response.result
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
output["error"] = %* fmt"Error getting derived address list: {e.msg}"
|
output["error"] = %* fmt"Error fetching derived address: {e.msg}"
|
||||||
arg.finish(output)
|
arg.finish(output)
|
||||||
|
|
||||||
type
|
type
|
||||||
GetDerivedAddressesTaskArg* = ref object of GetDerivedAddressTaskArg
|
FetchDerivedAddressesForMnemonicTaskArg* = ref object of FetchAddressesArg
|
||||||
pageSize: int
|
|
||||||
pageNumber: int
|
|
||||||
|
|
||||||
const getDerivedAddressesTask*: Task = proc(argEncoded: string) {.gcsafe, nimcall.} =
|
|
||||||
let arg = decode[GetDerivedAddressesTaskArg](argEncoded)
|
|
||||||
try:
|
|
||||||
let response = status_go_accounts.getDerivedAddressList(arg.password, arg.derivedFrom, arg.path, arg.pageSize, arg.pageNumber)
|
|
||||||
|
|
||||||
let output = %*{
|
|
||||||
"derivedAddresses": response.result,
|
|
||||||
"error": ""
|
|
||||||
}
|
|
||||||
arg.finish(output)
|
|
||||||
except Exception as e:
|
|
||||||
let output = %* {
|
|
||||||
"derivedAddresses": "",
|
|
||||||
"error": fmt"Error getting derived address list: {e.msg}"
|
|
||||||
}
|
|
||||||
arg.finish(output)
|
|
||||||
|
|
||||||
type
|
|
||||||
GetDerivedAddressesForMnemonicTaskArg* = ref object of QObjectTaskArg
|
|
||||||
mnemonic: string
|
mnemonic: string
|
||||||
path: string
|
|
||||||
pageSize: int
|
|
||||||
pageNumber: int
|
|
||||||
|
|
||||||
const getDerivedAddressesForMnemonicTask*: Task = proc(argEncoded: string) {.gcsafe, nimcall.} =
|
const fetchDerivedAddressesForMnemonicTask*: Task = proc(argEncoded: string) {.gcsafe, nimcall.} =
|
||||||
let arg = decode[GetDerivedAddressesForMnemonicTaskArg](argEncoded)
|
let arg = decode[FetchDerivedAddressesForMnemonicTaskArg](argEncoded)
|
||||||
try:
|
var output = %*{
|
||||||
let response = status_go_accounts.getDerivedAddressListForMnemonic(arg.mnemonic, arg.path, arg.pageSize, arg.pageNumber)
|
"derivedAddress": "",
|
||||||
|
|
||||||
let output = %*{
|
|
||||||
"derivedAddresses": response.result,
|
|
||||||
"error": ""
|
"error": ""
|
||||||
}
|
}
|
||||||
arg.finish(output)
|
try:
|
||||||
|
let response = status_go_accounts.getDerivedAddressesForMnemonic(arg.mnemonic, arg.paths)
|
||||||
|
output["derivedAddresses"] = response.result
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
let output = %* {
|
output["error"] = %* fmt"Error fetching derived address for mnemonic: {e.msg}"
|
||||||
"derivedAddresses": "",
|
|
||||||
"error": fmt"Error getting derived address list for mnemonic: {e.msg}"
|
|
||||||
}
|
|
||||||
arg.finish(output)
|
arg.finish(output)
|
||||||
|
|
||||||
type
|
type
|
||||||
GetDerivedAddressForPrivateKeyTaskArg* = ref object of QObjectTaskArg
|
FetchDetailsForAddressesTaskArg* = ref object of QObjectTaskArg
|
||||||
privateKey: string
|
uniqueId: string
|
||||||
|
addresses: seq[string]
|
||||||
|
|
||||||
const getDerivedAddressForPrivateKeyTask*: Task = proc(argEncoded: string) {.gcsafe, nimcall.} =
|
const fetchDetailsForAddressesTask*: Task = proc(argEncoded: string) {.gcsafe, nimcall.} =
|
||||||
let arg = decode[GetDerivedAddressForPrivateKeyTaskArg](argEncoded)
|
let arg = decode[FetchDetailsForAddressesTaskArg](argEncoded)
|
||||||
try:
|
for address in arg.addresses:
|
||||||
let response = status_go_accounts.getDerivedAddressForPrivateKey(arg.privateKey)
|
|
||||||
|
|
||||||
let output = %*{
|
|
||||||
"derivedAddresses": response.result,
|
|
||||||
"error": ""
|
|
||||||
}
|
|
||||||
arg.finish(output)
|
|
||||||
except Exception as e:
|
|
||||||
let output = %* {
|
|
||||||
"derivedAddresses": "",
|
|
||||||
"error": fmt"Error getting derived address list for private key: {e.msg}"
|
|
||||||
}
|
|
||||||
arg.finish(output)
|
|
||||||
|
|
||||||
type
|
|
||||||
FetchDerivedAddressDetailsTaskArg* = ref object of QObjectTaskArg
|
|
||||||
address: string
|
|
||||||
|
|
||||||
const fetchDerivedAddressDetailsTask*: Task = proc(argEncoded: string) {.gcsafe, nimcall.} =
|
|
||||||
let arg = decode[FetchDerivedAddressDetailsTaskArg](argEncoded)
|
|
||||||
var data = %* {
|
var data = %* {
|
||||||
|
"uniqueId": arg.uniqueId,
|
||||||
"details": "",
|
"details": "",
|
||||||
"error": ""
|
"error": ""
|
||||||
}
|
}
|
||||||
try:
|
try:
|
||||||
let response = status_go_accounts.getDerivedAddressDetails(arg.address)
|
let response = status_go_accounts.getAddressDetails(address)
|
||||||
|
sleep(250)
|
||||||
data["details"] = response.result
|
data["details"] = response.result
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
let err = fmt"Error getting details for an address: {e.msg}"
|
let err = fmt"Error fetching details for an address: {e.msg}"
|
||||||
data["error"] = %* err
|
data["error"] = %* err
|
||||||
arg.finish(data)
|
arg.finish(data)
|
||||||
|
|
||||||
|
@ -95,6 +95,8 @@ type
|
|||||||
relatedAccounts*: seq[WalletAccountDto]
|
relatedAccounts*: seq[WalletAccountDto]
|
||||||
ens*: string
|
ens*: string
|
||||||
assetsLoading*: bool
|
assetsLoading*: bool
|
||||||
|
keypairName*: string
|
||||||
|
lastUsedDerivationIndex*: int
|
||||||
|
|
||||||
proc newDto*(
|
proc newDto*(
|
||||||
name: string,
|
name: string,
|
||||||
@ -137,6 +139,8 @@ proc toWalletAccountDto*(jsonObj: JsonNode): WalletAccountDto =
|
|||||||
discard jsonObj.getProp("type", result.walletType)
|
discard jsonObj.getProp("type", result.walletType)
|
||||||
discard jsonObj.getProp("emoji", result.emoji)
|
discard jsonObj.getProp("emoji", result.emoji)
|
||||||
discard jsonObj.getProp("derived-from", result.derivedfrom)
|
discard jsonObj.getProp("derived-from", result.derivedfrom)
|
||||||
|
discard jsonObj.getProp("keypair-name", result.keypairName)
|
||||||
|
discard jsonObj.getProp("last-used-derivation-index", result.lastUsedDerivationIndex)
|
||||||
result.assetsLoading = true
|
result.assetsLoading = true
|
||||||
|
|
||||||
proc getCurrencyBalance*(self: BalanceDto, currencyPrice: float64): float64 =
|
proc getCurrencyBalance*(self: BalanceDto, currencyPrice: float64): float64 =
|
||||||
|
@ -30,9 +30,11 @@ const SIGNAL_WALLET_ACCOUNT_DELETED* = "walletAccount/accountDeleted"
|
|||||||
const SIGNAL_WALLET_ACCOUNT_CURRENCY_UPDATED* = "walletAccount/currencyUpdated"
|
const SIGNAL_WALLET_ACCOUNT_CURRENCY_UPDATED* = "walletAccount/currencyUpdated"
|
||||||
const SIGNAL_WALLET_ACCOUNT_UPDATED* = "walletAccount/walletAccountUpdated"
|
const SIGNAL_WALLET_ACCOUNT_UPDATED* = "walletAccount/walletAccountUpdated"
|
||||||
const SIGNAL_WALLET_ACCOUNT_NETWORK_ENABLED_UPDATED* = "walletAccount/networkEnabledUpdated"
|
const SIGNAL_WALLET_ACCOUNT_NETWORK_ENABLED_UPDATED* = "walletAccount/networkEnabledUpdated"
|
||||||
const SIGNAL_WALLET_ACCOUNT_DERIVED_ADDRESS_READY* = "walletAccount/derivedAddressesReady"
|
|
||||||
const SIGNAL_WALLET_ACCOUNT_TOKENS_REBUILT* = "walletAccount/tokensRebuilt"
|
const SIGNAL_WALLET_ACCOUNT_TOKENS_REBUILT* = "walletAccount/tokensRebuilt"
|
||||||
const SIGNAL_WALLET_ACCOUNT_DERIVED_ADDRESS_DETAILS_FETCHED* = "walletAccount/derivedAddressDetailsFetched"
|
const SIGNAL_WALLET_ACCOUNT_TOKENS_BEING_FETCHED* = "walletAccount/tokenFetching"
|
||||||
|
const SIGNAL_WALLET_ACCOUNT_DERIVED_ADDRESSES_FETCHED* = "walletAccount/derivedAddressesFetched"
|
||||||
|
const SIGNAL_WALLET_ACCOUNT_DERIVED_ADDRESSES_FROM_MNEMONIC_FETCHED* = "walletAccount/derivedAddressesFromMnemonicFetched"
|
||||||
|
const SIGNAL_WALLET_ACCOUNT_ADDRESS_DETAILS_FETCHED* = "walletAccount/addressDetailsFetched"
|
||||||
|
|
||||||
const SIGNAL_KEYCARDS_SYNCHRONIZED* = "keycardsSynchronized"
|
const SIGNAL_KEYCARDS_SYNCHRONIZED* = "keycardsSynchronized"
|
||||||
const SIGNAL_NEW_KEYCARD_SET* = "newKeycardSet"
|
const SIGNAL_NEW_KEYCARD_SET* = "newKeycardSet"
|
||||||
@ -83,6 +85,7 @@ type WalletAccountUpdated* = ref object of Args
|
|||||||
account*: WalletAccountDto
|
account*: WalletAccountDto
|
||||||
|
|
||||||
type DerivedAddressesArgs* = ref object of Args
|
type DerivedAddressesArgs* = ref object of Args
|
||||||
|
uniqueId*: string
|
||||||
derivedAddresses*: seq[DerivedAddressDto]
|
derivedAddresses*: seq[DerivedAddressDto]
|
||||||
error*: string
|
error*: string
|
||||||
|
|
||||||
@ -264,7 +267,7 @@ QtObject:
|
|||||||
|
|
||||||
proc getIndex*(self: Service, address: string): int =
|
proc getIndex*(self: Service, address: string): int =
|
||||||
let accounts = self.getWalletAccounts()
|
let accounts = self.getWalletAccounts()
|
||||||
for i in 0..accounts.len:
|
for i in 0 ..< accounts.len:
|
||||||
if(accounts[i].address == address):
|
if(accounts[i].address == address):
|
||||||
return i
|
return i
|
||||||
|
|
||||||
@ -308,101 +311,77 @@ QtObject:
|
|||||||
self.buildAllTokens(@[newAccount.address], store = true)
|
self.buildAllTokens(@[newAccount.address], store = true)
|
||||||
self.events.emit(SIGNAL_WALLET_ACCOUNT_SAVED, AccountSaved(account: newAccount))
|
self.events.emit(SIGNAL_WALLET_ACCOUNT_SAVED, AccountSaved(account: newAccount))
|
||||||
|
|
||||||
proc addOrReplaceWalletAccount(self: Service, name, address, path, addressAccountIsDerivedFrom, publicKey, keyUid, accountType,
|
## if password is not provided local keystore file won't be created
|
||||||
color, emoji: string, walletDefaultAccount = false, chatDefaultAccount = false): string =
|
proc addWalletAccount*(self: Service, password: string, doPasswordHashing: bool, name, keyPairName, address, path: string,
|
||||||
|
lastUsedDerivationIndex: int, rootWalletMasterKey, publicKey, keyUid, accountType, color, emoji: string): string =
|
||||||
try:
|
try:
|
||||||
let response = status_go_accounts.saveAccount(name, address, path, addressAccountIsDerivedFrom, publicKey, keyUid,
|
var response: RpcResponse[JsonNode]
|
||||||
accountType, color, emoji, walletDefaultAccount, chatDefaultAccount)
|
if password.len == 0:
|
||||||
|
response = status_go_accounts.addAccountWithoutKeystoreFileCreation(name, keyPairName, address, path, lastUsedDerivationIndex,
|
||||||
|
rootWalletMasterKey, publicKey, keyUid, accountType, color, emoji)
|
||||||
|
else:
|
||||||
|
var finalPassword = password
|
||||||
|
if doPasswordHashing:
|
||||||
|
finalPassword = utils.hashPassword(password)
|
||||||
|
response = status_go_accounts.addAccount(finalPassword, name, keyPairName, address, path,
|
||||||
|
lastUsedDerivationIndex, rootWalletMasterKey, publicKey, keyUid, accountType, color, emoji)
|
||||||
if not response.error.isNil:
|
if not response.error.isNil:
|
||||||
return "(" & $response.error.code & ") " & response.error.message
|
error "status-go error", procName="addWalletAccount", errCode=response.error.code, errDesription=response.error.message
|
||||||
|
return response.error.message
|
||||||
|
self.addNewAccountToLocalStore()
|
||||||
|
return ""
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
error "error: ", procName="addWalletAccount", errName=e.name, errDesription=e.msg
|
error "error: ", procName="addWalletAccount", errName=e.name, errDesription=e.msg
|
||||||
return "error: " & e.msg
|
return e.msg
|
||||||
|
|
||||||
proc generateNewAccount*(self: Service, password: string, accountName: string, color: string, emoji: string,
|
proc addNewPrivateKeyAccount*(self: Service, privateKey, password: string, doPasswordHashing: bool, name, keyPairName, address, path: string,
|
||||||
path: string, derivedFrom: string, skipPasswordVerification: bool): string =
|
lastUsedDerivationIndex: int, rootWalletMasterKey, publicKey, keyUid, accountType, color, emoji: string): string =
|
||||||
|
if password.len == 0:
|
||||||
|
error "for adding new private key account, password must be provided"
|
||||||
|
return
|
||||||
|
var finalPassword = password
|
||||||
|
if doPasswordHashing:
|
||||||
|
finalPassword = utils.hashPassword(password)
|
||||||
try:
|
try:
|
||||||
if skipPasswordVerification:
|
let response = status_go_accounts.importPrivateKey(privateKey, finalPassword)
|
||||||
discard backend.generateAccountWithDerivedPathPasswordVerified(
|
if not response.error.isNil:
|
||||||
password,
|
error "status-go error importing private key", procName="addNewPrivateKeyAccount", errCode=response.error.code, errDesription=response.error.message
|
||||||
accountName,
|
return response.error.message
|
||||||
color,
|
return self.addWalletAccount(password, doPasswordHashing, name, keyPairName, address, path, lastUsedDerivationIndex, rootWalletMasterKey, publicKey,
|
||||||
emoji,
|
keyUid, accountType, color, emoji)
|
||||||
path,
|
|
||||||
derivedFrom)
|
|
||||||
else:
|
|
||||||
discard backend.generateAccountWithDerivedPath(
|
|
||||||
utils.hashPassword(password),
|
|
||||||
accountName,
|
|
||||||
color,
|
|
||||||
emoji,
|
|
||||||
path,
|
|
||||||
derivedFrom)
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
return fmt"Error generating new account: {e.msg}"
|
error "error: ", procName="addNewPrivateKeyAccount", errName=e.name, errDesription=e.msg
|
||||||
|
return e.msg
|
||||||
|
|
||||||
self.addNewAccountToLocalStore()
|
proc addNewSeedPhraseAccount*(self: Service, seedPhrase, password: string, doPasswordHashing: bool, name, keyPairName, address, path: string,
|
||||||
|
lastUsedDerivationIndex: int, rootWalletMasterKey, publicKey, keyUid, accountType, color, emoji: string): string =
|
||||||
proc addAccountsFromPrivateKey*(self: Service, privateKey: string, password: string, accountName: string, color: string,
|
if password.len == 0:
|
||||||
emoji: string, skipPasswordVerification: bool): string =
|
error "for adding new seed phrase account, password must be provided"
|
||||||
|
return
|
||||||
|
var finalPassword = password
|
||||||
|
if doPasswordHashing:
|
||||||
|
finalPassword = utils.hashPassword(password)
|
||||||
try:
|
try:
|
||||||
if skipPasswordVerification:
|
let response = status_go_accounts.importMnemonic(seedPhrase, finalPassword)
|
||||||
discard backend.addAccountWithPrivateKeyPasswordVerified(
|
if not response.error.isNil:
|
||||||
privateKey,
|
error "status-go error importing private key", procName="addNewSeedPhraseAccount", errCode=response.error.code, errDesription=response.error.message
|
||||||
password,
|
return response.error.message
|
||||||
accountName,
|
return self.addWalletAccount(password, doPasswordHashing, name, keyPairName, address, path, lastUsedDerivationIndex, rootWalletMasterKey, publicKey,
|
||||||
color,
|
keyUid, accountType, color, emoji)
|
||||||
emoji)
|
|
||||||
else:
|
|
||||||
discard backend.addAccountWithPrivateKey(
|
|
||||||
privateKey,
|
|
||||||
utils.hashPassword(password),
|
|
||||||
accountName,
|
|
||||||
color,
|
|
||||||
emoji)
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
return fmt"Error adding account with private key: {e.msg}"
|
error "error: ", procName="addNewSeedPhraseAccount", errName=e.name, errDesription=e.msg
|
||||||
|
return e.msg
|
||||||
|
|
||||||
self.addNewAccountToLocalStore()
|
proc getRandomMnemonic*(self: Service): string =
|
||||||
|
|
||||||
proc addAccountsFromSeed*(self: Service, mnemonic: string, password: string, accountName: string, color: string,
|
|
||||||
emoji: string, path: string, skipPasswordVerification: bool): string =
|
|
||||||
try:
|
try:
|
||||||
if skipPasswordVerification:
|
let response = status_go_accounts.getRandomMnemonic()
|
||||||
discard backend.addAccountWithMnemonicAndPathPasswordVerified(
|
if not response.error.isNil:
|
||||||
mnemonic,
|
error "status-go error", procName="getRandomMnemonic", errCode=response.error.code, errDesription=response.error.message
|
||||||
password,
|
return ""
|
||||||
accountName,
|
return response.result.getStr
|
||||||
color,
|
|
||||||
emoji,
|
|
||||||
path
|
|
||||||
)
|
|
||||||
else:
|
|
||||||
discard backend.addAccountWithMnemonicAndPath(
|
|
||||||
mnemonic,
|
|
||||||
utils.hashPassword(password),
|
|
||||||
accountName,
|
|
||||||
color,
|
|
||||||
emoji,
|
|
||||||
path
|
|
||||||
)
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
return fmt"Error adding account with mnemonic: {e.msg}"
|
error "error: ", procName="getRandomMnemonic", errName=e.name, errDesription=e.msg
|
||||||
|
return ""
|
||||||
self.addNewAccountToLocalStore()
|
|
||||||
|
|
||||||
proc addWatchOnlyAccount*(self: Service, address: string, accountName: string, color: string, emoji: string): string =
|
|
||||||
try:
|
|
||||||
discard backend.addAccountWatch(
|
|
||||||
address,
|
|
||||||
accountName,
|
|
||||||
color,
|
|
||||||
emoji
|
|
||||||
)
|
|
||||||
except Exception as e:
|
|
||||||
return fmt"Error adding account with mnemonic: {e.msg}"
|
|
||||||
|
|
||||||
self.addNewAccountToLocalStore()
|
|
||||||
|
|
||||||
proc deleteAccount*(self: Service, address: string, password = "") =
|
proc deleteAccount*(self: Service, address: string, password = "") =
|
||||||
try:
|
try:
|
||||||
@ -437,102 +416,83 @@ QtObject:
|
|||||||
if not self.walletAccountsContainsAddress(address):
|
if not self.walletAccountsContainsAddress(address):
|
||||||
error "account's address is not among known addresses: ", address=address
|
error "account's address is not among known addresses: ", address=address
|
||||||
return
|
return
|
||||||
|
try:
|
||||||
var account = self.getAccountByAddress(address)
|
var account = self.getAccountByAddress(address)
|
||||||
let res = self.addOrReplaceWalletAccount(accountName, account.address, account.path, account.derivedfrom,
|
let response = status_go_accounts.updateAccount(accountName, account.keyPairName, account.address, account.path, account.lastUsedDerivationIndex,
|
||||||
account.publicKey, account.keyUid, account.walletType, color, emoji, account.isWallet, account.isChat)
|
account.derivedfrom, account.publicKey, account.keyUid, account.walletType, color, emoji, account.isWallet, account.isChat)
|
||||||
if res.len == 0:
|
if not response.error.isNil:
|
||||||
|
error "status-go error", procName="updateWalletAccount", errCode=response.error.code, errDesription=response.error.message
|
||||||
|
return
|
||||||
account.name = accountName
|
account.name = accountName
|
||||||
account.color = color
|
account.color = color
|
||||||
account.emoji = emoji
|
account.emoji = emoji
|
||||||
self.events.emit(SIGNAL_WALLET_ACCOUNT_UPDATED, WalletAccountUpdated(account: account))
|
self.events.emit(SIGNAL_WALLET_ACCOUNT_UPDATED, WalletAccountUpdated(account: account))
|
||||||
|
except Exception as e:
|
||||||
|
error "error: ", procName="updateWalletAccount", errName=e.name, errDesription=e.msg
|
||||||
|
|
||||||
proc getDerivedAddress*(self: Service, password: string, derivedFrom: string, path: string, hashPassword: bool)=
|
proc fetchDerivedAddresses*(self: Service, password: string, derivedFrom: string, paths: seq[string], hashPassword: bool)=
|
||||||
let arg = GetDerivedAddressTaskArg(
|
let arg = FetchDerivedAddressesTaskArg(
|
||||||
password: if hashPassword: utils.hashPassword(password) else: password,
|
password: if hashPassword: utils.hashPassword(password) else: password,
|
||||||
derivedFrom: derivedFrom,
|
derivedFrom: derivedFrom,
|
||||||
path: path,
|
paths: paths,
|
||||||
tptr: cast[ByteAddress](getDerivedAddressTask),
|
tptr: cast[ByteAddress](fetchDerivedAddressesTask),
|
||||||
vptr: cast[ByteAddress](self.vptr),
|
vptr: cast[ByteAddress](self.vptr),
|
||||||
slot: "setDerivedAddress",
|
slot: "onDerivedAddressesFetched",
|
||||||
)
|
)
|
||||||
self.threadpool.start(arg)
|
self.threadpool.start(arg)
|
||||||
|
|
||||||
proc getDerivedAddressList*(self: Service, password: string, derivedFrom: string, path: string, pageSize: int, pageNumber: int, hashPassword: bool)=
|
proc onDerivedAddressesFetched*(self: Service, jsonString: string) {.slot.} =
|
||||||
let arg = GetDerivedAddressesTaskArg(
|
let response = parseJson(jsonString)
|
||||||
password: if hashPassword: utils.hashPassword(password) else: password,
|
|
||||||
derivedFrom: derivedFrom,
|
|
||||||
path: path,
|
|
||||||
pageSize: pageSize,
|
|
||||||
pageNumber: pageNumber,
|
|
||||||
tptr: cast[ByteAddress](getDerivedAddressesTask),
|
|
||||||
vptr: cast[ByteAddress](self.vptr),
|
|
||||||
slot: "setDerivedAddresses",
|
|
||||||
)
|
|
||||||
self.threadpool.start(arg)
|
|
||||||
|
|
||||||
proc getDerivedAddressListForMnemonic*(self: Service, mnemonic: string, path: string, pageSize: int, pageNumber: int) =
|
|
||||||
let arg = GetDerivedAddressesForMnemonicTaskArg(
|
|
||||||
mnemonic: mnemonic,
|
|
||||||
path: path,
|
|
||||||
pageSize: pageSize,
|
|
||||||
pageNumber: pageNumber,
|
|
||||||
tptr: cast[ByteAddress](getDerivedAddressesForMnemonicTask),
|
|
||||||
vptr: cast[ByteAddress](self.vptr),
|
|
||||||
slot: "setDerivedAddresses",
|
|
||||||
)
|
|
||||||
self.threadpool.start(arg)
|
|
||||||
|
|
||||||
proc getDerivedAddressForPrivateKey*(self: Service, privateKey: string) =
|
|
||||||
let arg = GetDerivedAddressForPrivateKeyTaskArg(
|
|
||||||
privateKey: privateKey,
|
|
||||||
tptr: cast[ByteAddress](getDerivedAddressForPrivateKeyTask),
|
|
||||||
vptr: cast[ByteAddress](self.vptr),
|
|
||||||
slot: "setDerivedAddresses",
|
|
||||||
)
|
|
||||||
self.threadpool.start(arg)
|
|
||||||
|
|
||||||
proc setDerivedAddresses*(self: Service, derivedAddressesJson: string) {.slot.} =
|
|
||||||
let response = parseJson(derivedAddressesJson)
|
|
||||||
var derivedAddress: seq[DerivedAddressDto] = @[]
|
var derivedAddress: seq[DerivedAddressDto] = @[]
|
||||||
derivedAddress = response["derivedAddresses"].getElems().map(x => x.toDerivedAddressDto())
|
derivedAddress = response["derivedAddresses"].getElems().map(x => x.toDerivedAddressDto())
|
||||||
let error = response["error"].getStr()
|
let error = response["error"].getStr()
|
||||||
|
self.events.emit(SIGNAL_WALLET_ACCOUNT_DERIVED_ADDRESSES_FETCHED, DerivedAddressesArgs(
|
||||||
# emit event
|
|
||||||
self.events.emit(SIGNAL_WALLET_ACCOUNT_DERIVED_ADDRESS_READY, DerivedAddressesArgs(
|
|
||||||
derivedAddresses: derivedAddress,
|
derivedAddresses: derivedAddress,
|
||||||
error: error
|
error: error
|
||||||
))
|
))
|
||||||
|
|
||||||
proc setDerivedAddress*(self: Service, derivedAddressesJson: string) {.slot.} =
|
proc fetchDerivedAddressesForMnemonic*(self: Service, mnemonic: string, paths: seq[string])=
|
||||||
let response = parseJson(derivedAddressesJson)
|
let arg = FetchDerivedAddressesForMnemonicTaskArg(
|
||||||
let derivedAddress = response["derivedAddresses"].toDerivedAddressDto()
|
mnemonic: mnemonic,
|
||||||
let error = response["error"].getStr()
|
paths: paths,
|
||||||
# emit event
|
tptr: cast[ByteAddress](fetchDerivedAddressesForMnemonicTask),
|
||||||
self.events.emit(SIGNAL_WALLET_ACCOUNT_DERIVED_ADDRESS_READY, DerivedAddressesArgs(
|
|
||||||
derivedAddresses: @[derivedAddress],
|
|
||||||
error: error
|
|
||||||
))
|
|
||||||
|
|
||||||
proc fetchDerivedAddressDetails*(self: Service, address: string) =
|
|
||||||
let arg = FetchDerivedAddressDetailsTaskArg(
|
|
||||||
address: address,
|
|
||||||
tptr: cast[ByteAddress](fetchDerivedAddressDetailsTask),
|
|
||||||
vptr: cast[ByteAddress](self.vptr),
|
vptr: cast[ByteAddress](self.vptr),
|
||||||
slot: "onDerivedAddressDetailsFetched",
|
slot: "onDerivedAddressesForMnemonicFetched",
|
||||||
)
|
)
|
||||||
self.threadpool.start(arg)
|
self.threadpool.start(arg)
|
||||||
|
|
||||||
proc onDerivedAddressDetailsFetched*(self: Service, jsonString: string) {.slot.} =
|
proc onDerivedAddressesForMnemonicFetched*(self: Service, jsonString: string) {.slot.} =
|
||||||
|
let response = parseJson(jsonString)
|
||||||
|
var derivedAddress: seq[DerivedAddressDto] = @[]
|
||||||
|
derivedAddress = response["derivedAddresses"].getElems().map(x => x.toDerivedAddressDto())
|
||||||
|
let error = response["error"].getStr()
|
||||||
|
self.events.emit(SIGNAL_WALLET_ACCOUNT_DERIVED_ADDRESSES_FROM_MNEMONIC_FETCHED, DerivedAddressesArgs(
|
||||||
|
derivedAddresses: derivedAddress,
|
||||||
|
error: error
|
||||||
|
))
|
||||||
|
|
||||||
|
proc fetchDetailsForAddresses*(self: Service, uniqueId: string, addresses: seq[string]) =
|
||||||
|
let arg = FetchDetailsForAddressesTaskArg(
|
||||||
|
uniqueId: uniqueId,
|
||||||
|
addresses: addresses,
|
||||||
|
tptr: cast[ByteAddress](fetchDetailsForAddressesTask),
|
||||||
|
vptr: cast[ByteAddress](self.vptr),
|
||||||
|
slot: "onAddressDetailsFetched",
|
||||||
|
)
|
||||||
|
self.threadpool.start(arg)
|
||||||
|
|
||||||
|
proc onAddressDetailsFetched*(self: Service, jsonString: string) {.slot.} =
|
||||||
var data = DerivedAddressesArgs()
|
var data = DerivedAddressesArgs()
|
||||||
try:
|
try:
|
||||||
let response = parseJson(jsonString)
|
let response = parseJson(jsonString)
|
||||||
|
data.uniqueId = response["uniqueId"].getStr()
|
||||||
let addrDto = response{"details"}.toDerivedAddressDto()
|
let addrDto = response{"details"}.toDerivedAddressDto()
|
||||||
data.derivedAddresses.add(addrDto)
|
data.derivedAddresses.add(addrDto)
|
||||||
data.error = response["error"].getStr()
|
data.error = response["error"].getStr()
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
error "error: ", procName="getDerivedAddressDetails", errName = e.name, errDesription = e.msg
|
error "error: ", procName="fetchAddressDetails", errName = e.name, errDesription = e.msg
|
||||||
data.error = e.msg
|
data.error = e.msg
|
||||||
self.events.emit(SIGNAL_WALLET_ACCOUNT_DERIVED_ADDRESS_DETAILS_FETCHED, data)
|
self.events.emit(SIGNAL_WALLET_ACCOUNT_ADDRESS_DETAILS_FETCHED, data)
|
||||||
|
|
||||||
proc updateAssetsLoadingState(self: Service, wAddress: string, loading: bool) =
|
proc updateAssetsLoadingState(self: Service, wAddress: string, loading: bool) =
|
||||||
withLock self.walletAccountsLock:
|
withLock self.walletAccountsLock:
|
||||||
@ -809,13 +769,6 @@ QtObject:
|
|||||||
error "error: ", procName="deleteKeycard", errName = e.name, errDesription = e.msg
|
error "error: ", procName="deleteKeycard", errName = e.name, errDesription = e.msg
|
||||||
return false
|
return false
|
||||||
|
|
||||||
proc addWalletAccount*(self: Service, name, address, path, addressAccountIsDerivedFrom, publicKey, keyUid, accountType,
|
|
||||||
color, emoji: string): string =
|
|
||||||
result = self.addOrReplaceWalletAccount(name, address, path, addressAccountIsDerivedFrom, publicKey, keyUid,
|
|
||||||
accountType, color, emoji)
|
|
||||||
if result.len == 0:
|
|
||||||
self.addNewAccountToLocalStore()
|
|
||||||
|
|
||||||
proc handleKeycardActions(self: Service, keycardActions: seq[KeycardActionDto]) =
|
proc handleKeycardActions(self: Service, keycardActions: seq[KeycardActionDto]) =
|
||||||
if keycardActions.len == 0:
|
if keycardActions.len == 0:
|
||||||
return
|
return
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
import json, json_serialization, chronicles, strutils
|
import json, json_serialization, chronicles, strutils
|
||||||
import ./core, ../app_service/common/utils
|
import ./core, ../app_service/common/utils
|
||||||
|
import ../app_service/common/account_constants
|
||||||
import ./response_type
|
import ./response_type
|
||||||
|
|
||||||
import status_go
|
import status_go
|
||||||
@ -25,22 +26,64 @@ proc deleteAccount*(address: string, password: string): RpcResponse[JsonNode] {.
|
|||||||
let payload = %* [address, password]
|
let payload = %* [address, password]
|
||||||
return core.callPrivateRPC("accounts_deleteAccount", payload)
|
return core.callPrivateRPC("accounts_deleteAccount", payload)
|
||||||
|
|
||||||
proc saveAccount*(name, address, path, addressAccountIsDerivedFrom, publicKey, keyUid, accountType, color, emoji: string,
|
## Adds a new account and creates a Keystore file if password is provided, otherwise it only creates a new account
|
||||||
walletDefaultAccount: bool, chatDefaultAccount: bool):
|
proc addAccount*(password, name, keyPairName, address, path: string, lastUsedDerivationIndex: int, rootWalletMasterKey, publicKey,
|
||||||
|
keyUid, accountType, color, emoji: string):
|
||||||
|
RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
|
let payload = %* [
|
||||||
|
password,
|
||||||
|
{
|
||||||
|
"address": address,
|
||||||
|
"key-uid": keyUid,
|
||||||
|
"wallet": false, #this refers to the default wallet account and it's set at the moment of Status chat account creation, cannot be changed later
|
||||||
|
"chat": false, #this refers to Status chat account, set when the Status account is created, cannot be changed later
|
||||||
|
"type": accountType,
|
||||||
|
#"storage" present on the status-go side, but we don't use it
|
||||||
|
"path": path,
|
||||||
|
"public-key": publicKey,
|
||||||
|
"name": name,
|
||||||
|
"emoji": emoji,
|
||||||
|
"color": color,
|
||||||
|
#"hidden" present on the status-go side, but we don't use it
|
||||||
|
"derived-from": rootWalletMasterKey,
|
||||||
|
#"clock" we leave this empty, if needed should be set on the status-go side
|
||||||
|
#"removed" present on the status-go side, used for synchronization, no need to set it here
|
||||||
|
"keypair-name": keyPairName,
|
||||||
|
"last-used-derivation-index": lastUsedDerivationIndex
|
||||||
|
}
|
||||||
|
]
|
||||||
|
return core.callPrivateRPC("accounts_addAccount", payload)
|
||||||
|
|
||||||
|
## Adds a new account without creating a Keystore file
|
||||||
|
proc addAccountWithoutKeystoreFileCreation*(name, keyPairName, address, path: string, lastUsedDerivationIndex: int, rootWalletMasterKey, publicKey,
|
||||||
|
keyUid, accountType, color, emoji: string):
|
||||||
|
RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
|
return addAccount(password = "", name, keyPairName, address, path, lastUsedDerivationIndex, rootWalletMasterKey, publicKey,
|
||||||
|
keyUid, accountType, color, emoji)
|
||||||
|
|
||||||
|
## Updates either regular or keycard account, without interaction to a Keystore file
|
||||||
|
proc updateAccount*(name, keyPairName, address, path: string, lastUsedDerivationIndex: int, rootWalletMasterKey, publicKey,
|
||||||
|
keyUid, accountType, color, emoji: string, walletDefaultAccount: bool, chatDefaultAccount: bool):
|
||||||
RpcResponse[JsonNode] {.raises: [Exception].} =
|
RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
let payload = %* [
|
let payload = %* [
|
||||||
[{
|
[{
|
||||||
"name": name,
|
|
||||||
"address": address,
|
"address": address,
|
||||||
"path": path,
|
|
||||||
"derived-from": addressAccountIsDerivedFrom,
|
|
||||||
"public-key": publicKey,
|
|
||||||
"key-uid": keyUid,
|
"key-uid": keyUid,
|
||||||
"type": accountType,
|
|
||||||
"color": color,
|
|
||||||
"emoji": emoji,
|
|
||||||
"wallet": walletDefaultAccount,
|
"wallet": walletDefaultAccount,
|
||||||
"chat": chatDefaultAccount
|
"chat": chatDefaultAccount,
|
||||||
|
"type": accountType,
|
||||||
|
#"storage" present on the status-go side, but we don't use it
|
||||||
|
"path": path,
|
||||||
|
"public-key": publicKey,
|
||||||
|
"name": name,
|
||||||
|
"emoji": emoji,
|
||||||
|
"color": color,
|
||||||
|
#"hidden" present on the status-go side, but we don't use it
|
||||||
|
"derived-from": rootWalletMasterKey,
|
||||||
|
#"clock" we leave this empty, if needed should be set on the status-go side
|
||||||
|
#"removed" present on the status-go side, used for synchronization, no need to set it here
|
||||||
|
"keypair-name": keyPairName,
|
||||||
|
"last-used-derivation-index": lastUsedDerivationIndex
|
||||||
}]
|
}]
|
||||||
]
|
]
|
||||||
return core.callPrivateRPC("accounts_saveAccounts", payload)
|
return core.callPrivateRPC("accounts_saveAccounts", payload)
|
||||||
@ -130,6 +173,10 @@ proc isAlias*(value: string): bool =
|
|||||||
let r = Json.decode(response, JsonNode)
|
let r = Json.decode(response, JsonNode)
|
||||||
return r["result"].getBool()
|
return r["result"].getBool()
|
||||||
|
|
||||||
|
proc getRandomMnemonic*(): RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
|
let payload = %* []
|
||||||
|
return core.callPrivateRPC("accounts_getRandomMnemonic", payload)
|
||||||
|
|
||||||
proc multiAccountImportMnemonic*(mnemonic: string): RpcResponse[JsonNode] {.raises: [Exception].} =
|
proc multiAccountImportMnemonic*(mnemonic: string): RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
let payload = %* {
|
let payload = %* {
|
||||||
"mnemonicPhrase": mnemonic,
|
"mnemonicPhrase": mnemonic,
|
||||||
@ -144,6 +191,12 @@ proc multiAccountImportMnemonic*(mnemonic: string): RpcResponse[JsonNode] {.rais
|
|||||||
error "error doing rpc request", methodName = "multiAccountImportMnemonic", exception=e.msg
|
error "error doing rpc request", methodName = "multiAccountImportMnemonic", exception=e.msg
|
||||||
raise newException(RpcException, e.msg)
|
raise newException(RpcException, e.msg)
|
||||||
|
|
||||||
|
## Imports a new mnemonic and creates local keystore file.
|
||||||
|
proc importMnemonic*(mnemonic, password: string):
|
||||||
|
RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
|
let payload = %* [mnemonic, password]
|
||||||
|
return core.callPrivateRPC("accounts_importMnemonic", payload)
|
||||||
|
|
||||||
proc createAccountFromMnemonicAndDeriveAccountsForPaths*(mnemonic: string, paths: seq[string]): RpcResponse[JsonNode] {.raises: [Exception].} =
|
proc createAccountFromMnemonicAndDeriveAccountsForPaths*(mnemonic: string, paths: seq[string]): RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
let payload = %* {
|
let payload = %* {
|
||||||
"mnemonicPhrase": mnemonic,
|
"mnemonicPhrase": mnemonic,
|
||||||
@ -158,6 +211,21 @@ proc createAccountFromMnemonicAndDeriveAccountsForPaths*(mnemonic: string, paths
|
|||||||
error "error doing rpc request", methodName = "createAccountFromMnemonicAndDeriveAccountsForPaths", exception=e.msg
|
error "error doing rpc request", methodName = "createAccountFromMnemonicAndDeriveAccountsForPaths", exception=e.msg
|
||||||
raise newException(RpcException, e.msg)
|
raise newException(RpcException, e.msg)
|
||||||
|
|
||||||
|
## Imports a new private key and creates local keystore file.
|
||||||
|
proc importPrivateKey*(privateKey, password: string):
|
||||||
|
RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
|
let payload = %* [privateKey, password]
|
||||||
|
return core.callPrivateRPC("accounts_importPrivateKey", payload)
|
||||||
|
|
||||||
|
proc createAccountFromPrivateKey*(privateKey: string): RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
|
let payload = %* {"privateKey": privateKey}
|
||||||
|
try:
|
||||||
|
let response = status_go.createAccountFromPrivateKey($payload)
|
||||||
|
result.result = Json.decode(response, JsonNode)
|
||||||
|
except RpcException as e:
|
||||||
|
error "error doing rpc request", methodName = "createAccountFromPrivateKey", exception=e.msg
|
||||||
|
raise newException(RpcException, e.msg)
|
||||||
|
|
||||||
proc deriveAccounts*(accountId: string, paths: seq[string]): RpcResponse[JsonNode] {.raises: [Exception].} =
|
proc deriveAccounts*(accountId: string, paths: seq[string]): RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
let payload = %* {
|
let payload = %* {
|
||||||
"accountID": accountId,
|
"accountID": accountId,
|
||||||
@ -323,25 +391,17 @@ proc setDisplayName*(displayName: string): RpcResponse[JsonNode] {.raises: [Exce
|
|||||||
let payload = %* [displayName]
|
let payload = %* [displayName]
|
||||||
result = core.callPrivateRPC("setDisplayName".prefix, payload)
|
result = core.callPrivateRPC("setDisplayName".prefix, payload)
|
||||||
|
|
||||||
proc getDerivedAddress*(password: string, derivedFrom: string, path: string): RpcResponse[JsonNode] {.raises: [Exception].} =
|
proc getDerivedAddresses*(password: string, derivedFrom: string, paths: seq[string]): RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
let payload = %* [password, derivedFrom, path]
|
let payload = %* [password, derivedFrom, paths]
|
||||||
result = core.callPrivateRPC("wallet_getDerivedAddressForPath", payload)
|
result = core.callPrivateRPC("wallet_getDerivedAddresses", payload)
|
||||||
|
|
||||||
proc getDerivedAddressList*(password: string, derivedFrom: string, path: string, pageSize: int = 0, pageNumber: int = 6,): RpcResponse[JsonNode] {.raises: [Exception].} =
|
proc getDerivedAddressesForMnemonic*(mnemonic: string, paths: seq[string]): RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
let payload = %* [password, derivedFrom, path, pageSize, pageNumber ]
|
let payload = %* [mnemonic, paths]
|
||||||
result = core.callPrivateRPC("wallet_getDerivedAddressesForPath", payload)
|
result = core.callPrivateRPC("wallet_getDerivedAddressesForMnemonic", payload)
|
||||||
|
|
||||||
proc getDerivedAddressListForMnemonic*(mnemonic: string, path: string, pageSize: int = 0, pageNumber: int = 6,): RpcResponse[JsonNode] {.raises: [Exception].} =
|
proc getAddressDetails*(address: string,): RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
let payload = %* [mnemonic, path, pageSize, pageNumber ]
|
|
||||||
result = core.callPrivateRPC("wallet_getDerivedAddressesForMnemonicWithPath", payload)
|
|
||||||
|
|
||||||
proc getDerivedAddressForPrivateKey*(privateKey: string,): RpcResponse[JsonNode] {.raises: [Exception].} =
|
|
||||||
let payload = %* [privateKey]
|
|
||||||
result = core.callPrivateRPC("wallet_getDerivedAddressForPrivateKey", payload)
|
|
||||||
|
|
||||||
proc getDerivedAddressDetails*(address: string,): RpcResponse[JsonNode] {.raises: [Exception].} =
|
|
||||||
let payload = %* [address]
|
let payload = %* [address]
|
||||||
result = core.callPrivateRPC("wallet_getDerivedAddressDetails", payload)
|
result = core.callPrivateRPC("wallet_getAddressDetails", payload)
|
||||||
|
|
||||||
proc verifyPassword*(password: string): RpcResponse[JsonNode] {.raises: [Exception].} =
|
proc verifyPassword*(password: string): RpcResponse[JsonNode] {.raises: [Exception].} =
|
||||||
let payload = %* [password]
|
let payload = %* [password]
|
||||||
|
@ -113,58 +113,6 @@ rpc(fetchPrices, "wallet"):
|
|||||||
symbols: seq[string]
|
symbols: seq[string]
|
||||||
currencies: seq[string]
|
currencies: seq[string]
|
||||||
|
|
||||||
rpc(generateAccountWithDerivedPath, "accounts"):
|
|
||||||
password: string
|
|
||||||
name: string
|
|
||||||
color: string
|
|
||||||
emoji: string
|
|
||||||
path: string
|
|
||||||
derivedFrom: string
|
|
||||||
|
|
||||||
rpc(generateAccountWithDerivedPathPasswordVerified, "accounts"):
|
|
||||||
password: string
|
|
||||||
name: string
|
|
||||||
color: string
|
|
||||||
emoji: string
|
|
||||||
path: string
|
|
||||||
derivedFrom: string
|
|
||||||
|
|
||||||
rpc(addAccountWithMnemonicAndPath, "accounts"):
|
|
||||||
mnemonic: string
|
|
||||||
password: string
|
|
||||||
name: string
|
|
||||||
color: string
|
|
||||||
emoji: string
|
|
||||||
path: string
|
|
||||||
|
|
||||||
rpc(addAccountWithMnemonicAndPathPasswordVerified, "accounts"):
|
|
||||||
mnemonic: string
|
|
||||||
password: string
|
|
||||||
name: string
|
|
||||||
color: string
|
|
||||||
emoji: string
|
|
||||||
path: string
|
|
||||||
|
|
||||||
rpc(addAccountWithPrivateKey, "accounts"):
|
|
||||||
privateKey: string
|
|
||||||
password: string
|
|
||||||
name: string
|
|
||||||
color: string
|
|
||||||
emoji: string
|
|
||||||
|
|
||||||
rpc(addAccountWithPrivateKeyPasswordVerified, "accounts"):
|
|
||||||
privateKey: string
|
|
||||||
password: string
|
|
||||||
name: string
|
|
||||||
color: string
|
|
||||||
emoji: string
|
|
||||||
|
|
||||||
rpc(addAccountWatch, "accounts"):
|
|
||||||
address: string
|
|
||||||
name: string
|
|
||||||
color: string
|
|
||||||
emoji: string
|
|
||||||
|
|
||||||
rpc(activityCenterNotifications, "wakuext"):
|
rpc(activityCenterNotifications, "wakuext"):
|
||||||
request: ActivityCenterNotificationsRequest
|
request: ActivityCenterNotificationsRequest
|
||||||
|
|
||||||
|
2
vendor/nim-status-go
vendored
2
vendor/nim-status-go
vendored
@ -1 +1 @@
|
|||||||
Subproject commit 73fe79616ce6c7a6e5e79f6425d20cd74b788ffd
|
Subproject commit 534c04dc737f681ef49207e1f183e9fc53647fd5
|
2
vendor/status-go
vendored
2
vendor/status-go
vendored
@ -1 +1 @@
|
|||||||
Subproject commit 8c85a62e108d9c54f6124117cf7a196fb3731732
|
Subproject commit e9482e3974a2f82bd6a23f0c9e861b5bca23f472
|
Loading…
x
Reference in New Issue
Block a user