Source code for edge_st_sdk.edge_client

################################################################################
# COPYRIGHT(c) 2018 STMicroelectronics                                         #
#                                                                              #
# Redistribution and use in source and binary forms, with or without           #
# modification, are permitted provided that the following conditions are met:  #
#   1. Redistributions of source code must retain the above copyright notice,  #
#      this list of conditions and the following disclaimer.                   #
#   2. Redistributions in binary form must reproduce the above copyright       #
#      notice, this list of conditions and the following disclaimer in the     #
#      documentation and/or other materials provided with the distribution.    #
#   3. Neither the name of STMicroelectronics nor the names of its             #
#      contributors may be used to endorse or promote products derived from    #
#      this software without specific prior written permission.                #
#                                                                              #
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"  #
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE    #
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE   #
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE    #
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR          #
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF         #
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS     #
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN      #
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)      #
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE   #
# POSSIBILITY OF SUCH DAMAGE.                                                  #
################################################################################


"""edge_client

The edge_client module contains an interface for creating edge client classes.
"""


# IMPORT

from abc import ABCMeta
from abc import abstractmethod
from enum import Enum


# INTERFACE

[docs]class EdgeClient(object): """The EdgeClient class is an interface for creating edge client classes.""" __metaclass__ = ABCMeta
[docs] @abstractmethod def connect(self): """Connect to the core.""" raise NotImplementedError('You must define "connect()" to use the ' '"EdgeClient" class.')
[docs] @abstractmethod def disconnect(self): """Disconnect from the core.""" raise NotImplementedError('You must define "disconnect()" to use the ' '"EdgeClient" class.')
[docs] @abstractmethod def publish(self, topic, payload, qos): """Publish a new message to the desired topic with the given quality of service. :param topic: Topic name to publish to. :type topic: str :param payload: Payload to publish (JSON formatted string). :type payload: str :param qos: Quality of Service. Could be "0" or "1". :type qos: int """ raise NotImplementedError('You must define "publish()" to use the ' '"EdgeClient" class.')
[docs] @abstractmethod def subscribe(self, topic, qos, callback): """Subscribe to the desired topic with the given quality of service and register a callback to handle the published messages. :param topic: Topic name to publish to. :type topic: str :param qos: Quality of Service. Could be "0" or "1". :type qos: int :param callback: Function to be called when a new message for the subscribed topic comes in. """ raise NotImplementedError('You must define "subscribe()" to use the ' '"EdgeClient" class.')
[docs] @abstractmethod def unsubscribe(self, topic): """Unsubscribe from the desired topic. :param topic: Topic name to unsubscribe from. :type topic: str """ raise NotImplementedError('You must define "unsubscribe()" to use the ' '"EdgeClient" class.')
[docs] @abstractmethod def get_shadow_state(self, callback, timeout_s): """Get the state of the shadow client. Retrieve the device shadow JSON document from the cloud by publishing an empty JSON document to the corresponding shadow topics. :param callback: Function to be called when the response for a shadow request comes back. :param timeout_s: Timeout in seconds to perform the request. :type timeout_s: int """ raise NotImplementedError('You must define "get_shadow()" to use the ' '"EdgeClient" class.')
[docs] @abstractmethod def update_shadow_state(self, payload, callback, timeout_s): """Update the state of the shadow client. Update the device shadow JSON document string on the cloud by publishing the provided JSON document to the corresponding shadow topics. :param payload: JSON document string used to update the shadow JSON document on the cloud. :type payload: json :param callback: Function to be called when the response for a shadow request comes back. :param timeout_s: Timeout in seconds to perform the request. :type timeout_s: int """ raise NotImplementedError('You must define "update_shadow()" to use the ' '"EdgeClient" class.')
[docs] @abstractmethod def delete_shadow_state(self, callback, timeout_s): """Delete the state of the shadow client. Delete the device shadow from the cloud by publishing an empty JSON document to the corresponding shadow topics. :param callback: Function to be called when the response for a shadow request comes back. :param timeout_s: Timeout in seconds to perform the request. :type timeout_s: int """ raise NotImplementedError('You must define "delete_shadow()" to use the ' '"EdgeClient" class.')
[docs] @abstractmethod def add_listener(self, listener): """Add a listener. :param listener: Listener to be added. :type listener: :class:`edge_st_sdk.edge_client.EdgeClientListener` """ raise NotImplementedError('You must define "add_listener()" to use the ' '"EdgeClient" class.')
[docs] @abstractmethod def remove_listener(self, listener): """Remove a listener. :param listener: Listener to be removed. :type listener: :class:`edge_st_sdk.edge_client.EdgeClientListener` """ raise NotImplementedError('You must define "remove_listener()" to use ' 'the "EdgeClient" class.')
@abstractmethod def _update_status(self, new_status): """Update the status of the client. :param new_status: New status. :type new_status: :class:`edge_st_sdk.edge_client.EdgeClientStatus` """ raise NotImplementedError('You must define "_update_client_status()" to ' 'use the "EdgeClient" class.')
[docs]class EdgeClientStatus(Enum): """Status of the client.""" INIT = 'INIT' """Dummy initial status.""" IDLE = 'IDLE' """Waiting for a connection and sending advertising data.""" CONNECTING = 'CONNECTING' """Opening a connection with the client.""" CONNECTED = 'CONNECTED' """Connected to the client.""" DISCONNECTING = 'DISCONNECTING' """Closing the connection to the client.""" UNREACHABLE = 'UNREACHABLE' """The client disappeared without first disconnecting."""
# INTERFACES
[docs]class EdgeClientListener(object): """Interface used by the :class:`edge_st_sdk.edge_client.EdgeClient` class to notify changes of a client's status. """ __metaclass__ = ABCMeta
[docs] @abstractmethod def on_status_change(self, client, new_status, old_status): """To be called whenever a client changes its status. :param client: Client that has changed its status. :type client: :class:`edge_st_sdk.edge_client.EdgeClient` :param new_status: New status. :type new_status: :class:`edge_st_sdk.edge_client.EdgeClientStatus` :param old_status: Old status. :type old_status: :class:`edge_st_sdk.edge_client.EdgeClientStatus` :raises NotImplementedError`: if the method has not been implemented. """ raise NotImplementedError('You must implement "on_status_change()" to ' 'use the "EdgeClientListener" class.')