mirror of
https://github.com/everoddandeven/monerod-gui.git
synced 2025-01-23 03:04:51 +00:00
Fix daemon settings keys parsing #8
This commit is contained in:
parent
55c7cfd52b
commit
f744dad0f5
7 changed files with 52 additions and 13 deletions
|
@ -191,8 +191,8 @@
|
||||||
|
|
||||||
|
|
||||||
<div class="form-check form-switch col-md-6">
|
<div class="form-check form-switch col-md-6">
|
||||||
<label for="enforce-dns-checkpoints" class="form-check-label">Enforce DNS checkpoints</label>
|
<label for="enforce-dns-checkpointing" class="form-check-label">Enforce DNS checkpointing</label>
|
||||||
<input class="form-control form-check-input" type="checkbox" role="switch" id="enforce-dns-checkpoints" [checked]="currentSettings.enforceDnsCheckpoint" [(ngModel)]="currentSettings.enforceDnsCheckpoint" [ngModelOptions]="{standalone: true}">
|
<input class="form-control form-check-input" type="checkbox" role="switch" id="enforce-dns-checkpointing" [checked]="currentSettings.enforceDnsCheckpoint" [(ngModel)]="currentSettings.enforceDnsCheckpoint" [ngModelOptions]="{standalone: true}">
|
||||||
<br>
|
<br>
|
||||||
<small class="text-body-secondary">Checkpoints from DNS server will be enforced</small>
|
<small class="text-body-secondary">Checkpoints from DNS server will be enforced</small>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -3,6 +3,7 @@ import { NavbarLink } from '../../shared/components/navbar/navbar.model';
|
||||||
import { DaemonSettings } from '../../../common/DaemonSettings';
|
import { DaemonSettings } from '../../../common/DaemonSettings';
|
||||||
import { DaemonService } from '../../core/services/daemon/daemon.service';
|
import { DaemonService } from '../../core/services/daemon/daemon.service';
|
||||||
import { ElectronService } from '../../core/services';
|
import { ElectronService } from '../../core/services';
|
||||||
|
import { InvalidDaemonSettingsKeyError } from '../../../common';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-settings',
|
selector: 'app-settings',
|
||||||
|
@ -309,6 +310,11 @@ export class SettingsComponent {
|
||||||
catch(error: any) {
|
catch(error: any) {
|
||||||
console.error(error);
|
console.error(error);
|
||||||
this.successMessage = '';
|
this.successMessage = '';
|
||||||
|
|
||||||
|
if (error instanceof InvalidDaemonSettingsKeyError) {
|
||||||
|
throw error;
|
||||||
|
}
|
||||||
|
|
||||||
throw new Error("Could not parse monerod config file");
|
throw new Error("Could not parse monerod config file");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
import { DaemonSettingsInvalidNetworkError, InvalidDaemonSettingsKeyError } from "./error";
|
||||||
|
|
||||||
export class DaemonSettings {
|
export class DaemonSettings {
|
||||||
public monerodPath: string = '';
|
public monerodPath: string = '';
|
||||||
|
|
||||||
|
@ -45,7 +47,7 @@ export class DaemonSettings {
|
||||||
|
|
||||||
public keepFakeChain: boolean = false;
|
public keepFakeChain: boolean = false;
|
||||||
public fixedDifficulty: number = 0;
|
public fixedDifficulty: number = 0;
|
||||||
public enforceDnsCheckpoint: boolean = false;
|
public enforceDnsCheckpointing: boolean = false;
|
||||||
public prepBlocksThreads: number = 0;
|
public prepBlocksThreads: number = 0;
|
||||||
public fastBlockSync: boolean = false;
|
public fastBlockSync: boolean = false;
|
||||||
public showTimeStats: boolean = false;
|
public showTimeStats: boolean = false;
|
||||||
|
@ -266,14 +268,15 @@ export class DaemonSettings {
|
||||||
case 'p2p-bind-ip': settings.p2pBindIp = value; break;
|
case 'p2p-bind-ip': settings.p2pBindIp = value; break;
|
||||||
case 'p2p-bind-ipv6-address': settings.p2pBindIpv6Address = value; break;
|
case 'p2p-bind-ipv6-address': settings.p2pBindIpv6Address = value; break;
|
||||||
case 'p2p-bind-port': settings.p2pBindPort = parseInt(value, 10); break;
|
case 'p2p-bind-port': settings.p2pBindPort = parseInt(value, 10); break;
|
||||||
|
case 'p2p-bind-port-ipv6': settings.p2pBindPortIpv6 = parseInt(value, 10); break;
|
||||||
case 'p2p-use-ipv6': settings.p2pUseIpv6 = boolValue; break;
|
case 'p2p-use-ipv6': settings.p2pUseIpv6 = boolValue; break;
|
||||||
|
case 'p2p-ignore-ipv4': settings.p2pIgnoreIpv4 = boolValue; break;
|
||||||
|
case 'p2p-external-port': settings.p2pExternalPort = parseInt(value, 10); break;
|
||||||
case 'add-peer': settings.addPeer = value; break;
|
case 'add-peer': settings.addPeer = value; break;
|
||||||
case 'add-priority-node': settings.addPriorityNode = value; break;
|
case 'add-priority-node': settings.addPriorityNode = value; break;
|
||||||
case 'bootstrap-daemon-address': settings.bootstrapDaemonAddress = value; break;
|
case 'bootstrap-daemon-address': settings.bootstrapDaemonAddress = value; break;
|
||||||
case 'bootstrap-daemon-login': settings.bootstrapDaemonLogin = value; break;
|
case 'bootstrap-daemon-login': settings.bootstrapDaemonLogin = value; break;
|
||||||
case 'bootstrap-daemon-proxy': settings.bootstrapDaemonProxy = value; break;
|
case 'bootstrap-daemon-proxy': settings.bootstrapDaemonProxy = value; break;
|
||||||
case 'rpc-bind-ip': settings.rpcBindIp = value; break;
|
|
||||||
case 'rpc-bind-port': settings.rpcBindPort = parseInt(value, 10); break;
|
|
||||||
case 'confirm-external-bind': settings.confirmExternalBind = boolValue; break;
|
case 'confirm-external-bind': settings.confirmExternalBind = boolValue; break;
|
||||||
case 'disable-dns-checkpoints': settings.disableDnsCheckpoints = boolValue; break;
|
case 'disable-dns-checkpoints': settings.disableDnsCheckpoints = boolValue; break;
|
||||||
case 'sync-pruned-blocks': settings.syncPrunedBlocks = boolValue; break;
|
case 'sync-pruned-blocks': settings.syncPrunedBlocks = boolValue; break;
|
||||||
|
@ -293,6 +296,8 @@ export class DaemonSettings {
|
||||||
case 'tos-flag': settings.tosFlag = parseInt(value, 10); break;
|
case 'tos-flag': settings.tosFlag = parseInt(value, 10); break;
|
||||||
case 'max-connections-per-ip': settings.maxConnectionsPerIp = parseInt(value, 10); break;
|
case 'max-connections-per-ip': settings.maxConnectionsPerIp = parseInt(value, 10); break;
|
||||||
case 'disable-rpc-ban': settings.disableRpcBan = boolValue; break;
|
case 'disable-rpc-ban': settings.disableRpcBan = boolValue; break;
|
||||||
|
case 'rpc-bind-ip': settings.rpcBindIp = value; break;
|
||||||
|
case 'rpc-bind-port': settings.rpcBindPort = parseInt(value, 10); break;
|
||||||
case 'rpc-access-control-origins': settings.rpcAccessControlOrigins = value; break;
|
case 'rpc-access-control-origins': settings.rpcAccessControlOrigins = value; break;
|
||||||
case 'rpc-ssl': settings.rpcSsl = value as 'autodetect' | 'enabled' | 'disabled'; break;
|
case 'rpc-ssl': settings.rpcSsl = value as 'autodetect' | 'enabled' | 'disabled'; break;
|
||||||
case 'rpc-ssl-private-key': settings.rpcSslPrivateKey = value; break;
|
case 'rpc-ssl-private-key': settings.rpcSslPrivateKey = value; break;
|
||||||
|
@ -304,12 +309,13 @@ export class DaemonSettings {
|
||||||
case 'rpc-payment-allow-free-loopback': settings.rpcPaymentAllowFreeLoopback = boolValue; break;
|
case 'rpc-payment-allow-free-loopback': settings.rpcPaymentAllowFreeLoopback = boolValue; break;
|
||||||
case 'rpc-payment-difficulty': settings.rpcPaymentDifficuly = parseInt(value, 10); break;
|
case 'rpc-payment-difficulty': settings.rpcPaymentDifficuly = parseInt(value, 10); break;
|
||||||
case 'rpc-payment-credits': settings.rpcPaymentCredits = parseInt(value, 10); break;
|
case 'rpc-payment-credits': settings.rpcPaymentCredits = parseInt(value, 10); break;
|
||||||
|
case 'rpc-payment-address': settings.rpcPaymentAddress = value; break;
|
||||||
|
case 'restricted-rpc': settings.restrictedRpc = boolValue; break;
|
||||||
case 'extra-messages-file': settings.extraMessagesFile = value; break;
|
case 'extra-messages-file': settings.extraMessagesFile = value; break;
|
||||||
case 'seed-node': settings.seedNode = value; break;
|
case 'seed-node': settings.seedNode = value; break;
|
||||||
case 'zmq-rpc-bind-ip': settings.zmqRpcBindIp = value; break;
|
case 'zmq-rpc-bind-ip': settings.zmqRpcBindIp = value; break;
|
||||||
case 'zmq-rpc-bind-port': settings.zmqRpcBindPort = parseInt(value, 10); break;
|
case 'zmq-rpc-bind-port': settings.zmqRpcBindPort = parseInt(value, 10); break;
|
||||||
case 'zmq-pub': settings.zmqPub = value; break;
|
case 'zmq-pub': settings.zmqPub = value; break;
|
||||||
case 'rpc-payment-address': settings.rpcPaymentAddress = value; break;
|
|
||||||
case 'no-zmq': settings.noZmq = boolValue; break;
|
case 'no-zmq': settings.noZmq = boolValue; break;
|
||||||
case 'fixed-difficulty': settings.fixedDifficulty = parseInt(value, 10); break;
|
case 'fixed-difficulty': settings.fixedDifficulty = parseInt(value, 10); break;
|
||||||
case 'prep-blocks-threads': settings.prepBlocksThreads = parseInt(value, 10); break;
|
case 'prep-blocks-threads': settings.prepBlocksThreads = parseInt(value, 10); break;
|
||||||
|
@ -318,10 +324,11 @@ export class DaemonSettings {
|
||||||
case 'show-time-stats': settings.showTimeStats = boolValue; break;
|
case 'show-time-stats': settings.showTimeStats = boolValue; break;
|
||||||
case 'block-sync-size': settings.blockSyncSize = parseInt(value, 10); break;
|
case 'block-sync-size': settings.blockSyncSize = parseInt(value, 10); break;
|
||||||
case 'block-rate-notify': settings.blockRateNotify = value; break;
|
case 'block-rate-notify': settings.blockRateNotify = value; break;
|
||||||
|
case 'block-download-max-size': settings.blockDownloadMaxSize = parseInt(value, 10); break;
|
||||||
case 'reorg-notify': settings.reorgNotify = value; break;
|
case 'reorg-notify': settings.reorgNotify = value; break;
|
||||||
case 'prune-blockchain': settings.pruneBlockchain = boolValue; break;
|
case 'prune-blockchain': settings.pruneBlockchain = boolValue; break;
|
||||||
case 'keep-alt-blocks': settings.keepAltBlocks = boolValue; break;
|
case 'keep-alt-blocks': settings.keepAltBlocks = boolValue; break;
|
||||||
case 'keep-fake-chain': settings.keepFakeChain = boolValue; break;
|
case 'keep-fakechain': settings.keepFakeChain = boolValue; break;
|
||||||
case 'add-exclusive-node': settings.addExclusiveNode = value; break;
|
case 'add-exclusive-node': settings.addExclusiveNode = value; break;
|
||||||
case 'no-sync': settings.noSync = boolValue; break;
|
case 'no-sync': settings.noSync = boolValue; break;
|
||||||
case 'start-mining': settings.startMining = value; break;
|
case 'start-mining': settings.startMining = value; break;
|
||||||
|
@ -329,16 +336,17 @@ export class DaemonSettings {
|
||||||
case 'bg-mining-enable': settings.bgMiningEnable = boolValue; break;
|
case 'bg-mining-enable': settings.bgMiningEnable = boolValue; break;
|
||||||
case 'bg-mining-ignore-battery': settings.bgMiningIgnoreBattery = boolValue; break;
|
case 'bg-mining-ignore-battery': settings.bgMiningIgnoreBattery = boolValue; break;
|
||||||
case 'bg-mining-idle-threshold': settings.bgMiningIdleThreshold = parseInt(value, 10); break;
|
case 'bg-mining-idle-threshold': settings.bgMiningIdleThreshold = parseInt(value, 10); break;
|
||||||
|
case 'bg-mining-min-idle-interval': settings.bgMiningMinIdleInterval = parseInt(value, 10); break;
|
||||||
case 'bg-mining-miner-target': settings.bgMiningMinerTarget = parseInt(value, 10); break;
|
case 'bg-mining-miner-target': settings.bgMiningMinerTarget = parseInt(value, 10); break;
|
||||||
case 'hide-my-port': settings.hideMyPort = boolValue; break;
|
case 'hide-my-port': settings.hideMyPort = boolValue; break;
|
||||||
case 'enforce-dns-checkpoint': settings.enforceDnsCheckpoint = boolValue; break;
|
case 'enforce-dns-checkpointing': settings.enforceDnsCheckpointing = boolValue; break;
|
||||||
case 'test-drop-download': settings.testDropDownload = boolValue; break;
|
case 'test-drop-download': settings.testDropDownload = boolValue; break;
|
||||||
case 'test-drop-download-height': settings.testDropDownloadHeight = parseInt(value, 10); break;
|
case 'test-drop-download-height': settings.testDropDownloadHeight = parseInt(value, 10); break;
|
||||||
case 'test-dbg-lock-sleep': settings.testDbgLockSleep = parseInt(value, 10); break;
|
case 'test-dbg-lock-sleep': settings.testDbgLockSleep = parseInt(value, 10); break;
|
||||||
case 'in-peers': settings.inPeers = parseInt(value, 10); break;
|
case 'in-peers': settings.inPeers = parseInt(value, 10); break;
|
||||||
case 'out-peers': settings.outPeers = parseInt(value, 10); break;
|
case 'out-peers': settings.outPeers = parseInt(value, 10); break;
|
||||||
|
|
||||||
default: throw new Error(`Invalid setting: ${key}`);
|
default: throw new InvalidDaemonSettingsKeyError(key);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -364,7 +372,7 @@ export class DaemonSettings {
|
||||||
if (this.testnet) options.push(`--testnet`);
|
if (this.testnet) options.push(`--testnet`);
|
||||||
else if (this.stagenet) options.push(`--stagenet`);
|
else if (this.stagenet) options.push(`--stagenet`);
|
||||||
else if (!this.mainnet) {
|
else if (!this.mainnet) {
|
||||||
throw new Error("Invalid daemon settings");
|
throw new DaemonSettingsInvalidNetworkError();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.logFile != '') options.push('--log-file', this.logFile);
|
if (this.logFile != '') options.push('--log-file', this.logFile);
|
||||||
|
@ -382,11 +390,11 @@ export class DaemonSettings {
|
||||||
if (!this.noZmq && this.zmqPub != '') options.push(`--zmq-pub`, this.zmqPub);
|
if (!this.noZmq && this.zmqPub != '') options.push(`--zmq-pub`, this.zmqPub);
|
||||||
if (this.testDropDownload) options.push(`--test-drop-download`);
|
if (this.testDropDownload) options.push(`--test-drop-download`);
|
||||||
if (this.testDropDownload && this.testDropDownloadHeight) options.push(`--test-drop-download-height`);
|
if (this.testDropDownload && this.testDropDownloadHeight) options.push(`--test-drop-download-height`);
|
||||||
if (this.testDbgLockSleep) options.push(`--tet-dbg-lock-sleep`, `${this.testDbgLockSleep}`);
|
if (this.testDbgLockSleep) options.push(`--test-dbg-lock-sleep`, `${this.testDbgLockSleep}`);
|
||||||
if (this.regtest) options.push(`--regtest`);
|
if (this.regtest) options.push(`--regtest`);
|
||||||
if (this.keepFakeChain) options.push(`--keep-fakechain`);
|
if (this.keepFakeChain) options.push(`--keep-fakechain`);
|
||||||
if (this.fixedDifficulty) options.push(`--fixed-difficulty`, `${this.fixedDifficulty}`);
|
if (this.fixedDifficulty) options.push(`--fixed-difficulty`, `${this.fixedDifficulty}`);
|
||||||
if (this.enforceDnsCheckpoint) options.push(`--enforce-dns-checkpoint`);
|
if (this.enforceDnsCheckpointing) options.push(`--enforce-dns-checkpointing`);
|
||||||
if (this.prepBlocksThreads) options.push(`--prep-blocks-threads`, `${this.prepBlocksThreads}`);
|
if (this.prepBlocksThreads) options.push(`--prep-blocks-threads`, `${this.prepBlocksThreads}`);
|
||||||
if (!this.noSync && this.fastBlockSync) options.push(`--fast-block-sync`, `1`);
|
if (!this.noSync && this.fastBlockSync) options.push(`--fast-block-sync`, `1`);
|
||||||
if (this.showTimeStats) options.push(`--show-time-stats`);
|
if (this.showTimeStats) options.push(`--show-time-stats`);
|
||||||
|
@ -409,7 +417,7 @@ export class DaemonSettings {
|
||||||
if (this.bgMiningEnable) options.push(`--bg-mining-enable`);
|
if (this.bgMiningEnable) options.push(`--bg-mining-enable`);
|
||||||
if (this.bgMiningIgnoreBattery) options.push(`--bg-mining-ignore-battery`);
|
if (this.bgMiningIgnoreBattery) options.push(`--bg-mining-ignore-battery`);
|
||||||
if (this.bgMiningIdleThreshold) options.push(`--bg-mining-idle-threshold`, `${this.bgMiningIdleThreshold}`);
|
if (this.bgMiningIdleThreshold) options.push(`--bg-mining-idle-threshold`, `${this.bgMiningIdleThreshold}`);
|
||||||
if (this.bgMiningMinIdleInterval) options.push(`--bg-mining-idle-interval`, `${this.bgMiningMinIdleInterval}`);
|
if (this.bgMiningMinIdleInterval) options.push(`--bg-mining-min-idle-interval`, `${this.bgMiningMinIdleInterval}`);
|
||||||
if (this.bgMiningMinerTarget) options.push(`--bg-mining-miner-target`, `${this.bgMiningMinerTarget}`);
|
if (this.bgMiningMinerTarget) options.push(`--bg-mining-miner-target`, `${this.bgMiningMinerTarget}`);
|
||||||
if (!this.noSync && this.dbSyncMode != '') options.push(`--db-sync-mode`, `${this.dbSyncMode}`);
|
if (!this.noSync && this.dbSyncMode != '') options.push(`--db-sync-mode`, `${this.dbSyncMode}`);
|
||||||
if (this.dbSalvage) options.push(`--db-salvage`);
|
if (this.dbSalvage) options.push(`--db-salvage`);
|
||||||
|
|
3
src/common/error/DaemonSettingsError.ts
Normal file
3
src/common/error/DaemonSettingsError.ts
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
export class DaemonSettingsError extends Error {
|
||||||
|
|
||||||
|
}
|
8
src/common/error/DaemonSettingsInvalidNetworkError.ts
Normal file
8
src/common/error/DaemonSettingsInvalidNetworkError.ts
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
import { DaemonSettingsError } from "./DaemonSettingsError";
|
||||||
|
|
||||||
|
export class DaemonSettingsInvalidNetworkError extends DaemonSettingsError {
|
||||||
|
|
||||||
|
constructor() {
|
||||||
|
super("Invalid daemon network settings");
|
||||||
|
}
|
||||||
|
}
|
11
src/common/error/DaemonSettingsUnknownKeyError.ts
Normal file
11
src/common/error/DaemonSettingsUnknownKeyError.ts
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
import { DaemonSettingsError } from "./DaemonSettingsError"
|
||||||
|
|
||||||
|
export class DaemonSettingsUnkownKeyError extends DaemonSettingsError {
|
||||||
|
public key: string;
|
||||||
|
|
||||||
|
constructor(key: string) {
|
||||||
|
super(`Unknown daemon setting <strong>${key}</strong>`);
|
||||||
|
|
||||||
|
this.key = key;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,3 +1,6 @@
|
||||||
export { RpcError } from "./RpcError";
|
export { RpcError } from "./RpcError";
|
||||||
export { CoreIsBusyError } from "./CoreIsBusyError";
|
export { CoreIsBusyError } from "./CoreIsBusyError";
|
||||||
|
export { DaemonSettingsError } from "./DaemonSettingsError";
|
||||||
|
export { DaemonSettingsInvalidNetworkError } from "./DaemonSettingsInvalidNetworkError";
|
||||||
|
export { DaemonSettingsUnkownKeyError as InvalidDaemonSettingsKeyError } from "./DaemonSettingsUnknownKeyError";
|
||||||
export { MethodNotFoundError } from "./MethodNotFoundError";
|
export { MethodNotFoundError } from "./MethodNotFoundError";
|
||||||
|
|
Loading…
Reference in a new issue