aboutsummaryrefslogtreecommitdiffstats
path: root/extras/Kuksa_Instance.py
blob: 500e0398c71cff3827be26af0230a179363f2eac (plain)
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
"""
   Copyright 2023 Suchinton Chakravarty

   Licensed under the Apache License, Version 2.0 (the "License");
   you may not use this file except in compliance with the License.
   You may obtain a copy of the License at

       http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing, software
   distributed under the License is distributed on an "AS IS" BASIS,
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   See the License for the specific language governing permissions and
   limitations under the License.
"""

from typing import Optional
import kuksa_client as kuksa
import threading
import time

from extras import config

class KuksaClientSingleton:
    """
    A singleton class that provides a single instance of KuksaClientThread.

    This class is thread-safe and ensures that only one instance of KuksaClientThread is created.

    Attributes:
        _instance (Optional[KuksaClientSingleton]): The instance of the class.
        _lock (threading.Lock): A lock to ensure thread-safety.
        kuksa_config (dict): The configuration for KuksaClientThread.
        token (str): The path to the token file.
        client (KuksaClientThread): The instance of KuksaClientThread.

    Methods:
        instance() -> KuksaClientSingleton: Returns the instance of the class.
        reconnect(config, token) -> KuksaClientThread: Reconnects the client with the given configuration and token.
        get_client() -> Optional[KuksaClientThread]: Returns the client instance.
        get_config() -> dict: Returns the configuration.
        get_token() -> str: Returns the path to the token file.
        status() -> bool: Returns the status of the client connection.
    """

    _instance: Optional["KuksaClientSingleton"] = None
    _lock = threading.Lock()

    @staticmethod
    def instance() -> "KuksaClientSingleton":
        """
        Returns the instance of the class.

        If the instance does not exist, it creates a new instance.

        Returns:
            KuksaClientSingleton: The instance of the class.
        """
        if KuksaClientSingleton._instance is None:
            with KuksaClientSingleton._lock:
                if KuksaClientSingleton._instance is None:
                    KuksaClientSingleton._instance = KuksaClientSingleton()
        return KuksaClientSingleton._instance

    def __init__(self):
        """
        Initializes the class.

        If the instance already exists, it raises an exception.

        It initializes the configuration, token and client instance.
        """
        if KuksaClientSingleton._instance is not None:
            raise Exception("This class is a singleton!")

        self.kuksa_config = config.KUKSA_CONFIG
        self.ws_token = config.WS_TOKEN
        self.grpc_token = config.GRPC_TOKEN
        
        if self.kuksa_config["protocol"] == 'ws':
            self.token = self.ws_token
        if self.kuksa_config["protocol"] == 'grpc':
            self.token = self.grpc_token

        try:
            self.client = kuksa.KuksaClientThread(self.kuksa_config)
            self.client.authorize(self.token)
            self.client.start()
            time.sleep(2)
            if not self.client.checkConnection():
                self.client = None
        except Exception as e:
            print(e)

        KuksaClientSingleton._instance = self

    def reconnect(self, config):
        """
        Reconnects the client with the given configuration and token.

        Args:
            config (dict): The configuration for KuksaClientThread.
            token (str): The path to the token file.

        Returns:
            KuksaClientThread: The instance of KuksaClientThread.
        """
        if self.client:
            self.client.stop()

        if self.kuksa_config["protocol"] == 'ws':
            self.token = self.ws_token
            self.kuksa_config["port"] = "8090"
        if self.kuksa_config["protocol"] == 'grpc':
            self.token = self.grpc_token
            self.kuksa_config["port"] = "55555"
            
        self.client = kuksa.KuksaClientThread(self.kuksa_config)
        self.client.authorize(self.token)
        self.client.start()
        return self.client

    def get_client(self):
        """
        Returns the client instance.

        Returns:
            Optional[KuksaClientThread]: The instance of KuksaClientThread.
        """
        if self.client:
            return self.client
        else:
            return None
        
    def get_config(self):
        """
        Returns the configuration.

        Returns:
            dict: The configuration for KuksaClientThread.
        """
        return self.kuksa_config

    def status(self):
        """
        Returns the status of the client connection.

        Returns:
            bool: The status of the client connection.
        """
        return self.client.checkConnection() if self.client else False

    def __del__(self):
        """
        Stops the client instance.
        """
        if self.client:
            self.client.stop()