@ -20,46 +20,27 @@
* * /
* * /
"""
"""
import logging , logging . handlers
import logging , logging . handlers
import sys , os , signal , argparse
import sys , os , signal , argparse
import httplib , time
import httplib , time
import threading
import threading
import Adafruit_DHT # Adafruit library required for temperature sensing
import iotUtils
import httpServer # python script used to start a http-server to listen for operations (includes the TEMPERATURE global variable)
import xmppServer # python script used to communicate with xmpp server
import mqttListener # python script used to accept messages via mqtt
import datetime
import running_mode
PUSH_INTERVAL = 300 # time interval between successive data pushes in seconds
PUSH_INTERVAL = 5000 # time interval between successive data pushes in seconds
logging_enabled = False
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# Endpoint specific settings to which the data is pushed
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
DC_IP = ' 204.232.188.214 ' #'192.168.57.128'
DC_PORT = 8281
HOST = DC_IP + ' : ' + ` DC_PORT `
DC_ENDPOINT = ' /firealarm/1.0/controller ' #'/firealarm/1.0/'
PUSH_ENDPOINT = DC_ENDPOINT + ' /push_temperature '
REGISTER_ENDPOINT = DC_ENDPOINT + ' /register '
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# Logger defaults
# Logger defaults
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
LOG_FILENAME = " /usr/local/src/RaspberryAgent/logs/RaspberryStats.log "
#LOG_FILENAME = "/usr/local/src/RaspberryAgent/logs/RaspberryStats.log"
LOG_FILENAME = " RaspberryStats.log "
logging_enabled = False
LOG_LEVEL = logging . INFO # Could be e.g. "DEBUG" or "WARNING"
LOG_LEVEL = logging . INFO # Could be e.g. "DEBUG" or "WARNING"
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# Define and parse command line arguments
# Define and parse command line arguments
# If the log file is specified on the command line then override the default
# If the log file is specified on the command line then override the default
@ -67,30 +48,60 @@ LOG_LEVEL = logging.INFO # Could be e.g. "DEBUG" or "WARNING"
parser = argparse . ArgumentParser ( description = " Python service to push RPi info to the Device Cloud " )
parser = argparse . ArgumentParser ( description = " Python service to push RPi info to the Device Cloud " )
parser . add_argument ( " -l " , " --log " , help = " file to write log to (default ' " + LOG_FILENAME + " ' ) " )
parser . add_argument ( " -l " , " --log " , help = " file to write log to (default ' " + LOG_FILENAME + " ' ) " )
help_string = " time interval between successive data pushes (default ' " + str ( PUSH_INTERVAL ) + " ' ) "
help_string_for_data_push_interval = " time interval between successive data pushes (default ' " + str ( PUSH_INTERVAL ) + " ' ) "
parser . add_argument ( " -i " , " --interval " , type = int , help = help_string )
help_string_for_running_mode = " time interval between successive data pushes (default ' " + str ( PUSH_INTERVAL ) + " ' ) "
parser . add_argument ( " -i " , " --interval " , type = int , help = help_string_for_data_push_interval )
parser . add_argument ( " -m " , " --mode " , type = str , help = help_string_for_running_mode )
args = parser . parse_args ( )
args = parser . parse_args ( )
if args . log :
if args . log :
LOG_FILENAME = args . log
LOG_FILENAME = args . log
if args . interval :
if args . interval :
PUSH_INTERVAL = args . interval
PUSH_INTERVAL = args . interval
if args . mode :
running_mode . RUNNING_MODE = args . mode
iotUtils = __import__ ( ' iotUtils ' )
httpServer = __import__ ( ' httpServer ' ) # python script used to start a http-server to listen for operations
# (includes the TEMPERATURE global variable)
mqttListener = __import__ ( ' mqttListener ' ) # python script used to accept messages via mqtt
#xmppServer = __import__('xmppServer') # python script used to communicate with xmpp server
if running_mode . RUNNING_MODE == ' N ' :
Adafruit_DHT = __import__ ( ' Adafruit_DHT ' ) # Adafruit library required for temperature sensing
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# Endpoint specific settings to which the data is pushed
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
DC_ENDPOINT = iotUtils . HTTP_EP . split ( " : " )
DC_IP = DC_ENDPOINT [ 1 ] . replace ( ' // ' , ' ' )
DC_PORT = int ( DC_ENDPOINT [ 2 ] )
DC_ENDPOINT_CONTEXT = iotUtils . CONTROLLER_CONTEXT
PUSH_ENDPOINT = str ( DC_ENDPOINT_CONTEXT ) + ' /push_temperature/ '
REGISTER_ENDPOINT = str ( DC_ENDPOINT_CONTEXT ) + ' /register '
HOST = iotUtils . getDeviceIP ( )
HOST_HTTP_SERVER_PORT = iotUtils . getHTTPServerPort ( )
HOST_AND_PORT = str ( HOST ) + " : " + str ( HOST_HTTP_SERVER_PORT )
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# A class we can use to capture stdout and sterr in the log
# A class we can use to capture stdout and sterr in the log
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
class IOTLogger ( object ) :
class IOTLogger ( object ) :
def __init__ ( self , logger , level ) :
def __init__ ( self , logger , level ) :
""" Needs a logger and a logger level. """
""" Needs a logger and a logger level. """
self . logger = logger
self . logger = logger
self . level = level
self . level = level
def write ( self , message ) :
def write ( self , message ) :
if message . rstrip ( ) != " " : # Only log if there is a message (not just a new line)
if message . rstrip ( ) != " " : # Only log if there is a message (not just a new line)
self . logger . log ( self . level , message . rstrip ( ) )
self . logger . log ( self . level , message . rstrip ( ) )
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@ -100,17 +111,18 @@ class IOTLogger(object):
# making a new file at midnight and keeping the last 3 day's data
# making a new file at midnight and keeping the last 3 day's data
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
def configureLogger ( loggerName ) :
def configureLogger ( loggerName ) :
logger = logging . getLogger ( loggerName )
logger = logging . getLogger ( loggerName )
logger . setLevel ( LOG_LEVEL ) # Set the log level to LOG_LEVEL
logger . setLevel ( LOG_LEVEL ) # Set the log level to LOG_LEVEL
handler = logging . handlers . TimedRotatingFileHandler ( LOG_FILENAME , when = " midnight " , backupCount = 3 ) # Handler that writes to a file,
handler = logging . handlers . TimedRotatingFileHandler ( LOG_FILENAME , when = " midnight " ,
# ~~~make new file at midnight and keep 3 backups
backupCount = 3 ) # Handler that writes to a file,
formatter = logging . Formatter ( ' %(asctime)s %(levelname)-8s %(message)s ' ) # Format each log message like this
# ~~~make new file at midnight and keep 3 backups
handler . setFormatter ( formatter ) # Attach the formatter to the handler
formatter = logging . Formatter ( ' %(asctime)s %(levelname)-8s %(message)s ' ) # Format each log message like this
logger . addHandler ( handler ) # Attach the handler to the logger
handler . setFormatter ( formatter ) # Attach the formatter to the handler
logger . addHandler ( handler ) # Attach the handler to the logger
if ( logging_enabled ) :
sys . stdout = IOTLogger ( logger , logging . INFO ) # Replace stdout with logging to file at INFO level
if ( logging_enabled ) :
sys . stderr = IOTLogger ( logger , logging . ERROR ) # Replace stderr with logging to file at ERROR level
sys . stdout = IOTLogger ( logger , logging . INFO ) # Replace stdout with logging to file at INFO level
sys . stderr = IOTLogger ( logger , logging . ERROR ) # Replace stderr with logging to file at ERROR level
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@ -118,86 +130,68 @@ def configureLogger(loggerName):
# This method registers the DevieIP in the Device-Cloud
# This method registers the DevieIP in the Device-Cloud
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
def registerDeviceIP ( ) :
def registerDeviceIP ( ) :
dcConncection = httplib . HTTPConnection ( DC_IP , DC_PORT )
dcConncection = httplib . HTTPConnection ( DC_IP , DC_PORT )
dcConncection . set_debuglevel ( 1 )
dcConncection . set_debuglevel ( 1 )
dcConncection . connect ( )
dcConncection . connect ( )
registerURL = str ( REGISTER_ENDPOINT ) + ' / ' + str ( iotUtils . DEVICE_OWNER ) + ' / ' + str ( iotUtils . DEVICE_ID ) + ' / ' + \
registerURL = REGISTER_ENDPOINT + ' / ' + iotUtils . DEVICE_OWNER + ' / ' + iotUtils . DEVICE_ID + ' / ' + iotUtils . HOST_NAME
str ( HOST ) + ' / ' + str ( HOST_HTTP_SERVER_PORT ) + ' / '
dcConncection . putrequest ( ' POST ' , registerURL )
dcConncection . putrequest ( ' POST ' , registerURL )
dcConncection . putheader ( ' Authorization ' , ' Bearer ' + iotUtils . AUTH_TOKEN )
dcConncection . putheader ( ' Authorization ' , ' Bearer ' + iotUtils . AUTH_TOKEN )
dcConncection . endheaders ( )
dcConncection . endheaders ( )
dcResponse = dcConncection . getresponse ( )
print ' ~~~~~~~~~~~~~~~~~~~~~~~~ Device Registration ~~~~~~~~~~~~~~~~~~~~~~~~~ '
print ' ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ '
dcResponse = dcConncection . getresponse ( )
print ( ' RASPBERRY_STATS: ' + str ( registerURL ) )
print ( ' RASPBERRY_STATS: ' + str ( dcResponse . status ) )
print ' ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ '
print ( ' RASPBERRY_STATS: ' + str ( dcResponse . reason ) )
print ( ' RASPBERRY_STATS: ' + str ( registerURL ) )
print ( ' RASPBERRY_STATS: Response Message ' )
print ( ' RASPBERRY_STATS: ' + str ( dcResponse . status ) )
print str ( dcResponse . msg )
print ( ' RASPBERRY_STATS: ' + str ( dcResponse . reason ) )
print ( ' RASPBERRY_STATS: Response Message ' )
dcConncection . close ( )
print str ( dcResponse . msg )
print ' ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ '
dcConncection . close ( )
print ' ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ '
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# This method connects to the Device-Cloud and pushes data
# This method connects to the Device-Cloud and pushes data
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
def connectAndPushData ( ) :
def connectAndPushData ( ) :
dcConnection = httplib . HTTPConnection ( DC_IP , DC_PORT )
dcConnection = httplib . HTTPConnection ( DC_IP , DC_PORT )
dcConnection . set_debuglevel ( 1 )
dcConnection . set_debuglevel ( 1 )
dcConnection . connect ( )
dcConnection . connect ( )
request = dcConnection . putrequest ( ' POST ' , PUSH_ENDPOINT )
request = dcConnection . putrequest ( ' POST ' , PUSH_ENDPOINT )
dcConnection . putheader ( ' Authorization ' , ' Bearer ' + iotUtils . AUTH_TOKEN )
headers = { }
dcConnection . putheader ( ' Content-Type ' , ' application/json ' )
headers [ ' Authorization ' ] = ' Bearer ' + iotUtils . AUTH_TOKEN
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
headers [ ' Content-Type ' ] = ' application/json '
### Read the Temperature and Load info of RPi and construct payload
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
### Read the Temperature and Load info of RPi and construct payload
rPiTemperature = iotUtils . LAST_TEMP # Push the last read temperature value
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
PUSH_DATA = iotUtils . DEVICE_INFO + iotUtils . DEVICE_IP . format ( ip = HOST_AND_PORT ) + iotUtils . DEVICE_DATA . format (
temperature = rPiTemperature )
# rPiTemperature=getCPUTemp() # Can be used if required to push CPU Temperature
PUSH_DATA + = ' } '
# rPiLoad = getCPULoad() # Can be used if required to push CPU Load
dcConnection . putheader ( ' Content-Length ' , len ( PUSH_DATA ) )
dcConnection . endheaders ( )
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
print PUSH_DATA
rPiTemperature = iotUtils . LAST_TEMP # Push the last read temperature value
print ' ~~~~~~~~~~~~~~~~~~~~~~~~ Pushing Device-Data ~~~~~~~~~~~~~~~~~~~~~~~~~ '
PUSH_DATA = iotUtils . DEVICE_INFO + iotUtils . DEVICE_IP . format ( ip = iotUtils . HOST_NAME ) + iotUtils . DEVICE_DATA . format ( temperature = rPiTemperature )
PUSH_DATA + = ' } '
dcConnection . send ( PUSH_DATA ) # Push the data
dcResponse = dcConnection . getresponse ( )
# print PUSH_DATA
print ' ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ '
headers [ ' Content-Length ' ] = len ( PUSH_DATA )
print ( ' RASPBERRY_STATS: ' + str ( dcResponse . status ) )
print ' ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ '
print ( ' RASPBERRY_STATS: ' + str ( dcResponse . reason ) )
print ( ' RASPBERRY_STATS: Response Message ' )
for k in headers :
print str ( dcResponse . msg )
dcConnection . putheader ( k , headers [ k ] )
print ' ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ '
dcConnection . endheaders ( )
dcConnection . close ( )
print ' ~~~~~~~~~~~~~~~~~~~~~~~~ Pushing Device-Data ~~~~~~~~~~~~~~~~~~~~~~~~~ '
if ( dcResponse . status == 409 or dcResponse . status == 412 ) :
print ' RASPBERRY_STATS: Re-registering Device IP '
dcConnection . send ( PUSH_DATA ) # Push the data
registerDeviceIP ( )
dcResponse = dcConnection . getresponse ( )
print ' ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ '
print ( ' RASPBERRY_STATS: ' + str ( dcResponse . status ) )
print ( ' RASPBERRY_STATS: ' + str ( dcResponse . reason ) )
print ( ' RASPBERRY_STATS: Response Message ' )
print str ( dcResponse . msg )
print ' ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ '
dcConnection . close ( )
if ( dcResponse . status == 409 or dcResponse . status == 412 ) :
print ' RASPBERRY_STATS: Re-registering Device IP '
registerDeviceIP ( )
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
### ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@ -205,36 +199,38 @@ def connectAndPushData():
# This is a Thread object for reading temperature continuously
# This is a Thread object for reading temperature continuously
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
class TemperatureReaderThread ( object ) :
class TemperatureReaderThread ( object ) :
def __init__ ( self , interval = 3 ) :
def __init__ ( self ) :
self . interval = interval
if running_mode . RUNNING_MODE == ' N ' :
self . interval = iotUtils . TEMPERATURE_READING_INTERVAL_REAL_MODE
else :
self . interval = iotUtils . TEMPERATURE_READING_INTERVAL_VIRTUAL_MODE
thread = threading . Thread ( target = self . run , args = ( ) )
thread = threading . Thread ( target = self . run , args = ( ) )
thread . daemon = True # Daemonize thread
thread . daemon = True # Daemonize thread
thread . start ( ) # Start the execution
thread . start ( ) # Start the execution
def run ( self ) :
def run ( self ) :
TEMP_PIN = 4
TEMP_SENSOR_TYPE = 11
# Try to grab a sensor reading. Use the read_retry method which will retry up
# Try to grab a sensor reading. Use the read_retry method which will retry up
# to 15 times to get a sensor reading (waiting 2 seconds between each retry).
# to 15 times to get a sensor reading (waiting 2 seconds between each retry).
while True :
while True :
try :
try :
humidity , temperature = Adafruit_DHT . read_retry ( TEMP_SENSOR_TYPE , TEMP_PIN )
if running_mode . RUNNING_MODE == ' N ' :
humidity , temperature = Adafruit_DHT . read_retry ( iotUtils . TEMP_SENSOR_TYPE , iotUtils . TEMP_PIN )
else :
humidity , temperature = iotUtils . generateRandomTemperatureAndHumidityValues ( )
if temperature != iotUtils . LAST_TEMP :
if temperature != iotUtils . LAST_TEMP :
iotUtils . LAST_TEMP = temperature
iotUtils . LAST_TEMP = temperature
connectAndPushData ( )
connectAndPushData ( )
iotUtils . LAST_TEMP = temperature
iotUtils . LAST_TEMP = temperature
print ' RASPBERRY_STATS: Temp= {0:0.1f} *C Humidity= {1:0.1f} % ' . format ( temperature , humidity )
print ' RASPBERRY_STATS: Temp= {0:0.1f} *C Humidity= {1:0.1f} % ' . format ( temperature , humidity )
except Exception , e :
except Exception , e :
print " RASPBERRY_STATS: Exception in TempReaderThread: Could not successfully read Temperature "
print " RASPBERRY_STATS: Exception in TempReaderThread: Could not successfully read Temperature "
print ( " RASPBERRY_STATS: " + str ( e ) )
print ( " RASPBERRY_STATS: " + str ( e ) )
print ' ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ '
print ' ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ '
pass
pass
time . sleep ( self . interval )
time . sleep ( self . interval )
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@ -246,9 +242,9 @@ class TemperatureReaderThread(object):
class UtilsThread ( object ) :
class UtilsThread ( object ) :
def __init__ ( self ) :
def __init__ ( self ) :
thread = threading . Thread ( target = self . run , args = ( ) )
thread = threading . Thread ( target = self . run , args = ( ) )
thread . daemon = True # Daemonize thread
thread . daemon = True # Daemonize thread
thread . start ( ) # Start the execution
thread . start ( ) # Start the execution
def run ( self ) :
def run ( self ) :
iotUtils . main ( )
iotUtils . main ( )
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@ -262,13 +258,22 @@ class UtilsThread(object):
class ListenHTTPServerThread ( object ) :
class ListenHTTPServerThread ( object ) :
def __init__ ( self ) :
def __init__ ( self ) :
thread = threading . Thread ( target = self . run , args = ( ) )
thread = threading . Thread ( target = self . run , args = ( ) )
thread . daemon = True # Daemonize thread
thread . daemon = True # Daemonize thread
thread . start ( ) # Start the execution
thread . start ( ) # Start the execution
def run ( self ) :
def run ( self ) :
httpServer . main ( )
httpServer . main ( )
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
def get_now ( ) :
" get the current date and time as a string "
return datetime . datetime . now ( ) . strftime ( ' % Y- % m- %d % H: % M: % S ' )
def sigterm_handler ( _signo , _stack_frame ) :
" When sysvinit sends the TERM signal, cleanup before exiting. "
print ( " [] received signal {} , exiting... " . format ( _signo ) )
sys . exit ( 0 )
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@ -277,11 +282,12 @@ class ListenHTTPServerThread(object):
class ListenXMPPServerThread ( object ) :
class ListenXMPPServerThread ( object ) :
def __init__ ( self ) :
def __init__ ( self ) :
thread = threading . Thread ( target = self . run , args = ( ) )
thread = threading . Thread ( target = self . run , args = ( ) )
thread . daemon = True # Daemonize thread
thread . daemon = True # Daemonize thread
thread . start ( ) # Start the execution
thread . start ( ) # Start the execution
def run ( self ) :
def run ( self ) :
xmppServer . main ( )
pass
#xmppServer.main()
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@ -292,41 +298,41 @@ class ListenXMPPServerThread(object):
class ListenMQTTThread ( object ) :
class ListenMQTTThread ( object ) :
def __init__ ( self ) :
def __init__ ( self ) :
thread = threading . Thread ( target = self . run , args = ( ) )
thread = threading . Thread ( target = self . run , args = ( ) )
thread . daemon = True # Daemonize thread
thread . daemon = True # Daemonize thread
thread . start ( ) # Start the execution
thread . start ( ) # Start the execution
def run ( self ) :
def run ( self ) :
mqttListener . main ( )
mqttListener . main ( )
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
signal . signal ( signal . SIGTERM , sigterm_handler )
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# The Main method of the RPi Agent
# The Main method of the RPi Agent
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
def main ( ) :
def main ( ) :
configureLogger ( " WSO2IOT_RPiStats " )
configureLogger ( " WSO2IOT_RPiStats " )
# iotUtils.setUpGPIOPins()
if running_mode . RUNNING_MODE == ' N ' :
iotUtils . setUpGPIOPins ( )
UtilsThread ( )
UtilsThread ( )
registerDeviceIP ( ) # Call the register endpoint and register Device IP
registerDeviceIP ( ) # Call the register endpoint and register Device IP
TemperatureReaderThread ( ) # initiates and runs the thread to continuously read temperature from DHT Sensor
TemperatureReaderThread ( ) # initiates and runs the thread to continuously read temperature from DHT Sensor
ListenHTTPServerThread ( ) # starts an HTTP Server that listens for operational commands to switch ON/OFF Led
ListenHTTPServerThread ( ) # starts an HTTP Server that listens for operational commands to switch ON/OFF Led
ListenXMPPServerThread ( )
# ListenXMPPServerThread()
ListenMQTTThread ( )
# ListenMQTTThread()
while True :
while True :
try :
try :
if iotUtils . LAST_TEMP > 0 : # Push data only if there had been a successful temperature read
if iotUtils . LAST_TEMP > 0 : # Push data only if there had been a successful temperature read
connectAndPushData ( ) # Push Sensor (Temperature) data to WSO2 BAM
connectAndPushData ( ) # Push Sensor (Temperature) data to WSO2 BAM
time . sleep ( PUSH_INTERVAL )
time . sleep ( PUSH_INTERVAL )
except ( KeyboardInterrupt , Exception ) as e :
except ( KeyboardInterrupt , Exception ) as e :
print " RASPBERRY_STATS: Exception in RaspberryAgentThread (either KeyboardInterrupt or Other) "
print " RASPBERRY_STATS: Exception in RaspberryAgentThread (either KeyboardInterrupt or Other) "
print ( " RASPBERRY_STATS: " + str ( e ) )
print ( " RASPBERRY_STATS: " + str ( e ) )
print ' ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ '
print ' ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ '
pass
pass
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
if __name__ == " __main__ " :
if __name__ == " __main__ " :
main ( )
main ( )