This repository has been archived by the owner on Jun 11, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 15
/
config.js
111 lines (102 loc) · 3.28 KB
/
config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/*
* LiskHQ/lisk-service
* Copyright © 2022 Lisk Foundation
*
* See the LICENSE file at the top-level directory of this distribution
* for licensing information.
*
* Unless otherwise agreed in a custom licensing agreement with the Lisk Foundation,
* no part of this software, including this file, may be copied, modified,
* propagated, or distributed except according to the terms contained in the
* LICENSE file.
*
* Removal or modification of this copyright notice is prohibited.
*
*/
const packageJson = require('./package.json');
const config = {
endpoints: {},
log: {
name: packageJson.name,
version: packageJson.version,
},
};
/**
* Inter-service message broker
*/
config.transporter = process.env.SERVICE_BROKER || 'redis://lisk:[email protected]:6379/0';
config.brokerTimeout = Number(process.env.SERVICE_BROKER_TIMEOUT) || 10; // in seconds
/**
* External endpoints
*/
config.endpoints.redis =
process.env.SERVICE_STATISTICS_REDIS || 'redis://lisk:[email protected]:6379/7';
// Primary database. Used for both read-write operations.
config.endpoints.mysql =
process.env.SERVICE_STATISTICS_MYSQL || 'mysql://lisk:[email protected]:3306/lisk';
// DB replicas against the primary. Used for read-only operations.
config.endpoints.mysqlReplica =
process.env.SERVICE_STATISTICS_MYSQL_READ_REPLICA || config.endpoints.mysql;
config.transactionStatistics = {
historyLengthDays: Number(process.env.TRANSACTION_STATS_HISTORY_LENGTH_DAYS) || 366,
};
/**
* LOGGING
*
* log.level - TRACE < DEBUG < INFO < WARN < ERROR < FATAL < MARK
* log.console - Plain JavaScript console.log() output (true/false)
* log.stdout - Writes directly to stdout (true/false)
* log.file - outputs to a file (ie. ./logs/app.log)
* log.gelf - Writes to GELF-compatible socket (ie. 127.0.0.1:12201/udp)
*/
config.log.level = process.env.SERVICE_LOG_LEVEL || 'info';
config.log.console = process.env.SERVICE_LOG_CONSOLE || 'false';
config.log.stdout = process.env.SERVICE_LOG_STDOUT || 'true';
config.log.gelf = process.env.SERVICE_LOG_GELF || 'false';
config.log.file = process.env.SERVICE_LOG_FILE || 'false';
config.log.docker_host = process.env.DOCKER_HOST || 'local';
config.debug = process.env.SERVICE_LOG_LEVEL === 'debug';
config.queue = {
transactionStats: {
name: 'TransactionStats',
concurrency: 1,
},
default: {
defaultJobOptions: {
attempts: 5,
timeout: 5 * 60 * 1000, // millisecs
removeOnComplete: true,
removeOnFail: true,
stackTraceLimit: 0,
},
},
};
config.networks = [
{
networkName: 'mainnet',
chainID: '00000000',
serviceUrl: 'https://service.lisk.com',
},
{
networkName: 'testnet',
chainID: '01000000',
serviceUrl: 'https://testnet-service.lisk.com',
},
{
networkName: 'betanet',
chainID: '02000000',
serviceUrl: 'https://betanet-service.lisk.com',
},
];
config.job = {
// Interval takes priority over schedule and must be greater than 0 to be valid
refreshTransactionStats: {
interval: Number(process.env.JOB_INTERVAL_REFRESH_TRANSACTION_STATS) || 0,
schedule: process.env.JOB_SCHEDULE_REFRESH_TRANSACTION_STATS || '*/30 * * * *',
},
verifyTransactionStats: {
interval: Number(process.env.JOB_INTERVAL_VERIFY_TRANSACTION_STATS) || 0,
schedule: process.env.JOB_SCHEDULE_VERIFY_TRANSACTION_STATS || '15 */3 * * *',
},
};
module.exports = config;