mirror of
https://github.com/monero-project/monero-gui.git
synced 2025-01-03 17:39:54 +00:00
Merge pull request #226
abd5c68
Windows: don't allow non-ascii characters in path (Jaquee)1a610db
add isWindows property (Jaquee)
This commit is contained in:
commit
0c484ea424
4 changed files with 29 additions and 10 deletions
4
main.cpp
4
main.cpp
|
@ -118,12 +118,14 @@ int main(int argc, char *argv[])
|
||||||
// to save the wallet file (.keys, .bin), they have to be user-accessible for
|
// to save the wallet file (.keys, .bin), they have to be user-accessible for
|
||||||
// backups - I reckon we save that in My Documents\Monero Accounts\ on
|
// backups - I reckon we save that in My Documents\Monero Accounts\ on
|
||||||
// Windows, ~/Monero Accounts/ on nix / osx
|
// Windows, ~/Monero Accounts/ on nix / osx
|
||||||
|
bool isWindows = false;
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
|
isWindows = true;
|
||||||
QStringList moneroAccountsRootDir = QStandardPaths::standardLocations(QStandardPaths::DocumentsLocation);
|
QStringList moneroAccountsRootDir = QStandardPaths::standardLocations(QStandardPaths::DocumentsLocation);
|
||||||
#elif defined(Q_OS_UNIX)
|
#elif defined(Q_OS_UNIX)
|
||||||
QStringList moneroAccountsRootDir = QStandardPaths::standardLocations(QStandardPaths::HomeLocation);
|
QStringList moneroAccountsRootDir = QStandardPaths::standardLocations(QStandardPaths::HomeLocation);
|
||||||
#endif
|
#endif
|
||||||
|
engine.rootContext()->setContextProperty("isWindows", isWindows);
|
||||||
|
|
||||||
if (!moneroAccountsRootDir.empty()) {
|
if (!moneroAccountsRootDir.empty()) {
|
||||||
QString moneroAccountsDir = moneroAccountsRootDir.at(0) + "/Monero/wallets";
|
QString moneroAccountsDir = moneroAccountsRootDir.at(0) + "/Monero/wallets";
|
||||||
|
|
|
@ -55,7 +55,7 @@ Item {
|
||||||
settingsObject['words'] = uiItem.wordsTexttext
|
settingsObject['words'] = uiItem.wordsTexttext
|
||||||
settingsObject['wallet_path'] = uiItem.walletPath
|
settingsObject['wallet_path'] = uiItem.walletPath
|
||||||
var walletFullPath = wizard.createWalletPath(uiItem.walletPath,uiItem.accountNameText);
|
var walletFullPath = wizard.createWalletPath(uiItem.walletPath,uiItem.accountNameText);
|
||||||
return !wizard.walletExists(walletFullPath);
|
return wizard.walletPathValid(walletFullPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
function checkNextButton() {
|
function checkNextButton() {
|
||||||
|
|
|
@ -141,12 +141,30 @@ Rectangle {
|
||||||
return folder_path + "/" + account_name + "/" + account_name
|
return folder_path + "/" + account_name + "/" + account_name
|
||||||
}
|
}
|
||||||
|
|
||||||
function walletExists(path){
|
function walletPathValid(path){
|
||||||
if(walletManager.walletExists(path)){
|
if (walletManager.walletExists(path)) {
|
||||||
walletExistsErrorDialog.open();
|
walletErrorDialog.text = qsTr("A wallet with same name already exists. Please change wallet name") + translationManager.emptyString;
|
||||||
return true;
|
walletErrorDialog.open();
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
return false;
|
|
||||||
|
// Don't allow non ascii characters in path on windows platforms until supported by Wallet2
|
||||||
|
if (isWindows) {
|
||||||
|
if (!isAscii(path)) {
|
||||||
|
walletErrorDialog.text = qsTr("Non-ASCII characters are not allowed in wallet path or account name") + translationManager.emptyString;
|
||||||
|
walletErrorDialog.open();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
function isAscii(str){
|
||||||
|
for (var i = 0; i < str.length; i++) {
|
||||||
|
if (str.charCodeAt(i) > 127)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
//! actually writes the wallet
|
//! actually writes the wallet
|
||||||
|
@ -197,9 +215,8 @@ Rectangle {
|
||||||
}
|
}
|
||||||
|
|
||||||
MessageDialog {
|
MessageDialog {
|
||||||
id: walletExistsErrorDialog
|
id: walletErrorDialog
|
||||||
title: "Error"
|
title: "Error"
|
||||||
text: qsTr("A wallet with same name already exists. Please change wallet name") + translationManager.emptyString
|
|
||||||
onAccepted: {
|
onAccepted: {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -59,7 +59,7 @@ Item {
|
||||||
var restoreHeight = parseInt(uiItem.restoreHeight);
|
var restoreHeight = parseInt(uiItem.restoreHeight);
|
||||||
settingsObject['restore_height'] = isNaN(restoreHeight)? 0 : restoreHeight
|
settingsObject['restore_height'] = isNaN(restoreHeight)? 0 : restoreHeight
|
||||||
var walletFullPath = wizard.createWalletPath(uiItem.walletPath,uiItem.accountNameText);
|
var walletFullPath = wizard.createWalletPath(uiItem.walletPath,uiItem.accountNameText);
|
||||||
if(wizard.walletExists(walletFullPath)){
|
if(!wizard.walletPathValid(walletFullPath)){
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
return recoveryWallet(settingsObject)
|
return recoveryWallet(settingsObject)
|
||||||
|
|
Loading…
Reference in a new issue