create message boxes for saving editing autotypes statements, fix multiple messages problem on autotype execution

You now get an error when you try to save incorrect autotype statements and warnings if you have high delays or much repetiton in your statement.

Also you will now only get one warning if you want to perfom high delayed or often repeated statements.
This commit is contained in:
Marco 2017-05-15 21:06:14 +02:00 committed by thez3ro
parent 7bb9ea201c
commit fbfc2e4d07
No known key found for this signature in database
GPG Key ID: F628F9E41DD7C073
2 changed files with 56 additions and 33 deletions

View File

@ -21,6 +21,7 @@
#include <QApplication> #include <QApplication>
#include <QPluginLoader> #include <QPluginLoader>
#include <iostream> #include <iostream>
#include <QtWidgets/QErrorMessage>
#include "config-keepassx.h" #include "config-keepassx.h"
@ -328,8 +329,33 @@ bool AutoType::parseActions(const QString& sequence, const Entry* entry, QList<A
m_autoTypeDelay = config()->get("AutoTypeDelay").toInt(); m_autoTypeDelay = config()->get("AutoTypeDelay").toInt();
if (!AutoType::checkSyntax(sequence)) {
QMessageBox messageBox;
messageBox.critical(0, "AutoType", tr("The Syntax of your AutoType statement is incorrect!"));
return false;
}
else if (AutoType::checkHighDelay(sequence)) {
QMessageBox::StandardButton reply;
reply = QMessageBox::question(0,
"AutoType",
tr("This AutoType command contains a very long delay. Do you really want to execute it?"));
if (reply == QMessageBox::No) {
return false;
}
}
else if (AutoType::checkHighRepetition(sequence)) {
QMessageBox::StandardButton reply;
reply = QMessageBox::question(0,
"AutoType",
tr("This AutoType command contains arguments which are repeated very often. Do you really want to execute it?"));
if (reply == QMessageBox::No) {
return false;
}
}
for (const QChar &ch : sequence) { for (const QChar &ch : sequence) {
if (inTmpl) {
if (ch == '{') { if (ch == '{') {
qWarning("Syntax error in auto-type sequence."); qWarning("Syntax error in auto-type sequence.");
return false; return false;
@ -391,30 +417,6 @@ QList<AutoTypeAction*> AutoType::createActionFromTemplate(const QString& tmpl, c
if (num == 0) { if (num == 0) {
return list; return list;
} }
// some safety checks
else if (tmplName.compare("delay",Qt::CaseInsensitive)==0) {
if (num > 10000) {
QMessageBox::StandardButton reply;
reply = QMessageBox::question(0,
"AutoType",
tr("This AutoType command contains a very long delay. Do you really want to execute it?"));
if (reply == QMessageBox::No) {
return list;
}
}
}
else if (num > 100) {
QMessageBox::StandardButton reply;
reply = QMessageBox::question(0,
"AutoType",
tr("This AutoType command contains arguments which are repeated very often. Do you really want to execute it?"));
if (reply == QMessageBox::No) {
return list;
}
}
} }
if (tmplName.compare("tab", Qt::CaseInsensitive) == 0) { if (tmplName.compare("tab", Qt::CaseInsensitive) == 0) {

View File

@ -767,19 +767,40 @@ void EditEntryWidget::updateEntryData(Entry* entry) const
} }
else { else {
if (!AutoType::checkSyntax(m_autoTypeUi->sequenceEdit->text())) { if (!AutoType::checkSyntax(m_autoTypeUi->sequenceEdit->text())) {
//@TODO handle wrong syntax //handle wrong syntax
std::cout << "wrong syntax\n"; QMessageBox messageBox;
messageBox.critical(0,
"AutoType",
tr("The Syntax of your AutoType statement is incorrect! It won't be saved!"));
} }
else if (AutoType::checkHighDelay(m_autoTypeUi->sequenceEdit->text())) { else if (AutoType::checkHighDelay(m_autoTypeUi->sequenceEdit->text())) {
//@TODO handle too long delay //handle too long delay
std::cout << "too long delay\n"; QMessageBox::StandardButton reply;
reply = QMessageBox::question(0,
"AutoType",
tr("This AutoType command contains a very long delay. Do you really want to save it?"));
if (reply == QMessageBox::Yes) {
entry->setDefaultAutoTypeSequence(m_autoTypeUi->sequenceEdit->text());
}
} }
else if (AutoType::checkHighRepetition(m_autoTypeUi->sequenceEdit->text())) { else if (AutoType::checkHighRepetition(m_autoTypeUi->sequenceEdit->text())) {
//@TODO handle too much repetition //handle too much repetition
std::cout << "too much repetition\n"; QMessageBox::StandardButton reply;
} reply = QMessageBox::question(0,
"AutoType",
tr("This AutoType command contains arguments which are repeated very often. Do you really want to save it?"));
if (reply == QMessageBox::Yes) {
entry->setDefaultAutoTypeSequence(m_autoTypeUi->sequenceEdit->text()); entry->setDefaultAutoTypeSequence(m_autoTypeUi->sequenceEdit->text());
} }
}
else {
entry->setDefaultAutoTypeSequence(m_autoTypeUi->sequenceEdit->text());
}
}
entry->autoTypeAssociations()->copyDataFrom(m_autoTypeAssoc); entry->autoTypeAssociations()->copyDataFrom(m_autoTypeAssoc);
} }