2018-12-12 12:54:38 -05:00
|
|
|
import logging
|
|
|
|
import traceback
|
|
|
|
import argparse
|
|
|
|
import importlib
|
2019-12-31 16:33:08 -05:00
|
|
|
from lbry.wallet.server.env import Env
|
|
|
|
from lbry.wallet.server.server import Server
|
2018-12-12 12:54:38 -05:00
|
|
|
|
|
|
|
|
|
|
|
def get_argument_parser():
|
|
|
|
parser = argparse.ArgumentParser(
|
|
|
|
prog="torba-server"
|
|
|
|
)
|
2019-09-13 10:39:05 -04:00
|
|
|
parser.add_argument("spvserver", type=str, help="Python class path to SPV server implementation.",
|
|
|
|
nargs="?", default="lbry.wallet.server.coin.LBC")
|
2018-12-12 12:54:38 -05:00
|
|
|
return parser
|
|
|
|
|
|
|
|
|
|
|
|
def get_coin_class(spvserver):
|
|
|
|
spvserver_path, coin_class_name = spvserver.rsplit('.', 1)
|
|
|
|
spvserver_module = importlib.import_module(spvserver_path)
|
|
|
|
return getattr(spvserver_module, coin_class_name)
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
parser = get_argument_parser()
|
|
|
|
args = parser.parse_args()
|
|
|
|
coin_class = get_coin_class(args.spvserver)
|
2018-12-12 20:12:35 -03:00
|
|
|
logging.basicConfig(level=logging.INFO)
|
2019-12-31 16:33:08 -05:00
|
|
|
logging.info('lbry.server starting')
|
2018-12-12 12:54:38 -05:00
|
|
|
try:
|
|
|
|
server = Server(Env(coin_class))
|
|
|
|
server.run()
|
|
|
|
except Exception:
|
|
|
|
traceback.print_exc()
|
2019-12-31 16:33:08 -05:00
|
|
|
logging.critical('lbry.server terminated abnormally')
|
2018-12-12 12:54:38 -05:00
|
|
|
else:
|
2019-12-31 16:33:08 -05:00
|
|
|
logging.info('lbry.server terminated normally')
|
2018-12-12 12:54:38 -05:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|