A simple python agent connecting to Cumulocity via MQTT
- Install python 3.x
- Install libraries from requirements.txt
- Create a folder ".c8y-agent" in your home directory and copy the agent.ini from the config folder there
- Set the correct bootstrap password (If you do not know it ask support@cumulocity.com)
- Upload the smartrest.json to the SmartREST templates in your tenant (you can use the import functionality)
The agent can be started
python main.py start
stopped
python main.py stop
and restarted
python main.py restart
You can also run the agent with debug which will not create the daemon and run it in the process directly
python main.py debug
The agent uses normal device bootstrap. The serial that is used for bootstrapping is printed at the start of the agent. The credentials are later stored in the agent.ini file. To re-register the agent to a different tenant you can simply delete those lines.
The agent knows three types of classes that it will automatically load and include from the "agentmodules" directory.
-
Sensors
class Sensor: __metaclass__ = ABCMeta def __init__(self, serial): self.serial = serial ''' Returns a list of SmartREST messages. Will be called every iteration of the main loop. ''' @abstractmethod def getSensorMessages(self): pass
Sensors are periodically polled by the main loop and published.
-
Listeners
class Listener: __metaclass__ = ABCMeta def __init__(self, serial, agent): self.serial = serial self.agent = agent ''' Callback that is executed for any operation received ''' @abstractmethod def handleOperation(self, message): pass ''' Returns a list of supported operations ''' @abstractmethod def getSupportedOperations(self): pass ''' Returns a list of supported SmartREST templates (X-Ids) ''' @abstractmethod def getSupportedTemplates(self): pass
Listeners are called whenever there is a message received on a subscribed topic.
-
Initializers
class Initializer: __metaclass__ = ABCMeta def __init__(self, serial): self.serial = serial ''' Returns a list of SmartREST messages. Will be called at the start of the agent ''' @abstractmethod def getMessages(self): pass
Initializers are only called once at the start of the agent.
You can take a look at the two example modules for how it can be used.
The logfile can be found in the .c8y-agent directory that you created
I tested the agent so far only under Ubuntu 16.04 x64 with python 3.5.2