From 5252f608bd39d9a675aad5a30ba2cbc4363b962d Mon Sep 17 00:00:00 2001 From: Djordje Kovacevic Date: Fri, 27 Dec 2019 14:01:03 +0100 Subject: [PATCH 1/2] Improved logging of price calculation. Added ignoring of kademlia updating cached peer logs --- modules/logger.js | 9 +++------ modules/service/pricing-service.js | 8 +++++++- modules/service/trac-price-service.js | 11 ++++++++--- 3 files changed, 18 insertions(+), 10 deletions(-) diff --git a/modules/logger.js b/modules/logger.js index b66e5aeb5e..71dfec40a1 100644 --- a/modules/logger.js +++ b/modules/logger.js @@ -189,12 +189,6 @@ class Logger { * @return {*} */ static transformLog(level, msg) { - if (process.env.LOGS_LEVEL_DEBUG) { - return { - level, - msg, - }; - } if (msg.startsWith('connection timed out')) { return null; } @@ -213,6 +207,9 @@ class Logger { if (msg.startsWith('updating peer profile')) { return null; } + if (msg.startsWith('updating cached peer profile')) { + return null; + } if (msg.includes('client cannot service request at this time')) { return null; } diff --git a/modules/service/pricing-service.js b/modules/service/pricing-service.js index bcd42fc845..4538312b7d 100644 --- a/modules/service/pricing-service.js +++ b/modules/service/pricing-service.js @@ -44,12 +44,14 @@ class PricingService { async getGasPrice() { if (process.env.NODE_ENV === 'development') { + this.logger.trace(`Using default gas price from configuration: ${this.config.blockchain.gas_price}`); return this.config.blockchain.gas_price; } const now = new Date().getTime(); if (this.config.blockchain.gas_price_last_update_timestamp + constants.GAS_PRICE_VALIDITY_TIME_IN_MILLS > now) { + this.logger.trace(`Using gas price from configuration: ${this.config.blockchain.gas_price}`); return this.config.blockchain.gas_price; } let gasStationGasPrice = await this.gasStationService.getGasPrice() @@ -59,19 +61,23 @@ class PricingService { let web3GasPrice = await this.web3.eth.getGasPrice() .catch((err) => { this.logger.warn(err); }) * constants.AVERAGE_GAS_PRICE_MULTIPLIER; web3GasPrice = Math.round(web3GasPrice); - if (gasStationGasPrice && web3GasPrice) { const gasPrice = ( gasStationGasPrice > web3GasPrice ? gasStationGasPrice : web3GasPrice); this.saveNewGasPriceAndTime(gasPrice); + const service = gasStationGasPrice > web3GasPrice ? 'gas station' : 'web3'; + this.logger.trace(`Using gas price from ${service} service: ${gasStationGasPrice}`); return gasPrice; } else if (gasStationGasPrice) { this.saveNewGasPriceAndTime(gasStationGasPrice); + this.logger.trace(`Using gas price from gas station service: ${gasStationGasPrice}`); return gasStationGasPrice; } else if (web3GasPrice) { this.saveNewGasPriceAndTime(web3GasPrice); + this.logger.trace(`Using gas price from web3 service: ${web3GasPrice}`); return web3GasPrice; } + this.logger.trace(`Using gas price from configuration: ${this.config.blockchain.gas_price}`); return this.config.blockchain.gas_price; } diff --git a/modules/service/trac-price-service.js b/modules/service/trac-price-service.js index 2073cffdf1..39e81fb792 100644 --- a/modules/service/trac-price-service.js +++ b/modules/service/trac-price-service.js @@ -11,15 +11,17 @@ class TracPriceService { async getTracPriceInEth() { if (process.env.NODE_ENV === 'development') { + this.logger.trace(`Using default trac price in eth from configuration: ${this.config.blockchain.trac_price_in_eth}`); return this.config.blockchain.trac_price_in_eth; } const now = new Date().getTime(); if (this.config.blockchain.trac_price_in_eth_last_update_timestamp + constants.TRAC_PRICE_IN_ETH_VALIDITY_TIME_IN_MILLS > now) { + this.logger.trace(`Using trac price in eth from configuration: ${this.config.blockchain.trac_price_in_eth}`); return this.config.blockchain.trac_price_in_eth; } - let tracPriceInEth; + let tracPriceInEth = this.config.blockchain.trac_price_in_eth; const response = await axios.get(coinGeckoLink) .catch((err) => { this.logger.warn(err); @@ -29,9 +31,12 @@ class TracPriceService { } if (tracPriceInEth) { this._saveNewTracPriceInEth(tracPriceInEth); - return tracPriceInEth; + this.logger.trace(`Using trac price in eth from coingecko service: ${tracPriceInEth}`); + } else { + tracPriceInEth = this.config.blockchain.trac_price_in_eth; + this.logger.trace(`Using trac price in eth from configuration: ${tracPriceInEth}`); } - return this.config.blockchain.trac_price_in_eth; + return tracPriceInEth; } _saveNewTracPriceInEth(tracePrice) { From 9600b1f26a4a06efcc9d8e3af366347460be2377 Mon Sep 17 00:00:00 2001 From: djordjekovac Date: Mon, 30 Dec 2019 16:55:15 +0100 Subject: [PATCH 2/2] Resolved bug when reseting node causes updating of houston password (#1111) * Resolved bug when reseting node causes updating of houston password * Updated hosuton password file name in configuration --- config/config.json | 3 +++ ot-node.js | 17 ++++++++++------- test/modules/utilities.test.js | 2 +- 3 files changed, 14 insertions(+), 8 deletions(-) diff --git a/config/config.json b/config/config.json index b492b3fafe..15854331cd 100644 --- a/config/config.json +++ b/config/config.json @@ -17,6 +17,7 @@ "ssl_certificate_path": "kademlia.crt", "identity_filepath": "identity.json", "erc725_identity_filepath": "erc725_identity.json", + "houston_password_file_name": "houston.txt", "cpus": 0, "embedded_peercache_path": "peercache", "onion_virtual_port": "4043", @@ -121,6 +122,7 @@ "ssl_certificate_path": "kademlia.crt", "identity_filepath": "identity.json", "erc725_identity_filepath": "erc725_identity.json", + "houston_password_file_name": "houston.txt", "cpus": 0, "embedded_peercache_path": "peercache", "onion_virtual_port": "4043", @@ -229,6 +231,7 @@ "ssl_certificate_path": "kademlia.crt", "identity_filepath": "identity.json", "erc725_identity_filepath": "erc725_identity.json", + "houston_password_file_name": "houston.txt", "cpus": 0, "embedded_peercache_path": "peercache", "onion_virtual_port": "4043", diff --git a/ot-node.js b/ot-node.js index a2404d9ccc..74efdf7161 100644 --- a/ot-node.js +++ b/ot-node.js @@ -426,16 +426,19 @@ class OTNode { process.exit(1); } - // Fetch Houston access password - if (!config.houston_password) { + const houstonPasswordFilePath = path + .join(config.appDataPath, config.houston_password_file_name); + if (fs.existsSync(houstonPasswordFilePath)) { + log.info('Using existing houston password.'); + config.houston_password = fs.readFileSync(houstonPasswordFilePath).toString(); + } else { config.houston_password = uuidv4(); + fs.writeFileSync(houstonPasswordFilePath, config.houston_password); + log.notify('================================================================'); + log.notify(' Houston password generated and stored in file '); + log.notify('================================================================'); } - fs.writeFileSync(path.join(config.appDataPath, 'houston.txt'), config.houston_password); - log.notify('================================================================'); - log.notify('Houston password stored in file '); - log.notify('================================================================'); - // Starting the kademlia const transport = container.resolve('transport'); await transport.init(container.cradle); diff --git a/test/modules/utilities.test.js b/test/modules/utilities.test.js index 9ec0b321fb..1206af47da 100644 --- a/test/modules/utilities.test.js +++ b/test/modules/utilities.test.js @@ -23,7 +23,7 @@ describe('Utilities module', () => { 'ssl_authority_paths', 'node_rpc_port', 'remote_control_enabled', 'dc_challenge_retry_delay_in_millis', 'dh_challenge_retry_delay_in_millis', 'read_stake_factor', 'send_logs_to_origintrail', - 'dh_min_reputation', 'dh_min_stake_amount', + 'dh_min_reputation', 'dh_min_stake_amount', 'houston_password_file_name', 'is_bootstrap_node', 'houston_password', 'reverse_tunnel_address', 'reverse_tunnel_port', 'autoUpdater', 'bugSnag', 'network', 'dataSetStorage', 'dc_holding_time_in_minutes', 'dc_choose_time', 'dc_litigation_interval_in_minutes', 'dh_max_holding_time_in_minutes', 'dh_min_litigation_interval_in_minutes',