mirror of
https://github.com/monero-project/monero-gui.git
synced 2025-01-10 04:45:00 +00:00
Bootstrap daemon (requires #3165)
This commit is contained in:
parent
af882e87f5
commit
fd1f4bf628
5 changed files with 46 additions and 3 deletions
3
main.qml
3
main.qml
|
@ -478,7 +478,7 @@ ApplicationWindow {
|
||||||
currentWallet.pauseRefresh();
|
currentWallet.pauseRefresh();
|
||||||
|
|
||||||
appWindow.showProcessingSplash(qsTr("Waiting for daemon to start..."))
|
appWindow.showProcessingSplash(qsTr("Waiting for daemon to start..."))
|
||||||
daemonManager.start(flags, persistentSettings.testnet, persistentSettings.blockchainDataDir);
|
daemonManager.start(flags, persistentSettings.testnet, persistentSettings.blockchainDataDir, persistentSettings.bootstrapNodeAddress);
|
||||||
persistentSettings.daemonFlags = flags
|
persistentSettings.daemonFlags = flags
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1006,6 +1006,7 @@ ApplicationWindow {
|
||||||
property string blockchainDataDir: ""
|
property string blockchainDataDir: ""
|
||||||
property bool useRemoteNode: false
|
property bool useRemoteNode: false
|
||||||
property string remoteNodeAddress: ""
|
property string remoteNodeAddress: ""
|
||||||
|
property string bootstrapNodeAddress: ""
|
||||||
}
|
}
|
||||||
|
|
||||||
// Information dialog
|
// Information dialog
|
||||||
|
|
|
@ -260,6 +260,9 @@ Rectangle {
|
||||||
releasedColor: "#FF6C3C"
|
releasedColor: "#FF6C3C"
|
||||||
pressedColor: "#FF4304"
|
pressedColor: "#FF4304"
|
||||||
onClicked: {
|
onClicked: {
|
||||||
|
// Update bootstrap daemon address
|
||||||
|
persistentSettings.bootstrapNodeAddress = bootstrapNodeEdit.daemonAddrText ? bootstrapNodeEdit.getAddress() : "";
|
||||||
|
|
||||||
// Set current daemon address to local
|
// Set current daemon address to local
|
||||||
appWindow.currentDaemonAddress = appWindow.localDaemonAddress
|
appWindow.currentDaemonAddress = appWindow.localDaemonAddress
|
||||||
appWindow.startDaemon(daemonFlags.text)
|
appWindow.startDaemon(daemonFlags.text)
|
||||||
|
@ -374,6 +377,26 @@ Rectangle {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
RowLayout {
|
||||||
|
visible: persistentSettings.startLocalNode
|
||||||
|
ColumnLayout {
|
||||||
|
Label {
|
||||||
|
color: "#4A4949"
|
||||||
|
text: qsTr("Bootstrap node (leave blank if not wanted)") + translationManager.emptyString
|
||||||
|
}
|
||||||
|
RemoteNodeEdit {
|
||||||
|
id: bootstrapNodeEdit
|
||||||
|
Layout.minimumWidth: 100 * scaleRatio
|
||||||
|
daemonAddrText: persistentSettings.bootstrapNodeAddress.split(":")[0].trim()
|
||||||
|
daemonPortText: (persistentSettings.bootstrapNodeAddress.split(":")[1].trim() == "") ? "18081" : persistentSettings.bootstrapNodeAddress.split(":")[1]
|
||||||
|
onEditingFinished: {
|
||||||
|
persistentSettings.bootstrapNodeAddress = daemonAddrText ? bootstrapNodeEdit.getAddress() : "";
|
||||||
|
console.log("setting bootstrap node to " + persistentSettings.bootstrapNodeAddress)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
RowLayout {
|
RowLayout {
|
||||||
visible: persistentSettings.useRemoteNode
|
visible: persistentSettings.useRemoteNode
|
||||||
ColumnLayout {
|
ColumnLayout {
|
||||||
|
|
|
@ -32,7 +32,7 @@ DaemonManager *DaemonManager::instance(const QStringList *args)
|
||||||
return m_instance;
|
return m_instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool DaemonManager::start(const QString &flags, bool testnet, const QString &dataDir)
|
bool DaemonManager::start(const QString &flags, bool testnet, const QString &dataDir, const QString &bootstrapNodeAddress)
|
||||||
{
|
{
|
||||||
// prepare command line arguments and pass to monerod
|
// prepare command line arguments and pass to monerod
|
||||||
QStringList arguments;
|
QStringList arguments;
|
||||||
|
@ -67,6 +67,11 @@ bool DaemonManager::start(const QString &flags, bool testnet, const QString &dat
|
||||||
arguments << dataDir;
|
arguments << dataDir;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Bootstrap node address
|
||||||
|
if(!bootstrapNodeAddress.isEmpty()) {
|
||||||
|
arguments << "--bootstrap-daemon-address" << bootstrapNodeAddress;
|
||||||
|
}
|
||||||
|
|
||||||
arguments << "--check-updates" << "disabled";
|
arguments << "--check-updates" << "disabled";
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -14,7 +14,7 @@ public:
|
||||||
|
|
||||||
static DaemonManager * instance(const QStringList *args);
|
static DaemonManager * instance(const QStringList *args);
|
||||||
|
|
||||||
Q_INVOKABLE bool start(const QString &flags, bool testnet, const QString &dataDir = "");
|
Q_INVOKABLE bool start(const QString &flags, bool testnet, const QString &dataDir = "", const QString &bootstrapNodeAddress = "");
|
||||||
Q_INVOKABLE bool stop(bool testnet);
|
Q_INVOKABLE bool stop(bool testnet);
|
||||||
|
|
||||||
// return true if daemon process is started
|
// return true if daemon process is started
|
||||||
|
|
|
@ -55,6 +55,7 @@ ColumnLayout {
|
||||||
function onPageClosed(settingsObject) {
|
function onPageClosed(settingsObject) {
|
||||||
appWindow.persistentSettings.useRemoteNode = remoteNode.checked
|
appWindow.persistentSettings.useRemoteNode = remoteNode.checked
|
||||||
appWindow.persistentSettings.remoteNodeAddress = remoteNodeEdit.getAddress();
|
appWindow.persistentSettings.remoteNodeAddress = remoteNodeEdit.getAddress();
|
||||||
|
appWindow.persistentSettings.bootstrapNodeAddress = bootstrapNodeEdit.daemonAddrText ? bootstrapNodeEdit.getAddress() : "";
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -165,6 +166,19 @@ ColumnLayout {
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Label {
|
||||||
|
Layout.fillWidth: true
|
||||||
|
Layout.topMargin: 20 * scaleRatio
|
||||||
|
fontSize: 14 * scaleRatio
|
||||||
|
text: qsTr("Bootstrap node (leave blank if not wanted)") + translationManager.emptyString
|
||||||
|
}
|
||||||
|
RemoteNodeEdit {
|
||||||
|
Layout.minimumWidth: 300 * scaleRatio
|
||||||
|
opacity: localNode.checked
|
||||||
|
id: bootstrapNodeEdit
|
||||||
|
daemonAddrText: persistentSettings.bootstrapNodeAddress.split(":")[0].trim()
|
||||||
|
daemonPortText: (persistentSettings.bootstrapNodeAddress.split(":")[1].trim() == "") ? "18081" : persistentSettings.bootstrapNodeAddress.split(":")[1]
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
RowLayout {
|
RowLayout {
|
||||||
|
|
Loading…
Reference in a new issue