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
86 lines (77 loc) · 2.59 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
/*
* 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: {},
jobs: {},
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.messageQueue =
process.env.SERVICE_MESSAGE_QUEUE_REDIS || 'redis://lisk:[email protected]:6379/4';
/**
* 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';
/**
* Message queue options
*/
config.queue = {
defaultJobOptions: {
attempts: 5,
timeout: 5 * 60 * 1000, // millisecs
removeOnComplete: true,
removeOnFail: true,
stackTraceLimit: 0,
},
// Inter-microservice message queues
account: { name: 'Account' },
block: { name: 'Block' },
event: { name: 'Event' },
};
config.job = {
progressRefreshInterval: 30 * 1000, // millisecs
// Interval takes priority over schedule and must be greater than 0 to be valid
indexMissingBlocks: {
interval: Number(process.env.JOB_INTERVAL_INDEX_MISSING_BLOCKS) || 0,
schedule: process.env.JOB_SCHEDULE_INDEX_MISSING_BLOCKS || '*/5 * * * *',
skipThreshold: Number(process.env.INDEX_MISSING_BLOCKS_SKIP_THRESHOLD) || 1000,
maxBlocksToSchedule: Number(process.env.INDEX_MISSING_BLOCKS_MAX_SCHEDULE) || 25000,
},
};
module.exports = config;