Ask for password in wallet is password protected. closes #26

This commit is contained in:
Ilya Kitaev 2016-08-17 15:14:43 +03:00
parent 6f1343aaa0
commit c1269301f7
7 changed files with 138 additions and 29 deletions

View file

@ -27,6 +27,7 @@
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
import QtQuick 2.0 import QtQuick 2.0
import QtGraphicalEffects 1.0
import "components" import "components"
import "pages" import "pages"
@ -167,5 +168,12 @@ Rectangle {
} }
} }
// indicate disabled state
Desaturate {
anchors.fill: parent
source: parent
desaturation: root.enabled ? 0.0 : 1.0
}
} }

View file

@ -27,6 +27,7 @@
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
import QtQuick 2.2 import QtQuick 2.2
import QtGraphicalEffects 1.0
import "components" import "components"
Rectangle { Rectangle {
@ -355,4 +356,12 @@ Rectangle {
connected: false connected: false
} }
} }
// indicate disabled state
Desaturate {
anchors.fill: parent
source: parent
desaturation: panel.enabled ? 0.0 : 1.0
}
} }

View file

@ -27,8 +27,10 @@
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
import QtQuick 2.2 import QtQuick 2.2
import QtGraphicalEffects 1.0
Rectangle { Rectangle {
id: root
color: "#F0EEEE" color: "#F0EEEE"
signal paymentClicked(string address, string paymentId, double amount, int mixinCount, int priority) signal paymentClicked(string address, string paymentId, double amount, int mixinCount, int priority)
signal generatePaymentIdInvoked() signal generatePaymentIdInvoked()
@ -116,4 +118,11 @@ Rectangle {
height: 1 height: 1
color: "#DBDBDB" color: "#DBDBDB"
} }
// indicate disabled state
Desaturate {
anchors.fill: parent
source: parent
desaturation: root.enabled ? 0.0 : 1.0
}
} }

View file

@ -29,10 +29,13 @@
import QtQuick 2.2 import QtQuick 2.2
import QtQuick.Controls 1.2 import QtQuick.Controls 1.2
import QtQuick.Controls.Styles 1.2 import QtQuick.Controls.Styles 1.2
import QtGraphicalEffects 1.0
import "tabs" import "tabs"
import "components" import "components"
Rectangle { Rectangle {
id: root
width: 330 width: 330
color: "#FFFFFF" color: "#FFFFFF"
@ -145,4 +148,11 @@ Rectangle {
width: 1 width: 1
color: "#DBDBDB" color: "#DBDBDB"
} }
// indicate disabled state
Desaturate {
anchors.fill: parent
source: parent
desaturation: root.enabled ? 0.0 : 1.0
}
} }

View file

@ -1,5 +1,40 @@
import QtQuick 2.0 import QtQuick 2.0
import QtQuick.Controls 1.4
import QtQuick.Dialogs 1.2
import QtQuick.Layouts 1.1
import QtQuick.Controls.Styles 1.4
Item { // import "../components"
Dialog {
id: root
readonly property alias password: passwordInput.text
standardButtons: StandardButton.Ok + StandardButton.Cancel
ColumnLayout {
id: column
height: 40
anchors.fill: parent
Label {
text: qsTr("Please enter wallet password")
Layout.columnSpan: 2
Layout.fillWidth: true
font.family: "Arial"
font.pixelSize: 32
}
TextField {
id : passwordInput
echoMode: TextInput.Password
focus: true
Layout.fillWidth: true
font.family: "Arial"
font.pixelSize: 24
style: TextFieldStyle {
passwordCharacter: "•"
}
}
}
} }

View file

@ -41,7 +41,8 @@ import "wizard"
ApplicationWindow { ApplicationWindow {
id: appWindow id: appWindow
objectName: "appWindow"
property var currentItem property var currentItem
property bool whatIsEnable: false property bool whatIsEnable: false
property bool ctrlPressed: false property bool ctrlPressed: false
@ -50,6 +51,8 @@ ApplicationWindow {
property alias persistentSettings : persistentSettings property alias persistentSettings : persistentSettings
property var wallet; property var wallet;
property var transaction; property var transaction;
property alias password : passwordDialog.password
function altKeyReleased() { ctrlPressed = false; } function altKeyReleased() { ctrlPressed = false; }
@ -98,24 +101,24 @@ ApplicationWindow {
} }
function mousePressed(obj, mouseX, mouseY) { function mousePressed(obj, mouseX, mouseY) {
if(obj.objectName === "appWindow") // if(obj.objectName === "appWindow")
obj = rootItem // obj = rootItem
var tmp = rootItem.mapFromItem(obj, mouseX, mouseY) // var tmp = rootItem.mapFromItem(obj, mouseX, mouseY)
if(tmp !== undefined) { // if(tmp !== undefined) {
mouseX = tmp.x // mouseX = tmp.x
mouseY = tmp.y // mouseY = tmp.y
} // }
if(currentItem !== undefined) { // if(currentItem !== undefined) {
var tmp_x = rootItem.mapToItem(currentItem, mouseX, mouseY).x // var tmp_x = rootItem.mapToItem(currentItem, mouseX, mouseY).x
var tmp_y = rootItem.mapToItem(currentItem, mouseX, mouseY).y // var tmp_y = rootItem.mapToItem(currentItem, mouseX, mouseY).y
if(!currentItem.containsPoint(tmp_x, tmp_y)) { // if(!currentItem.containsPoint(tmp_x, tmp_y)) {
currentItem.hide() // currentItem.hide()
currentItem = undefined // currentItem = undefined
} // }
} // }
} }
function mouseReleased(obj, mouseX, mouseY) { function mouseReleased(obj, mouseX, mouseY) {
@ -142,17 +145,18 @@ ApplicationWindow {
var wallet_path = walletPath(); var wallet_path = walletPath();
console.log("opening wallet at: ", wallet_path); console.log("opening wallet at: ", wallet_path);
// TODO: wallet password dialog wallet = walletManager.openWallet(wallet_path, appWindow.password,
wallet = walletManager.openWallet(wallet_path, "", persistentSettings.testnet); persistentSettings.testnet);
if (wallet.status !== Wallet.Status_Ok) { if (wallet.status !== Wallet.Status_Ok) {
console.error("Error opening wallet with empty password: ", wallet.errorString); console.error("Error opening wallet with empty password: ", wallet.errorString);
console.log("closing wallet...")
walletManager.closeWallet(wallet)
console.log("wallet closed")
// try to open wallet with password; // try to open wallet with password;
passwordDialog.open(); passwordDialog.open();
return; return;
} }
console.log("Wallet opened successfully: ", wallet.errorString); console.log("Wallet opened successfully: ", wallet.errorString);
} }
// subscribing for wallet updates // subscribing for wallet updates
@ -195,6 +199,8 @@ ApplicationWindow {
} }
// called on "transfer" // called on "transfer"
function handlePayment(address, paymentId, amount, mixinCount, priority) { function handlePayment(address, paymentId, amount, mixinCount, priority) {
console.log("Creating transaction: ") console.log("Creating transaction: ")
@ -213,6 +219,7 @@ ApplicationWindow {
informationPopup.title = qsTr("Error") + translationManager.emptyString; informationPopup.title = qsTr("Error") + translationManager.emptyString;
informationPopup.text = qsTr("Can't create transaction: ") + transaction.errorString informationPopup.text = qsTr("Can't create transaction: ") + transaction.errorString
informationPopup.icon = StandardIcon.Critical informationPopup.icon = StandardIcon.Critical
informationPopup.onCloseCallback = null
informationPopup.open(); informationPopup.open();
// deleting transaction object, we don't want memleaks // deleting transaction object, we don't want memleaks
wallet.disposeTransaction(transaction); wallet.disposeTransaction(transaction);
@ -248,13 +255,22 @@ ApplicationWindow {
informationPopup.text = qsTr("Money sent successfully") + translationManager.emptyString informationPopup.text = qsTr("Money sent successfully") + translationManager.emptyString
informationPopup.icon = StandardIcon.Information informationPopup.icon = StandardIcon.Information
} }
informationPopup.onCloseCallback = null
informationPopup.open() informationPopup.open()
wallet.refresh() wallet.refresh()
wallet.disposeTransaction(transaction) wallet.disposeTransaction(transaction)
} }
// blocks UI if wallet can't be opened or no connection to the daemon
function enableUI(enable) {
middlePanel.enabled = enable;
leftPanel.enabled = enable;
rightPanel.enabled = enable;
basicPanel.enabled = enable;
}
objectName: "appWindow"
visible: true visible: true
width: rightPanelExpanded ? 1269 : 1269 - 300 width: rightPanelExpanded ? 1269 : 1269 - 300
height: 800 height: 800
@ -262,6 +278,7 @@ ApplicationWindow {
flags: Qt.FramelessWindowHint | Qt.WindowSystemMenuHint | Qt.Window | Qt.WindowMinimizeButtonHint flags: Qt.FramelessWindowHint | Qt.WindowSystemMenuHint | Qt.Window | Qt.WindowMinimizeButtonHint
onWidthChanged: x -= 0 onWidthChanged: x -= 0
Component.onCompleted: { Component.onCompleted: {
x = (Screen.width - width) / 2 x = (Screen.width - width) / 2
y = (Screen.height - height) / 2 y = (Screen.height - height) / 2
@ -278,6 +295,7 @@ ApplicationWindow {
} }
} }
Settings { Settings {
id: persistentSettings id: persistentSettings
property string language property string language
@ -296,9 +314,15 @@ ApplicationWindow {
// Information dialog // Information dialog
MessageDialog { MessageDialog {
// dynamically change onclose handler
property var onCloseCallback
id: informationPopup id: informationPopup
standardButtons: StandardButton.Ok standardButtons: StandardButton.Ok
onAccepted: {
if (onCloseCallback) {
onCloseCallback()
}
}
} }
// Confrirmation aka question dialog // Confrirmation aka question dialog
@ -317,6 +341,7 @@ ApplicationWindow {
var wallet_path = walletPath(); var wallet_path = walletPath();
console.log("opening wallet with password: ", wallet_path); console.log("opening wallet with password: ", wallet_path);
wallet = walletManager.openWallet(wallet_path, password, persistentSettings.testnet); wallet = walletManager.openWallet(wallet_path, password, persistentSettings.testnet);
if (wallet.status !== Wallet.Status_Ok) { if (wallet.status !== Wallet.Status_Ok) {
console.error("Error opening wallet with password: ", wallet.errorString); console.error("Error opening wallet with password: ", wallet.errorString);
@ -324,9 +349,16 @@ ApplicationWindow {
informationPopup.text = qsTr("Couldn't open wallet: ") + wallet.errorString; informationPopup.text = qsTr("Couldn't open wallet: ") + wallet.errorString;
informationPopup.icon = StandardIcon.Critical informationPopup.icon = StandardIcon.Critical
informationPopup.open() informationPopup.open()
informationPopup.onCloseCallback = appWindow.initialize
walletManager.closeWallet(wallet);
} }
} }
onRejected: {
appWindow.enableUI(false)
}
onDiscard: {
appWindow.enableUI(false)
}
} }
Window { Window {
@ -339,7 +371,6 @@ ApplicationWindow {
anchors.fill: parent anchors.fill: parent
text: qsTr("Initializing Wallet..."); text: qsTr("Initializing Wallet...");
} }
} }

View file

@ -146,6 +146,8 @@ isEmpty(QMAKE_LRELEASE) {
langupd.command = \ langupd.command = \
$$LANGUPD $$LANGUPD_OPTIONS $$shell_path($$_PRO_FILE) -ts $$_PRO_FILE_PWD/$$TRANSLATIONS $$LANGUPD $$LANGUPD_OPTIONS $$shell_path($$_PRO_FILE) -ts $$_PRO_FILE_PWD/$$TRANSLATIONS
langrel.depends = langupd langrel.depends = langupd
langrel.input = TRANSLATIONS langrel.input = TRANSLATIONS
langrel.output = $$TRANSLATION_TARGET_DIR/${QMAKE_FILE_BASE}.qm langrel.output = $$TRANSLATION_TARGET_DIR/${QMAKE_FILE_BASE}.qm
@ -157,7 +159,12 @@ QMAKE_EXTRA_TARGETS += langupd deploy deploy_win
QMAKE_EXTRA_COMPILERS += langrel QMAKE_EXTRA_COMPILERS += langrel
PRE_TARGETDEPS += langupd compiler_langrel_make_all
# temporary: do not update/release translations for "Debug" build,
# as we have an issue with linking
CONFIG(release, debug|release) {
PRE_TARGETDEPS += langupd compiler_langrel_make_all
}
RESOURCES += qml.qrc RESOURCES += qml.qrc
@ -182,8 +189,8 @@ OTHER_FILES += \
$$TRANSLATIONS $$TRANSLATIONS
DISTFILES += \ DISTFILES += \
notes.txt \ notes.txt
components/PasswordDialog.qml
# windows application icon # windows application icon
RC_FILE = monero-core.rc RC_FILE = monero-core.rc