2019-01-14 00:02:44 +00:00
|
|
|
|
.pragma library
|
|
|
|
|
|
|
|
|
|
function updateFromQrCode(address, payment_id, amount, tx_description, recipient_name, extra_parameters) {
|
|
|
|
|
// Switch to recover from keys
|
|
|
|
|
recoverFromSeedMode = false
|
2019-02-23 02:26:51 +00:00
|
|
|
|
spendKeyLine.text = ""
|
2019-01-14 00:02:44 +00:00
|
|
|
|
viewKeyLine.text = ""
|
2019-02-23 02:26:51 +00:00
|
|
|
|
restoreHeight.text = ""
|
2019-01-14 00:02:44 +00:00
|
|
|
|
|
|
|
|
|
if(typeof extra_parameters.secret_view_key != "undefined") {
|
|
|
|
|
viewKeyLine.text = extra_parameters.secret_view_key
|
|
|
|
|
}
|
|
|
|
|
if(typeof extra_parameters.secret_spend_key != "undefined") {
|
2019-02-23 02:26:51 +00:00
|
|
|
|
spendKeyLine.text = extra_parameters.secret_spend_key
|
2019-01-14 00:02:44 +00:00
|
|
|
|
}
|
|
|
|
|
if(typeof extra_parameters.restore_height != "undefined") {
|
2019-02-23 02:26:51 +00:00
|
|
|
|
restoreHeight.text = extra_parameters.restore_height
|
2019-01-14 00:02:44 +00:00
|
|
|
|
}
|
|
|
|
|
addressLine.text = address
|
|
|
|
|
|
|
|
|
|
cameraUi.qrcode_decoded.disconnect(updateFromQrCode)
|
|
|
|
|
|
|
|
|
|
// Check if keys are correct
|
|
|
|
|
checkNextButton();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function switchPage(next) {
|
|
|
|
|
// Android focus workaround
|
|
|
|
|
releaseFocus();
|
|
|
|
|
|
|
|
|
|
// save settings for current page;
|
|
|
|
|
if (next && typeof pages[currentPage].onPageClosed !== 'undefined') {
|
|
|
|
|
if (pages[currentPage].onPageClosed(settings) !== true) {
|
|
|
|
|
print ("Can't go to the next page");
|
|
|
|
|
return;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
console.log("switchpage: currentPage: ", currentPage);
|
|
|
|
|
|
|
|
|
|
// Update prev/next button positions for mobile/desktop
|
2019-09-05 22:11:12 +00:00
|
|
|
|
prevButton.anchors.verticalCenter = wizard.verticalCenter
|
|
|
|
|
nextButton.anchors.verticalCenter = wizard.verticalCenter
|
2019-01-14 00:02:44 +00:00
|
|
|
|
|
|
|
|
|
if (currentPage > 0 || currentPage < pages.length - 1) {
|
|
|
|
|
pages[currentPage].opacity = 0
|
|
|
|
|
var step_value = next ? 1 : -1
|
|
|
|
|
currentPage += step_value
|
|
|
|
|
pages[currentPage].opacity = 1;
|
|
|
|
|
|
|
|
|
|
var nextButtonVisible = currentPage > 1 && currentPage < pages.length - 1
|
|
|
|
|
nextButton.visible = nextButtonVisible
|
|
|
|
|
|
|
|
|
|
if (typeof pages[currentPage].onPageOpened !== 'undefined') {
|
|
|
|
|
pages[currentPage].onPageOpened(settings,next)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function createWalletPath(isIOS, folder_path,account_name){
|
|
|
|
|
// Store releative path on ios.
|
|
|
|
|
if(isIOS)
|
|
|
|
|
folder_path = "";
|
|
|
|
|
|
|
|
|
|
return folder_path + "/" + account_name + "/" + account_name
|
|
|
|
|
}
|
|
|
|
|
|
2020-07-28 17:42:59 +00:00
|
|
|
|
function walletPathExists(accountsDir, directory, filename, isIOS, walletManager) {
|
2019-01-14 00:02:44 +00:00
|
|
|
|
if(!filename || filename === "") return false;
|
|
|
|
|
if(!directory || directory === "") return false;
|
|
|
|
|
|
2021-04-14 18:41:46 +00:00
|
|
|
|
if (!directory.endsWith("/") && !directory.endsWith("\\"))
|
2019-01-14 00:02:44 +00:00
|
|
|
|
directory += "/"
|
|
|
|
|
|
|
|
|
|
if(isIOS)
|
2020-07-28 17:42:59 +00:00
|
|
|
|
var path = accountsDir + filename;
|
2019-01-14 00:02:44 +00:00
|
|
|
|
else
|
|
|
|
|
var path = directory + filename + "/" + filename;
|
2023-02-08 23:39:10 +00:00
|
|
|
|
var path2 = directory + filename;
|
2019-01-14 00:02:44 +00:00
|
|
|
|
|
2023-02-08 23:39:10 +00:00
|
|
|
|
if (walletManager.walletExists(path) || walletManager.walletExists(path2))
|
2019-01-14 00:02:44 +00:00
|
|
|
|
return true;
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-08 23:00:16 +00:00
|
|
|
|
function unusedWalletName(directory, filename, walletManager) {
|
|
|
|
|
for (var i = 0; i < 100; i++) {
|
|
|
|
|
var walletName = filename + (i > 0 ? "_" + i : "");
|
|
|
|
|
if (!walletManager.walletExists(directory + "/" + walletName + "/" + walletName)) {
|
|
|
|
|
return walletName;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return filename;
|
|
|
|
|
}
|
|
|
|
|
|
2019-01-14 00:02:44 +00:00
|
|
|
|
function isAscii(str){
|
|
|
|
|
for (var i = 0; i < str.length; i++) {
|
|
|
|
|
if (str.charCodeAt(i) > 127)
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function tr(text) {
|
|
|
|
|
return qsTr(text) + translationManager.emptyString
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function usefulName(path) {
|
|
|
|
|
// arbitrary "short enough" limit
|
|
|
|
|
if (path.length < 32)
|
|
|
|
|
return path
|
|
|
|
|
return path.replace(/.*[\/\\]/, '').replace(/\.keys$/, '')
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function checkSeed(seed) {
|
|
|
|
|
console.log("Checking seed")
|
2020-05-11 13:27:07 +00:00
|
|
|
|
var wordsArray = seed.split(/\s+/);
|
2019-01-14 00:02:44 +00:00
|
|
|
|
return wordsArray.length === 25 || wordsArray.length === 24
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function restoreWalletCheckViewSpendAddress(walletmanager, nettype, viewkey, spendkey, addressline){
|
2019-02-23 02:26:51 +00:00
|
|
|
|
var results = [];
|
|
|
|
|
// addressOK
|
|
|
|
|
results[0] = walletmanager.addressValid(addressline, nettype);
|
|
|
|
|
// viewKeyOK
|
|
|
|
|
results[1] = walletmanager.keyValid(viewkey, addressline, true, nettype);
|
|
|
|
|
// spendKeyOK, Spendkey is optional
|
|
|
|
|
results[2] = walletmanager.keyValid(spendkey, addressline, false, nettype);
|
|
|
|
|
return results;
|
2019-01-14 00:02:44 +00:00
|
|
|
|
}
|
2018-12-15 01:28:07 +00:00
|
|
|
|
|
|
|
|
|
//usage: getApproximateBlockchainHeight("March 18 2016") or getApproximateBlockchainHeight("2016-11-11")
|
|
|
|
|
//returns estimated block height with 1 month buffer prior to requested date.
|
2019-05-15 03:21:09 +00:00
|
|
|
|
function getApproximateBlockchainHeight(_date, _nettype){
|
2018-12-15 01:28:07 +00:00
|
|
|
|
// time of monero birth 2014-04-18 10:49:53 (1397818193)
|
2019-05-15 03:21:09 +00:00
|
|
|
|
var moneroBirthTime = _nettype == "Mainnet" ? 1397818193 : _nettype == "Testnet" ? 1410295020 : 1518932025;
|
2018-12-15 01:28:07 +00:00
|
|
|
|
// avg seconds per block in v1
|
|
|
|
|
var secondsPerBlockV1 = 60;
|
|
|
|
|
// time of v2 fork 2016-03-23 15:57:38 (1458748658)
|
2019-05-15 03:21:09 +00:00
|
|
|
|
var forkTime = _nettype == "Mainnet" ? 1458748658 : _nettype == "Testnet" ? 1448285909 : 1520937818;
|
2018-12-15 01:28:07 +00:00
|
|
|
|
// v2 fork block
|
2019-05-15 03:21:09 +00:00
|
|
|
|
var forkBlock = _nettype == "Mainnet" ? 1009827 : _nettype == "Testnet" ? 624634 : 32000;
|
2018-12-15 01:28:07 +00:00
|
|
|
|
// avg seconds per block in V2
|
|
|
|
|
var secondsPerBlockV2 = 120;
|
|
|
|
|
// time in UTC
|
|
|
|
|
var requestedTime = Math.floor(new Date(_date) / 1000);
|
|
|
|
|
var approxBlockchainHeight;
|
|
|
|
|
var secondsPerBlock;
|
|
|
|
|
// before monero's birth
|
|
|
|
|
if (requestedTime < moneroBirthTime){
|
|
|
|
|
console.log("Calculated blockchain height: 0, requestedTime < moneroBirthTime " );
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
// time between during v1
|
|
|
|
|
if (requestedTime > moneroBirthTime && requestedTime < forkTime){
|
|
|
|
|
approxBlockchainHeight = Math.floor((requestedTime - moneroBirthTime)/secondsPerBlockV1);
|
|
|
|
|
console.log("Calculated blockchain height: " + approxBlockchainHeight );
|
|
|
|
|
secondsPerBlock = secondsPerBlockV1;
|
|
|
|
|
}
|
|
|
|
|
// time is during V2
|
|
|
|
|
else{
|
|
|
|
|
approxBlockchainHeight = Math.floor(forkBlock + (requestedTime - forkTime)/secondsPerBlockV2);
|
|
|
|
|
console.log("Calculated blockchain height: " + approxBlockchainHeight );
|
|
|
|
|
secondsPerBlock = secondsPerBlockV2;
|
|
|
|
|
}
|
2019-05-15 03:21:09 +00:00
|
|
|
|
|
2022-02-28 23:18:09 +00:00
|
|
|
|
if(_nettype == "Testnet" || _nettype == "Stagenet"){
|
2019-05-15 03:21:09 +00:00
|
|
|
|
// testnet got some huge rollbacks, so the estimation is way off
|
2022-02-28 23:18:09 +00:00
|
|
|
|
var approximateTestnetRolledBackBlocks = _nettype == "Testnet" ? 342100 : 30000;
|
2019-05-15 03:21:09 +00:00
|
|
|
|
if(approxBlockchainHeight > approximateTestnetRolledBackBlocks)
|
|
|
|
|
approxBlockchainHeight -= approximateTestnetRolledBackBlocks
|
|
|
|
|
}
|
|
|
|
|
|
2018-12-15 01:28:07 +00:00
|
|
|
|
var blocksPerMonth = 60*60*24*30/secondsPerBlock;
|
|
|
|
|
if(approxBlockchainHeight - blocksPerMonth > 0){
|
|
|
|
|
return approxBlockchainHeight - blocksPerMonth;
|
|
|
|
|
}
|
|
|
|
|
else{
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
2019-02-23 02:26:51 +00:00
|
|
|
|
}
|