Browse Source

Sticky Server and Note Automation as GUI setting

pull/145/head
lucretius 4 months ago
parent
commit
6f7fd863f0
  1. 2
      lib/Cargo.lock
  2. 2
      lib/Cargo.toml
  3. 17
      src/controller.cpp
  4. 15
      src/mainwindow.cpp
  5. 4
      src/sendtab.cpp
  6. 17
      src/settings.cpp
  7. 6
      src/settings.h
  8. 63
      src/settings.ui

2
lib/Cargo.lock

@ -1849,7 +1849,7 @@ dependencies = [
[[package]] [[package]]
name = "silentdragonlitelib" name = "silentdragonlitelib"
version = "0.1.0" version = "0.1.0"
source = "git+https://git.hush.is/hush/silentdragonlite-cli?rev=568d7b7860ec0b848cb84474f38b25bed890de09#568d7b7860ec0b848cb84474f38b25bed890de09" source = "git+https://git.hush.is/hush/silentdragonlite-cli?rev=1334c89e0f4ddd23725020e16753d0ea95c09bf5#1334c89e0f4ddd23725020e16753d0ea95c09bf5"
dependencies = [ dependencies = [
"base58", "base58",
"bellman", "bellman",

2
lib/Cargo.toml

@ -12,4 +12,4 @@ crate-type = ["staticlib"]
libc = "0.2.58" libc = "0.2.58"
lazy_static = "1.4.0" lazy_static = "1.4.0"
blake3 = "0.3.4" blake3 = "0.3.4"
silentdragonlitelib = { git = "https://git.hush.is/hush/silentdragonlite-cli", rev = "568d7b7860ec0b848cb84474f38b25bed890de09" } silentdragonlitelib = { git = "https://git.hush.is/hush/silentdragonlite-cli", rev = "1334c89e0f4ddd23725020e16753d0ea95c09bf5" }

17
src/controller.cpp

@ -35,8 +35,11 @@ Controller::Controller(MainWindow* main)
auto current_server = Settings::getInstance()->getSettings().server; auto current_server = Settings::getInstance()->getSettings().server;
main->ui->current_server->setText(current_server); main->ui->current_server->setText(current_server);
auto stickyServer = Settings::getInstance()->getSettings().stickyServer; bool isStickyServerEnabled = Settings::getInstance()->getUseStickyServer();
main->ui->sticky_server->setText( stickyServer ? "True" : "False" ); qDebug() << "Sticky Server Status senden" << isStickyServerEnabled;
main->ui->sticky_server->setText( isStickyServerEnabled ? "True" : "False" );
//auto stickyServer = Settings::getInstance()->getSettings().stickyServer;
// Setup balances table model // Setup balances table model
balancesTableModel = new BalancesTableModel(main->ui->balancesTable); balancesTableModel = new BalancesTableModel(main->ui->balancesTable);
@ -166,8 +169,6 @@ void Controller::fillTxJsonParams(json& allRecepients, Tx tx)
// Only for Debugging/Testing: How many free Notes are available? // Only for Debugging/Testing: How many free Notes are available?
int spendableNotesCount = NoteCountDataStore::getInstance()->getSpendableNotesCount(); int spendableNotesCount = NoteCountDataStore::getInstance()->getSpendableNotesCount();
QString addressWithMaxValue = NoteCountDataStore::getInstance()->getAddressWithMaxValue(); QString addressWithMaxValue = NoteCountDataStore::getInstance()->getAddressWithMaxValue();
qDebug() << "Available notes over fee:" << spendableNotesCount;
// Clear NoteCountDataStore // Clear NoteCountDataStore
DataStore::getNoteCountDataStore()->clear(); DataStore::getNoteCountDataStore()->clear();
@ -191,8 +192,12 @@ void Controller::fillTxJsonParams(json& allRecepients, Tx tx)
} }
CAmount balanceAvailable = getModel()->getBalVerified(); CAmount balanceAvailable = getModel()->getBalVerified();
// Create more Notes if spendableNotesCount < 30 and enough funds are available bool isNoteAutomationEnabled = Settings::getInstance()->getUseNoteAutomation();
if (spendableNotesCount < 30 && balanceAvailable.toDecimalString().toDouble() > (dustTransactions.size() * 0.0001)) { // Create more Notes if spendableNotesCount < 30 and enough funds are available and note automation is checked in settings tab
if (spendableNotesCount < 30 &&
balanceAvailable.toDecimalString().toDouble() > (dustTransactions.size() * 0.0001) &&
isNoteAutomationEnabled) {
// Create extra transaction // Create extra transaction
for (size_t i = 0; i < dustTransactions.size(); ++i) { for (size_t i = 0; i < dustTransactions.size(); ++i) {
// Generate random memo // Generate random memo

15
src/mainwindow.cpp

@ -838,7 +838,13 @@ void MainWindow::setupSettingsModal() {
// Fetch prices // Fetch prices
settings.chkFetchPrices->setChecked(Settings::getInstance()->getAllowFetchPrices()); settings.chkFetchPrices->setChecked(Settings::getInstance()->getAllowFetchPrices());
// Check Status of StickyServer
settings.chkUseStickyServer->setChecked(Settings::getInstance()->getUseStickyServer());
// Check Status of Note Automation
settings.chkUseNoteAutomation->setChecked(Settings::getInstance()->getUseNoteAutomation())
// List of default servers // List of default servers
settings.cmbServer->addItem("https://lite.hush.is"); settings.cmbServer->addItem("https://lite.hush.is");
settings.cmbServer->addItem("https://lite.hush.land"); settings.cmbServer->addItem("https://lite.hush.land");
@ -867,6 +873,13 @@ void MainWindow::setupSettingsModal() {
// Allow fetching prices // Allow fetching prices
Settings::getInstance()->setAllowFetchPrices(settings.chkFetchPrices->isChecked()); Settings::getInstance()->setAllowFetchPrices(settings.chkFetchPrices->isChecked());
// Set State for Use Sticky Server
Settings::getInstance()->setUseStickyServer(settings.chkUseStickyServer->isChecked());
// Set State for Use Note Automation
Settings::getInstance()->setUseNoteAutomation(settings.chkUseNoteAutomation->isChecked());
// Save the server // Save the server
bool reloadConnection = false; bool reloadConnection = false;
if (conf.server != settings.cmbServer->currentText().trimmed()) { if (conf.server != settings.cmbServer->currentText().trimmed()) {

4
src/sendtab.cpp

@ -881,8 +881,8 @@ void MainWindow::sendButton() {
ui->tabWidget->setCurrentIndex(0); ui->tabWidget->setCurrentIndex(0);
}); });
auto stickyServer = Settings::getInstance()->getSettings().stickyServer; bool isStickyServerEnabled = Settings::getInstance()->getUseStickyServer();
if(stickyServer) { if(isStickyServerEnabled) {
qDebug() << "Not changing servers because stickyServer=1"; qDebug() << "Not changing servers because stickyServer=1";
} else { } else {
// After each transaction, change servers to spread out // After each transaction, change servers to spread out

17
src/settings.cpp

@ -139,6 +139,7 @@ double Settings::getHUSHPrice() {
double Settings::getEURPrice() { double Settings::getEURPrice() {
return EURPrice; return EURPrice;
} }
double Settings::getBTCPrice() { double Settings::getBTCPrice() {
return BTCPrice; return BTCPrice;
} }
@ -250,6 +251,22 @@ void Settings::setAllowFetchPrices(bool allow) {
QSettings().setValue("options/allowfetchprices", allow); QSettings().setValue("options/allowfetchprices", allow);
} }
bool Settings::getUseStickyServer() {
return QSettings().value("connection/stickyServer", false).toBool();
}
void Settings::setUseStickyServer(bool allow) {
QSettings().setValue("connection/stickyServer", allow);
}
bool Settings::getUseNoteAutomation() {
return QSettings().value("options/useNoteAutomation", true).toBool();
}
void Settings::setUseNoteAutomation(bool allow) {
QSettings().setValue("options/useNoteAutomation", allow);
}
QString Settings::get_currency_name() { QString Settings::get_currency_name() {
// Load from the QT Settings. // Load from the QT Settings.
return QSettings().value("options/currency_name", false).toString(); return QSettings().value("options/currency_name", false).toString();

6
src/settings.h

@ -66,6 +66,12 @@ public:
bool getCheckForUpdates(); bool getCheckForUpdates();
void setCheckForUpdates(bool allow); void setCheckForUpdates(bool allow);
bool getUseStickyServer();
void setUseStickyServer(bool allow);
bool getUseNoteAutomation();
void setUseNoteAutomation(bool allow);
QString get_theme_name(); QString get_theme_name();
void set_theme_name(QString theme_name); void set_theme_name(QString theme_name);

63
src/settings.ui

@ -38,7 +38,7 @@
<item> <item>
<widget class="QTabWidget" name="tabWidget"> <widget class="QTabWidget" name="tabWidget">
<property name="currentIndex"> <property name="currentIndex">
<number>1</number> <number>0</number>
</property> </property>
<widget class="QWidget" name="tab"> <widget class="QWidget" name="tab">
<attribute name="title"> <attribute name="title">
@ -79,6 +79,20 @@
</item> </item>
</layout> </layout>
</item> </item>
<item>
<widget class="QCheckBox" name="chkUseStickyServer">
<property name="text">
<string>Use Sticky Server</string>
</property>
</widget>
</item>
<item>
<widget class="QLabel" name="label_13">
<property name="text">
<string>Uses a fixed server instead of random </string>
</property>
</widget>
</item>
<item> <item>
<spacer name="verticalSpacer"> <spacer name="verticalSpacer">
<property name="orientation"> <property name="orientation">
@ -87,7 +101,7 @@
<property name="sizeHint" stdset="0"> <property name="sizeHint" stdset="0">
<size> <size>
<width>20</width> <width>20</width>
<height>40</height> <height>20</height>
</size> </size>
</property> </property>
</spacer> </spacer>
@ -102,7 +116,7 @@
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>80</x> <x>80</x>
<y>110</y> <y>190</y>
<width>111</width> <width>111</width>
<height>25</height> <height>25</height>
</rect> </rect>
@ -178,11 +192,27 @@
<string>Connect to git on startup to check for updates</string> <string>Connect to git on startup to check for updates</string>
</property> </property>
</widget> </widget>
<widget class="QCheckBox" name="chkUseNoteAutomation">
<property name="geometry">
<rect>
<x>10</x>
<y>110</y>
<width>200</width>
<height>23</height>
</rect>
</property>
<property name="text">
<string>Use Note Automation</string>
</property>
<property name="checked">
<bool>true</bool>
</property>
</widget>
<widget class="QLabel" name="label_20"> <widget class="QLabel" name="label_20">
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>9</x> <x>10</x>
<y>113</y> <y>190</y>
<width>47</width> <width>47</width>
<height>17</height> <height>17</height>
</rect> </rect>
@ -203,8 +233,8 @@
<widget class="Line" name="line_2"> <widget class="Line" name="line_2">
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>10</x> <x>0</x>
<y>180</y> <y>300</y>
<width>691</width> <width>691</width>
<height>16</height> <height>16</height>
</rect> </rect>
@ -222,7 +252,7 @@
<widget class="QLabel" name="label_10"> <widget class="QLabel" name="label_10">
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>9</x> <x>10</x>
<y>90</y> <y>90</y>
<width>601</width> <width>601</width>
<height>17</height> <height>17</height>
@ -236,7 +266,7 @@
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>10</x> <x>10</x>
<y>150</y> <y>230</y>
<width>61</width> <width>61</width>
<height>20</height> <height>20</height>
</rect> </rect>
@ -258,7 +288,7 @@
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>80</x> <x>80</x>
<y>150</y> <y>230</y>
<width>111</width> <width>111</width>
<height>25</height> <height>25</height>
</rect> </rect>
@ -320,6 +350,19 @@
</property> </property>
</item> </item>
</widget> </widget>
<widget class="QLabel" name="label_11">
<property name="geometry">
<rect>
<x>10</x>
<y>140</y>
<width>601</width>
<height>17</height>
</rect>
</property>
<property name="text">
<string>Increases the number of zutxo for instant hushchat</string>
</property>
</widget>
</widget> </widget>
</widget> </widget>
</item> </item>

Loading…
Cancel
Save