summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--bazarr/app/app.py1
-rw-r--r--bazarr/app/server.py39
2 files changed, 32 insertions, 8 deletions
diff --git a/bazarr/app/app.py b/bazarr/app/app.py
index f70d1d895..826f4ea62 100644
--- a/bazarr/app/app.py
+++ b/bazarr/app/app.py
@@ -1,7 +1,6 @@
# coding=utf-8
from flask import Flask, redirect
-import os
from flask_cors import CORS
from flask_socketio import SocketIO
diff --git a/bazarr/app/server.py b/bazarr/app/server.py
index b80b35cac..38664bc69 100644
--- a/bazarr/app/server.py
+++ b/bazarr/app/server.py
@@ -4,8 +4,10 @@ import warnings
import logging
import os
import io
+import errno
from waitress.server import create_server
+from time import sleep
from api import api_bp_list
from .ui import ui_bp
@@ -31,16 +33,39 @@ class Server:
# Mute Python3 BrokenPipeError
warnings.simplefilter("ignore", BrokenPipeError)
- self.server = create_server(app,
- host=str(settings.general.ip),
- port=int(args.port) if args.port else int(settings.general.port),
- threads=100)
+ self.server = None
+ self.connected = False
+ self.address = str(settings.general.ip)
+ self.port = int(args.port) if args.port else int(settings.general.port)
+
+ while not self.connected:
+ sleep(0.1)
+ self.configure_server()
+
+ def configure_server(self):
+ try:
+ self.server = create_server(app,
+ host=self.address,
+ port=self.port,
+ threads=100)
+ self.connected = True
+ except OSError as error:
+ if error.errno == errno.EADDRNOTAVAIL:
+ logging.exception("BAZARR cannot bind to specified IP, trying with default (0.0.0.0)")
+ self.address = '0.0.0.0'
+ self.connected = False
+ elif error.errno == errno.EADDRINUSE:
+ logging.exception("BAZARR cannot bind to specified TCP port, trying with default (6767)")
+ self.port = '6767'
+ self.connected = False
+ else:
+ logging.exception("BAZARR cannot start because of unhandled exception.")
+ self.shutdown()
def start(self):
try:
- logging.info(
- 'BAZARR is started and waiting for request on http://' + str(settings.general.ip) + ':' + (str(
- args.port) if args.port else str(settings.general.port)) + str(base_url))
+ logging.info(f'BAZARR is started and waiting for request on http://{self.server.effective_host}:'
+ f'{self.server.effective_port}')
try:
self.server.run()
except Exception: