115 lines
4.5 KiB
Python
115 lines
4.5 KiB
Python
import copy
|
|
import logging
|
|
import os
|
|
|
|
from bigchaindb.log.configs import SUBSCRIBER_LOGGING_CONFIG as log_config
|
|
|
|
# from functools import reduce
|
|
# PORT_NUMBER = reduce(lambda x, y: x * y, map(ord, 'BigchainDB')) % 2**16
|
|
# basically, the port number is 9984
|
|
|
|
|
|
_base_database_rethinkdb = {
|
|
'host': os.environ.get('BIGCHAINDB_DATABASE_HOST', 'localhost'),
|
|
'port': int(os.environ.get('BIGCHAINDB_DATABASE_PORT', 28015)),
|
|
'name': os.environ.get('BIGCHAINDB_DATABASE_NAME', 'bigchain'),
|
|
}
|
|
|
|
# The following variable is used by `bigchaindb configure` to
|
|
# prompt the user for database values. We cannot rely on
|
|
# _base_database_rethinkdb.keys() or _base_database_mongodb.keys()
|
|
# because dicts are unordered. I tried to configure
|
|
|
|
_database_keys_map = {
|
|
'mongodb': ('host', 'port', 'name', 'replicaset'),
|
|
'rethinkdb': ('host', 'port', 'name')
|
|
}
|
|
|
|
_base_database_mongodb = {
|
|
'host': os.environ.get('BIGCHAINDB_DATABASE_HOST', 'localhost'),
|
|
'port': int(os.environ.get('BIGCHAINDB_DATABASE_PORT', 27017)),
|
|
'name': os.environ.get('BIGCHAINDB_DATABASE_NAME', 'bigchain'),
|
|
'replicaset': os.environ.get('BIGCHAINDB_DATABASE_REPLICASET', 'bigchain-rs'),
|
|
'login': os.environ.get('BIGCHAINDB_DATABASE_LOGIN'),
|
|
'password': os.environ.get('BIGCHAINDB_DATABASE_PASSWORD')
|
|
}
|
|
|
|
_database_rethinkdb = {
|
|
'backend': os.environ.get('BIGCHAINDB_DATABASE_BACKEND', 'rethinkdb'),
|
|
'connection_timeout': 5000,
|
|
'max_tries': 3,
|
|
}
|
|
_database_rethinkdb.update(_base_database_rethinkdb)
|
|
|
|
_database_mongodb = {
|
|
'backend': os.environ.get('BIGCHAINDB_DATABASE_BACKEND', 'mongodb'),
|
|
'connection_timeout': 5000,
|
|
'max_tries': 3,
|
|
'ssl': bool(os.environ.get('BIGCHAINDB_DATABASE_SSL', False)),
|
|
'ca_cert': os.environ.get('BIGCHAINDB_DATABASE_CA_CERT'),
|
|
'certfile': os.environ.get('BIGCHAINDB_DATABASE_CERTFILE'),
|
|
'keyfile': os.environ.get('BIGCHAINDB_DATABASE_KEYFILE'),
|
|
'keyfile_passphrase': os.environ.get('BIGCHAINDB_DATABASE_KEYFILE_PASSPHRASE'),
|
|
'crlfile': os.environ.get('BIGCHAINDB_DATABASE_CRLFILE')
|
|
}
|
|
_database_mongodb.update(_base_database_mongodb)
|
|
|
|
_database_map = {
|
|
'mongodb': _database_mongodb,
|
|
'rethinkdb': _database_rethinkdb
|
|
}
|
|
|
|
config = {
|
|
'server': {
|
|
# Note: this section supports all the Gunicorn settings:
|
|
# - http://docs.gunicorn.org/en/stable/settings.html
|
|
'bind': os.environ.get('BIGCHAINDB_SERVER_BIND') or 'localhost:9984',
|
|
'loglevel': logging.getLevelName(
|
|
log_config['handlers']['console']['level']).lower(),
|
|
'workers': None, # if none, the value will be cpu_count * 2 + 1
|
|
},
|
|
'wsserver': {
|
|
'scheme': os.environ.get('BIGCHAINDB_WSSERVER_SCHEME') or 'ws',
|
|
'host': os.environ.get('BIGCHAINDB_WSSERVER_HOST') or 'localhost',
|
|
'port': int(os.environ.get('BIGCHAINDB_WSSERVER_PORT', 9985)),
|
|
'advertised_scheme': os.environ.get('BIGCHAINDB_WSSERVER_ADVERTISED_SCHEME') or 'ws',
|
|
'advertised_host': os.environ.get('BIGCHAINDB_WSSERVER_ADVERTISED_HOST') or 'localhost',
|
|
'advertised_port': int(os.environ.get('BIGCHAINDB_WSSERVER_ADVERTISED_PORT', 9985)),
|
|
},
|
|
'database': _database_map[
|
|
os.environ.get('BIGCHAINDB_DATABASE_BACKEND', 'rethinkdb')
|
|
],
|
|
'keypair': {
|
|
'public': None,
|
|
'private': None,
|
|
},
|
|
'keyring': [],
|
|
'backlog_reassign_delay': 120,
|
|
'log': {
|
|
'file': log_config['handlers']['file']['filename'],
|
|
'error_file': log_config['handlers']['errors']['filename'],
|
|
'level_console': logging.getLevelName(
|
|
log_config['handlers']['console']['level']).lower(),
|
|
'level_logfile': logging.getLevelName(
|
|
log_config['handlers']['file']['level']).lower(),
|
|
'datefmt_console': log_config['formatters']['console']['datefmt'],
|
|
'datefmt_logfile': log_config['formatters']['file']['datefmt'],
|
|
'fmt_console': log_config['formatters']['console']['format'],
|
|
'fmt_logfile': log_config['formatters']['file']['format'],
|
|
'granular_levels': {},
|
|
'port': log_config['root']['port']
|
|
},
|
|
'graphite': {
|
|
'host': os.environ.get('BIGCHAINDB_GRAPHITE_HOST', 'localhost'),
|
|
},
|
|
'consensus_plugin': os.environ.get('BIGCHAINDB_CONSENSUS_PLUGIN') or None,
|
|
}
|
|
|
|
# We need to maintain a backup copy of the original config dict in case
|
|
# the user wants to reconfigure the node. Check ``bigchaindb.config_utils``
|
|
# for more info.
|
|
_config = copy.deepcopy(config)
|
|
from bigchaindb.core import Bigchain # noqa
|
|
from bigchaindb.version import __version__ # noqa
|
|
|