2018-01-07 06:20:45 +01:00
|
|
|
// Copyright (c) 2014-2018, The Monero Project
|
2016-02-02 22:09:45 +01:00
|
|
|
//
|
|
|
|
// All rights reserved.
|
|
|
|
//
|
|
|
|
// Redistribution and use in source and binary forms, with or without modification, are
|
|
|
|
// permitted provided that the following conditions are met:
|
|
|
|
//
|
|
|
|
// 1. Redistributions of source code must retain the above copyright notice, this list of
|
|
|
|
// conditions and the following disclaimer.
|
|
|
|
//
|
|
|
|
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
|
|
|
// of conditions and the following disclaimer in the documentation and/or other
|
|
|
|
// materials provided with the distribution.
|
|
|
|
//
|
|
|
|
// 3. Neither the name of the copyright holder nor the names of its contributors may be
|
|
|
|
// used to endorse or promote products derived from this software without specific
|
|
|
|
// prior written permission.
|
|
|
|
//
|
|
|
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
|
|
|
|
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
|
|
|
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
|
|
|
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
|
|
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
|
|
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
|
|
|
|
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
|
|
|
import QtQuick 2.2
|
|
|
|
import QtQuick.Dialogs 1.2
|
2016-10-02 20:40:40 +02:00
|
|
|
import moneroComponents.Wallet 1.0
|
2017-01-30 10:37:14 +01:00
|
|
|
import QtQuick.Layouts 1.1
|
2016-08-19 13:44:44 +02:00
|
|
|
import 'utils.js' as Utils
|
2016-02-02 22:09:45 +01:00
|
|
|
|
2017-01-30 10:37:14 +01:00
|
|
|
ColumnLayout {
|
2016-02-02 22:09:45 +01:00
|
|
|
opacity: 0
|
|
|
|
visible: false
|
|
|
|
|
|
|
|
Behavior on opacity {
|
|
|
|
NumberAnimation { duration: 100; easing.type: Easing.InQuad }
|
|
|
|
}
|
|
|
|
|
|
|
|
onOpacityChanged: visible = opacity !== 0
|
|
|
|
|
2016-12-08 15:37:16 +01:00
|
|
|
function onWizardRestarted() {
|
|
|
|
// reset account name field
|
|
|
|
uiItem.accountNameText = defaultAccountName
|
2016-12-17 15:38:43 +01:00
|
|
|
// Empty seedText
|
2017-02-04 12:07:55 +01:00
|
|
|
uiItem.wordsTextItem.memoText = ""
|
|
|
|
uiItem.recoverFromKeysAddress = ""
|
|
|
|
uiItem.recoverFromKeysSpendKey = ""
|
|
|
|
uiItem.recoverFromKeysViewKey = ""
|
2016-12-08 15:37:16 +01:00
|
|
|
}
|
|
|
|
|
2016-07-21 12:56:17 +02:00
|
|
|
function onPageOpened(settingsObject) {
|
2017-01-26 21:54:31 +01:00
|
|
|
console.log("on page opened")
|
|
|
|
uiItem.checkNextButton();
|
2016-07-21 12:56:17 +02:00
|
|
|
}
|
|
|
|
|
2016-06-10 15:41:13 +02:00
|
|
|
function onPageClosed(settingsObject) {
|
2016-02-02 22:09:45 +01:00
|
|
|
settingsObject['account_name'] = uiItem.accountNameText
|
2016-08-19 13:44:44 +02:00
|
|
|
settingsObject['words'] = Utils.lineBreaksToSpaces(uiItem.wordsTextItem.memoText)
|
2016-02-02 22:09:45 +01:00
|
|
|
settingsObject['wallet_path'] = uiItem.walletPath
|
2017-01-26 21:54:31 +01:00
|
|
|
settingsObject['recover_address'] = uiItem.recoverFromKeysAddress
|
|
|
|
settingsObject['recover_viewkey'] = uiItem.recoverFromKeysViewKey
|
|
|
|
settingsObject['recover_spendkey'] = uiItem.recoverFromKeysSpendKey
|
|
|
|
|
|
|
|
|
2016-10-30 21:33:14 +01:00
|
|
|
var restoreHeight = parseInt(uiItem.restoreHeight);
|
|
|
|
settingsObject['restore_height'] = isNaN(restoreHeight)? 0 : restoreHeight
|
2016-10-30 18:07:56 +01:00
|
|
|
var walletFullPath = wizard.createWalletPath(uiItem.walletPath,uiItem.accountNameText);
|
2016-11-29 17:14:11 +01:00
|
|
|
if(!wizard.walletPathValid(walletFullPath)){
|
2016-10-30 18:07:56 +01:00
|
|
|
return false
|
|
|
|
}
|
2017-01-26 21:54:31 +01:00
|
|
|
return recoveryWallet(settingsObject, uiItem.recoverFromSeedMode)
|
2016-02-02 22:09:45 +01:00
|
|
|
}
|
|
|
|
|
2017-01-26 21:54:31 +01:00
|
|
|
function recoveryWallet(settingsObject, fromSeed) {
|
2018-03-05 17:19:45 +01:00
|
|
|
var nettype = appWindow.persistentSettings.nettype;
|
2016-10-10 20:20:50 +02:00
|
|
|
var restoreHeight = settingsObject.restore_height;
|
2017-01-03 21:44:55 +01:00
|
|
|
var tmp_wallet_filename = oshelper.temporaryFilename()
|
|
|
|
console.log("Creating temporary wallet", tmp_wallet_filename)
|
2017-01-26 21:54:31 +01:00
|
|
|
|
2017-08-06 17:29:43 +02:00
|
|
|
// delete the temporary wallet object before creating new
|
|
|
|
if (typeof m_wallet !== 'undefined') {
|
|
|
|
walletManager.closeWallet()
|
|
|
|
console.log("deleting temporary wallet")
|
|
|
|
}
|
|
|
|
|
2017-01-26 21:54:31 +01:00
|
|
|
// From seed or keys
|
|
|
|
if(fromSeed)
|
2018-03-05 17:19:45 +01:00
|
|
|
var wallet = walletManager.recoveryWallet(tmp_wallet_filename, settingsObject.words, nettype, restoreHeight)
|
2017-01-26 21:54:31 +01:00
|
|
|
else
|
2018-03-05 17:19:45 +01:00
|
|
|
var wallet = walletManager.createWalletFromKeys(tmp_wallet_filename, settingsObject.wallet_language, nettype,
|
2017-01-26 21:54:31 +01:00
|
|
|
settingsObject.recover_address, settingsObject.recover_viewkey,
|
|
|
|
settingsObject.recover_spendkey, restoreHeight)
|
|
|
|
|
|
|
|
|
2016-06-14 15:09:14 +02:00
|
|
|
var success = wallet.status === Wallet.Status_Ok;
|
|
|
|
if (success) {
|
2017-08-06 17:11:12 +02:00
|
|
|
m_wallet = wallet;
|
2016-10-10 21:38:30 +02:00
|
|
|
settingsObject['is_recovering'] = true;
|
2017-01-03 21:44:55 +01:00
|
|
|
settingsObject['tmp_wallet_filename'] = tmp_wallet_filename
|
2016-06-14 15:09:14 +02:00
|
|
|
} else {
|
2017-01-29 18:55:57 +01:00
|
|
|
console.log(wallet.errorString)
|
|
|
|
walletErrorDialog.text = wallet.errorString;
|
|
|
|
walletErrorDialog.open();
|
2016-12-04 13:13:59 +01:00
|
|
|
walletManager.closeWallet();
|
2016-06-14 15:09:14 +02:00
|
|
|
}
|
|
|
|
return success;
|
|
|
|
}
|
2016-02-29 15:39:39 +01:00
|
|
|
|
2016-08-19 13:44:44 +02:00
|
|
|
|
2016-02-29 15:39:39 +01:00
|
|
|
|
2016-02-02 22:09:45 +01:00
|
|
|
WizardManageWalletUI {
|
|
|
|
id: uiItem
|
2016-10-29 16:44:13 +02:00
|
|
|
accountNameText: defaultAccountName
|
2017-01-26 21:54:31 +01:00
|
|
|
titleText: qsTr("Restore wallet") + translationManager.emptyString
|
2016-02-06 13:49:31 +01:00
|
|
|
wordsTextItem.clipboardButtonVisible: false
|
|
|
|
wordsTextItem.tipTextVisible: false
|
|
|
|
wordsTextItem.memoTextReadOnly: false
|
|
|
|
wordsTextItem.memoText: ""
|
2017-01-26 21:54:31 +01:00
|
|
|
wordsTextItem.visible: true
|
2016-10-08 01:48:42 +02:00
|
|
|
restoreHeightVisible: true
|
2017-01-26 21:54:31 +01:00
|
|
|
recoverMode: true
|
2016-02-06 17:19:54 +01:00
|
|
|
wordsTextItem.onMemoTextChanged: {
|
2016-07-21 12:56:17 +02:00
|
|
|
checkNextButton();
|
2016-02-06 17:19:54 +01:00
|
|
|
}
|
2016-02-02 22:09:45 +01:00
|
|
|
}
|
2016-12-08 15:37:16 +01:00
|
|
|
|
|
|
|
Component.onCompleted: {
|
|
|
|
parent.wizardRestarted.connect(onWizardRestarted)
|
|
|
|
}
|
2016-02-02 22:09:45 +01:00
|
|
|
}
|