|
|
|
/*!
|
|
|
|
* keys/index-example.js
|
|
|
|
* Copyright (c) 2016-2018, Samourai Wallet (CC BY-NC-ND 4.0 License).
|
|
|
|
*/
|
|
|
|
const fs = require('fs')
|
|
|
|
|
|
|
|
|
|
|
|
// Retrieve active bitcoin network from conf files
|
|
|
|
const bitcoinNetwork = (process.env.COMMON_BTC_NETWORK == 'testnet')
|
|
|
|
? 'testnet'
|
|
|
|
: 'bitcoin'
|
|
|
|
|
|
|
|
// Retrieve explorer config from conf files
|
|
|
|
let explorerActive = 'oxt'
|
|
|
|
let explorerUrl = 'https://oxt.me'
|
|
|
|
let explorerPassword = ''
|
|
|
|
if (process.env.EXPLORER_INSTALL == 'on') {
|
|
|
|
try {
|
|
|
|
explorerUrl = fs.readFileSync('/var/lib/tor/hsv3explorer/hostname', 'utf8').replace('\n', '')
|
|
|
|
explorerPassword = process.env.EXPLORER_KEY
|
|
|
|
explorerActive = 'btc_rpc_explorer'
|
|
|
|
} catch(e) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Desired structure of /keys/index.js, which is ignored in the repository.
|
|
|
|
*/
|
|
|
|
module.exports = {
|
|
|
|
/*
|
|
|
|
* Mainnet parameters
|
|
|
|
*/
|
|
|
|
[bitcoinNetwork]: {
|
|
|
|
/*
|
|
|
|
* Dojo version
|
|
|
|
*/
|
|
|
|
dojoVersion: process.env.DOJO_NODEJS_VERSION_TAG,
|
|
|
|
/*
|
|
|
|
* Bitcoind
|
|
|
|
*/
|
|
|
|
bitcoind: {
|
|
|
|
// RPC API
|
|
|
|
rpc: {
|
|
|
|
// Login
|
|
|
|
user: process.env.BITCOIND_RPC_USER,
|
|
|
|
// Password
|
|
|
|
pass: process.env.BITCOIND_RPC_PASSWORD,
|
|
|
|
// IP address
|
|
|
|
host: process.env.BITCOIND_IP,
|
|
|
|
// TCP port
|
|
|
|
port: parseInt(process.env.BITCOIND_RPC_PORT)
|
|
|
|
},
|
|
|
|
// ZMQ Tx notifications
|
|
|
|
zmqTx: `tcp://${process.env.BITCOIND_IP}:${process.env.BITCOIND_ZMQ_RAWTXS}`,
|
|
|
|
// ZMQ Block notifications
|
|
|
|
zmqBlk: `tcp://${process.env.BITCOIND_IP}:${process.env.BITCOIND_ZMQ_BLK_HASH}`,
|
|
|
|
// Fee type (estimatesmartfee)
|
|
|
|
feeType: process.env.NODE_FEE_TYPE
|
|
|
|
},
|
|
|
|
/*
|
|
|
|
* MySQL database
|
|
|
|
*/
|
|
|
|
db: {
|
|
|
|
// User
|
|
|
|
user: process.env.MYSQL_USER,
|
|
|
|
// Password
|
|
|
|
pass: process.env.MYSQL_PASSWORD,
|
|
|
|
// IP address
|
|
|
|
host: 'db',
|
|
|
|
// TCP port
|
|
|
|
port: 3306,
|
|
|
|
// Db name
|
|
|
|
database: process.env.MYSQL_DATABASE,
|
|
|
|
// Timeout
|
|
|
|
acquireTimeout: 15000,
|
|
|
|
// Max number of concurrent connections
|
|
|
|
// for each module
|
|
|
|
connectionLimitApi: 50,
|
|
|
|
connectionLimitTracker: 10,
|
|
|
|
connectionLimitPushTxApi: 5,
|
|
|
|
connectionLimitPushTxOrchestrator: 5
|
|
|
|
},
|
|
|
|
/*
|
|
|
|
* IP address used to expose the API ports
|
|
|
|
*/
|
|
|
|
apiBind: '0.0.0.0',
|
|
|
|
/*
|
|
|
|
* TCP Ports
|
|
|
|
*/
|
|
|
|
ports: {
|
|
|
|
// Port used by the API
|
|
|
|
account: 8080,
|
|
|
|
// Port used by the pushtx API
|
|
|
|
pushtx: 8081,
|
|
|
|
// Port used by the tracker API
|
|
|
|
trackerApi: 8082,
|
|
|
|
// Port used by the tracker for its notifications
|
|
|
|
tracker: 5555,
|
|
|
|
// Port used by pushtx for its notifications
|
|
|
|
notifpushtx: 5556,
|
|
|
|
// Port used by the pushtx orchestrator for its notifications
|
|
|
|
orchestrator: 5557
|
|
|
|
},
|
|
|
|
/*
|
|
|
|
* Authenticated access to the APIs (account & pushtx)
|
|
|
|
*/
|
|
|
|
auth: {
|
|
|
|
// Name of the authentication strategy used
|
|
|
|
// Available values:
|
|
|
|
// null : No authentication
|
|
|
|
// 'localApiKey' : authentication with a shared local api key
|
|
|
|
activeStrategy: 'localApiKey',
|
|
|
|
// Flag indicating if authenticated access is mandatory
|
|
|
|
// (useful for launch, othewise should be true)
|
|
|
|
// @todo Set to true !!!
|
|
|
|
mandatory: true,
|
|
|
|
// List of available authentication strategies
|
|
|
|
strategies: {
|
|
|
|
// Authentication with a shared local api key
|
|
|
|
localApiKey: {
|
|
|
|
// List of API keys (alphanumeric characters)
|
|
|
|
apiKeys: [process.env.NODE_API_KEY],
|
|
|
|
// Admin key (alphanumeric characters)
|
|
|
|
adminKey: process.env.NODE_ADMIN_KEY,
|
|
|
|
// DO NOT MODIFY
|
|
|
|
configurator: 'localapikey-strategy-configurator'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
// Configuration of Json Web Tokens
|
|
|
|
// used for the management of authorizations
|
|
|
|
jwt: {
|
|
|
|
// Secret passphrase used by the server to sign the jwt
|
|
|
|
// (alphanumeric characters)
|
|
|
|
secret: process.env.NODE_JWT_SECRET,
|
|
|
|
accessToken: {
|
|
|
|
// Number of seconds after which the jwt expires
|
|
|
|
expires: parseInt(process.env.NODE_JWT_ACCESS_EXPIRES)
|
|
|
|
},
|
|
|
|
refreshToken: {
|
|
|
|
// Number of seconds after which the jwt expires
|
|
|
|
expires: parseInt(process.env.NODE_JWT_REFRESH_EXPIRES)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
/*
|
|
|
|
* Prefixes used by the API
|
|
|
|
* for /support and /status endpoints
|
|
|
|
*/
|
|
|
|
prefixes: {
|
|
|
|
// Prefix for /support endpoint
|
|
|
|
support: process.env.NODE_PREFIX_SUPPORT,
|
|
|
|
// Prefix for /status endpoint
|
|
|
|
status: process.env.NODE_PREFIX_STATUS,
|
|
|
|
// Prefix for pushtx /status endpoint
|
|
|
|
statusPushtx: process.env.NODE_PREFIX_STATUS_PUSHTX
|
|
|
|
},
|
|
|
|
/*
|
|
|
|
* Gaps used for derivation of keys
|
|
|
|
*/
|
|
|
|
gap: {
|
|
|
|
// Gap for derivation of external addresses
|
|
|
|
external: parseInt(process.env.NODE_GAP_EXTERNAL),
|
|
|
|
// Gap for derivation of internal (change) addresses
|
|
|
|
internal: parseInt(process.env.NODE_GAP_INTERNAL)
|
|
|
|
},
|
|
|
|
/*
|
|
|
|
* Multiaddr endpoint
|
|
|
|
*/
|
|
|
|
multiaddr: {
|
|
|
|
// Number of transactions returned by the endpoint
|
|
|
|
transactions: 50
|
|
|
|
},
|
|
|
|
/*
|
|
|
|
* Indexer or third party service
|
|
|
|
* used for fast scan of addresses
|
|
|
|
*/
|
|
|
|
indexer: {
|
|
|
|
// Active indexer
|
|
|
|
// Values: local_bitcoind | local_indexer | third_party_explorer
|
|
|
|
active: process.env.NODE_ACTIVE_INDEXER,
|
|
|
|
// Local indexer
|
|
|
|
localIndexer: {
|
|
|
|
// IP address or hostname of the local indexer
|
|
|
|
host: process.env.INDEXER_IP,
|
|
|
|
// Port
|
|
|
|
port: parseInt(process.env.INDEXER_RPC_PORT),
|
|
|
|
// Support of batch requests by the local indexer
|
|
|
|
// Values: active | inactive
|
|
|
|
batchRequests: process.env.INDEXER_BATCH_SUPPORT
|
|
|
|
},
|
|
|
|
// Use a SOCKS5 proxy for all communications with external services
|
|
|
|
// Values: null if no socks5 proxy used, otherwise the url of the socks5 proxy
|
|
|
|
socks5Proxy: 'socks5h://172.28.1.4:9050',
|
|
|
|
// OXT (mainnet)
|
|
|
|
oxt: process.env.NODE_URL_OXT_API,
|
|
|
|
// Esplora (testnet)
|
|
|
|
esplora: process.env.NODE_URL_ESPLORA_API,
|
|
|
|
},
|
|
|
|
/*
|
|
|
|
* Explorer recommended by this Dojo
|
|
|
|
*/
|
|
|
|
explorer: {
|
|
|
|
// Active explorer
|
|
|
|
// Values: oxt | btc_rpc_explorer
|
|
|
|
active: explorerActive,
|
|
|
|
// URI of the explorer
|
|
|
|
uri: explorerUrl,
|
|
|
|
// Password (value required for btc_rpc_explorer)
|
|
|
|
password: explorerPassword
|
|
|
|
},
|
|
|
|
/*
|
|
|
|
* Max number of transactions per address
|
|
|
|
* accepted during fast scan
|
|
|
|
*/
|
|
|
|
addrFilterThreshold: parseInt(process.env.NODE_ADDR_FILTER_THRESHOLD),
|
|
|
|
/*
|
|
|
|
* Pool of child processes
|
|
|
|
* for parallel derivation of addresses
|
|
|
|
* Be careful with these parameters ;)
|
|
|
|
*/
|
|
|
|
addrDerivationPool: {
|
|
|
|
// Min number of child processes always running
|
|
|
|
minNbChildren: parseInt(process.env.NODE_ADDR_DERIVATION_MIN_CHILD),
|
|
|
|
// Max number of child processes allowed
|
|
|
|
maxNbChildren: parseInt(process.env.NODE_ADDR_DERIVATION_MAX_CHILD),
|
|
|
|
// Max duration
|
|
|
|
acquireTimeoutMillis: 60000,
|
|
|
|
// Parallel derivation threshold
|
|
|
|
// (use parallel derivation if number of addresses to be derived
|
|
|
|
// is greater than thresholdParalleDerivation)
|
|
|
|
thresholdParallelDerivation: parseInt(process.env.NODE_ADDR_DERIVATION_THRESHOLD),
|
|
|
|
},
|
|
|
|
/*
|
|
|
|
* PushTx - Scheduler
|
|
|
|
*/
|
|
|
|
txsScheduler: {
|
|
|
|
// Max number of transactions allowed in a single script
|
|
|
|
maxNbEntries: parseInt(process.env.NODE_TXS_SCHED_MAX_ENTRIES),
|
|
|
|
// Max number of blocks allowed in the future
|
|
|
|
maxDeltaHeight: parseInt(process.env.NODE_TXS_SCHED_MAX_DELTA_HEIGHT)
|
|
|
|
},
|
|
|
|
/*
|
|
|
|
* Tracker
|
|
|
|
*/
|
|
|
|
tracker: {
|
|
|
|
// Processing of mempool (periodicity in ms)
|
|
|
|
mempoolProcessPeriod: parseInt(process.env.NODE_TRACKER_MEMPOOL_PERIOD),
|
|
|
|
// Processing of unconfirmed transactions (periodicity in ms)
|
|
|
|
unconfirmedTxsProcessPeriod: parseInt(process.env.NODE_TRACKER_UNCONF_TXS_PERIOD)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|