2019-06-16 06:06:32 +00:00
|
|
|
'''
|
|
|
|
Onionr - Private P2P Communication
|
|
|
|
|
|
|
|
Initialize Onionr configuration
|
|
|
|
'''
|
|
|
|
'''
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
'''
|
2019-07-30 05:19:22 +00:00
|
|
|
import os, json, base64
|
|
|
|
import config, logger, netcontroller
|
|
|
|
from etc import onionrvalues
|
2019-07-14 00:29:33 +00:00
|
|
|
from logger.settings import *
|
2019-03-09 01:57:44 +00:00
|
|
|
|
2019-09-08 09:48:16 +00:00
|
|
|
def setup_config():
|
2019-05-15 23:25:36 +00:00
|
|
|
config.reload()
|
|
|
|
|
|
|
|
if not os.path.exists(config._configfile):
|
|
|
|
if os.path.exists('static-data/default_config.json'):
|
|
|
|
# this is the default config, it will be overwritten if a config file already exists. Else, it saves it
|
|
|
|
with open('static-data/default_config.json', 'r') as configReadIn:
|
|
|
|
config.set_config(json.loads(configReadIn.read()))
|
2019-03-09 01:57:44 +00:00
|
|
|
|
|
|
|
config.save()
|
|
|
|
|
|
|
|
settings = 0b000
|
|
|
|
if config.get('log.console.color', True):
|
2019-07-14 00:29:33 +00:00
|
|
|
settings = settings | USE_ANSI
|
2019-03-09 01:57:44 +00:00
|
|
|
if config.get('log.console.output', True):
|
2019-07-14 00:29:33 +00:00
|
|
|
settings = settings | OUTPUT_TO_CONSOLE
|
2019-03-09 01:57:44 +00:00
|
|
|
if config.get('log.file.output', True):
|
2019-07-14 00:29:33 +00:00
|
|
|
settings = settings | OUTPUT_TO_FILE
|
|
|
|
set_settings(settings)
|
2019-03-09 01:57:44 +00:00
|
|
|
|
|
|
|
verbosity = str(config.get('log.verbosity', 'default')).lower().strip()
|
|
|
|
if not verbosity in ['default', 'null', 'none', 'nil']:
|
|
|
|
map = {
|
2019-07-14 00:29:33 +00:00
|
|
|
str(LEVEL_DEBUG) : LEVEL_DEBUG,
|
|
|
|
'verbose' : LEVEL_DEBUG,
|
|
|
|
'debug' : LEVEL_DEBUG,
|
|
|
|
str(LEVEL_INFO) : LEVEL_INFO,
|
|
|
|
'info' : LEVEL_INFO,
|
|
|
|
'information' : LEVEL_INFO,
|
|
|
|
str(LEVEL_WARN) : LEVEL_WARN,
|
|
|
|
'warn' : LEVEL_WARN,
|
|
|
|
'warning' : LEVEL_WARN,
|
|
|
|
'warnings' : LEVEL_WARN,
|
|
|
|
str(LEVEL_ERROR) : LEVEL_ERROR,
|
|
|
|
'err' : LEVEL_ERROR,
|
|
|
|
'error' : LEVEL_ERROR,
|
|
|
|
'errors' : LEVEL_ERROR,
|
|
|
|
str(LEVEL_FATAL) : LEVEL_FATAL,
|
|
|
|
'fatal' : LEVEL_FATAL,
|
|
|
|
str(LEVEL_IMPORTANT) : LEVEL_IMPORTANT,
|
|
|
|
'silent' : LEVEL_IMPORTANT,
|
|
|
|
'quiet' : LEVEL_IMPORTANT,
|
|
|
|
'important' : LEVEL_IMPORTANT
|
2019-03-09 01:57:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if verbosity in map:
|
2019-07-14 00:29:33 +00:00
|
|
|
set_level(map[verbosity])
|
2019-03-09 01:57:44 +00:00
|
|
|
else:
|
2019-07-30 05:19:22 +00:00
|
|
|
logger.warn('Verbosity level %s is not valid, using default verbosity.' % verbosity)
|
|
|
|
|
|
|
|
if type(config.get('client.webpassword')) is type(None):
|
|
|
|
config.set('client.webpassword', base64.b16encode(os.urandom(32)).decode('utf-8'), savefile=True)
|
|
|
|
if type(config.get('client.client.port')) is type(None):
|
|
|
|
randomPort = netcontroller.get_open_port()
|
|
|
|
config.set('client.client.port', randomPort, savefile=True)
|
|
|
|
if type(config.get('client.public.port')) is type(None):
|
|
|
|
randomPort = netcontroller.get_open_port()
|
|
|
|
config.set('client.public.port', randomPort, savefile=True)
|
|
|
|
if type(config.get('client.api_version')) is type(None):
|
|
|
|
config.set('client.api_version', onionrvalues.API_VERSION, savefile=True)
|