aboutsummaryrefslogtreecommitdiffstats
path: root/extras/KuksaClient.py
blob: 772fd500643cf5a87a625f8ddd8f9c2642f41855 (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
# Copyright (C) 2023 Suchinton Chakravarty
# Copyright (C) 2024 Konsulko Group
#
# SPDX-License-Identifier: Apache-2.0

import logging
from PyQt6.QtCore import QThread
from PyQt6.QtCore import pyqtSignal
from . import Kuksa_Instance as kuksa_instance
import threading

class KuksaClient(QThread):
    """
    A class to handle sending values to Kuksa.

    Attributes:
    -----------
    stop_flag : bool
        A flag to stop the thread.
    kuksa : kuksa_instance.KuksaClientSingleton.instance()
        An instance of the Kuksa client.
    client : kuksa_instance.KuksaClientSingleton.instance().client
        A client object to interact with the Kuksa server.
    """
    
    sending_values = pyqtSignal()
    finished_sending_values = pyqtSignal()

    def __init__(self, parent=None):
        """
        Constructs all the necessary attributes for the FeedKuksa object.

        Parameters:
        -----------
        parent : QObject
            The parent object of the FeedKuksa object.
        """
        QThread.__init__(self, parent)
        self.stop_flag = False
        self.kuksa = None
        self.client = None

    def run(self):
        """
        Starts the thread and sets the instance of the Kuksa client.
        """
        logging.info("Starting thread")
        self.set_instance()

    def stop(self):
        """
        Stops the thread.
        """
        self.stop_flag = True

        logging.info("Stopping thread")

    def set_instance(self):
        """
        Sets the instance of the Kuksa client.
        """
        self.kuksa = kuksa_instance.KuksaClientSingleton.instance()
        self.client = self.kuksa.get_client()

    def set(self, path=None, value=None, attribute=None):
        """
        Sets VSS value.

        Parameters:
        -----------
        path : str
            The VSS signal path.
        value : str
            The value to be set.
        attribute : str
            The value attribute ("value" or "targetValue" (for actuators)).

        Raises:
        -------
        Exception
            If there is an error setting the value.
        """
        
        if self.client is None:
            #logging.error("Kuksa client is None, try reconnecting")
            return

        if not self.client.checkConnection():
            logging.error("Client is not connected, try reconnecting")
            threading.Thread(target=self.set_instance).start()
            return

        try:
            if attribute is not None:
                self.sending_values.emit()
                self.client.setValue(path, value, attribute)
                self.finished_sending_values.emit()
            else:
                self.sending_values.emit()
                self.client.setValue(path, value)
                self.finished_sending_values.emit()
        except Exception as e:
            logging.error(f"Error sending values to kuksa {e}")
            threading.Thread(target=self.set_instance).start()

    def setValues(self, values: dict[str, any] = None):
        """
        Sets VSS values.

        Parameters:
        -----------
        values : Dict[str, Any]
            The values to be set.

        Raises:
        -------
        Exception
            If there is an error setting the values.
        """
        
        if self.client is None:
            #logging.error("Kuksa client is None, try reconnecting")
            return

        if not self.client.checkConnection():
            logging.error("Client is not connected, try reconnecting")
            threading.Thread(target=self.set_instance).start()
            return

        try:
            self.sending_values.emit()
            self.client.setValues(values)
        except Exception as e:
            logging.error(f"Error sending values to kuksa {e}")
            threading.Thread(target=self.set_instance).start()