forked from equinor/isar
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.py
63 lines (48 loc) · 1.84 KB
/
main.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
import logging
from logging import Logger
from threading import Thread
from typing import List
from dotenv import load_dotenv
from injector import Injector
from isar.apis.api import API
from isar.config.log import setup_logger
from isar.config.settings import settings
from isar.models.communication.queues.queues import Queues
from isar.modules import get_injector
from isar.services.service_connections.mqtt.mqtt_client import MqttClient
from isar.state_machine.state_machine import main
from isar.storage.storage_interface import StorageInterface
from isar.storage.uploader import Uploader
if __name__ == "__main__":
load_dotenv()
setup_logger()
logger: Logger = logging.getLogger("main")
injector: Injector = get_injector()
threads: List[Thread] = []
state_machine_thread: Thread = Thread(
target=main, name="ISAR State Machine", args=[injector], daemon=True
)
threads.append(state_machine_thread)
uploader: Uploader = Uploader(
upload_queue=injector.get(Queues).upload_queue,
storage_handlers=injector.get(List[StorageInterface]),
)
uploader_thread: Thread = Thread(
target=uploader.run, name="ISAR Uploader", daemon=True
)
threads.append(uploader_thread)
if settings.MQTT_ENABLED:
mqtt_client: MqttClient = MqttClient(mqtt_queue=injector.get(Queues).mqtt_queue)
mqtt_thread: Thread = Thread(
target=mqtt_client.run, name="ISAR MQTT Client", daemon=True
)
threads.append(mqtt_thread)
api: API = injector.get(API)
api_thread: Thread = Thread(target=api.run_app, name="ISAR API", daemon=True)
threads.append(api_thread)
for thread in threads:
thread.start()
logger.info(f"Started thread: {thread.name}")
for thread in threads:
thread.join()
logger.info(f"Joined thread: {thread.name}")