Browse Source

cleanup

main
Peter Shipley 10 years ago
parent
commit
e1c9198b55
1 changed files with 57 additions and 68 deletions
  1. +57
    -68
      RainEagle/EagleClass.py

+ 57
- 68
RainEagle/EagleClass.py View File

@@ -20,9 +20,7 @@ from warnings import warn
from pprint import pprint from pprint import pprint




api_arg_format = {

}
# api_arg_format = { }


__all__ = ['Eagle', 'RainEagleResponseError', 'to_epoch_1970, to_epoch_2000'] __all__ = ['Eagle', 'RainEagleResponseError', 'to_epoch_1970, to_epoch_2000']


@@ -61,7 +59,7 @@ def _et2d(et) :
converts an ETree to a Dict Tree converts an ETree to a Dict Tree
lists are created for duplicate tag lists are created for duplicate tag


if there are multiple XML of the name name
if there are multiple XML of the same name
an list array is used an list array is used
attrib tags are converted to "tag_name" + "attrib_name" attrib tags are converted to "tag_name" + "attrib_name"


@@ -98,7 +96,7 @@ def _et2d(et) :
return d return d




def twos_comp(val, bits=32):
def _twos_comp(val, bits=32):
"""compute the 2's compliment of int value val""" """compute the 2's compliment of int value val"""
if( (val&(1<<(bits-1))) != 0 ): if( (val&(1<<(bits-1))) != 0 ):
val = val - (1<<bits) val = val - (1<<bits)
@@ -140,6 +138,7 @@ class Eagle(object) :
addr address of device addr address of device
port port on device (default 5002) port port on device (default 5002)
getmac connect to device at start up and get macid (default true) getmac connect to device at start up and get macid (default true)
timeout TCP socket timeout


Currently there is very little error handling ( if any at all ) Currently there is very little error handling ( if any at all )
""" """
@@ -408,25 +407,25 @@ class Eagle(object) :
Get current demand usage summation Get current demand usage summation
On Success returns dict with the values (example): On Success returns dict with the values (example):
'demand' : '0.4980',
'demand_timestamp' : '1394505386',
'demand_units' : 'kW',
'message_confirm_required' : 'N',
'message_confirmed' : 'N',
'message_id' : '0',
'message_priority' : '',
'message_queue' : active',
'message_read' : 'Y',
'message_text' : '',
'message_timestamp' : '946684800',
'meter_status' : 'Connected',
'price' : '0.1400',
'price_label' : 'Set by User',
'price_units' : '$',
'summation_delivered' : '2667.867',
'summation_received' : '37.283',
'summation_units' : 'kWh',
'usage_timestamp' : '1394505386'}
'demand' : '0.4980'
'demand_timestamp' : '1394505386'
'demand_units' : 'kW'
'message_confirm_required' : 'N'
'message_confirmed' : 'N'
'message_id' : '0'
'message_priority' : ''
'message_queue' : active'
'message_read' : 'Y'
'message_text' : ''
'message_timestamp' : '946684800'
'meter_status' : 'Connected'
'price' : '0.1400'
'price_label' : 'Set by User'
'price_units' : '$'
'summation_delivered' : '2667.867'
'summation_received' : '37.283'
'summation_units' : 'kWh'
'usage_timestamp' : '1394505386'


""" """
comm_responce = self._send_http_comm("get_usage_data") comm_responce = self._send_http_comm("get_usage_data")
@@ -442,35 +441,35 @@ class Eagle(object) :
period day|week|month|year period day|week|month|year


On Success returns dict with the values (example): On Success returns dict with the values (example):
'data_period' 'day',
'data_size' '14',
'timestamp[0]' '1394422200',
'timestamp[1]' '1394425800',
'timestamp[2]' '1394429400',
'timestamp[3]' '1394433000',
'timestamp[4]' '1394436600',
'timestamp[5]' '1394440200',
'timestamp[6]' '1394443800',
'timestamp[7]' '1394447400',
'timestamp[8]' '1394451000',
'timestamp[9]' '1394454600',
'timestamp[10]' '1394458200',
'timestamp[11]' '1394461800',
'timestamp[12]' '1394465400',
'timestamp[13]' '1394469000',
'value[0]' '0.429',
'value[1]' '0.426',
'value[2]' '0.422',
'value[3]' '0.627',
'value[4]' '0.735',
'value[5]' '0.193',
'value[6]' '0.026',
'value[7]' '-0.985',
'value[8]' '-1.491',
'value[9]' '-2.196'}
'value[11]' '-1.868',
'value[12]' '-1.330',
'value[13]' '-0.870',
'data_period' 'day'
'data_size' '14'
'timestamp[0]' '1394422200'
'timestamp[1]' '1394425800'
'timestamp[2]' '1394429400'
'timestamp[3]' '1394433000'
'timestamp[4]' '1394436600'
'timestamp[5]' '1394440200'
'timestamp[6]' '1394443800'
'timestamp[7]' '1394447400'
'timestamp[8]' '1394451000'
'timestamp[9]' '1394454600'
'timestamp[10]' '1394458200'
'timestamp[11]' '1394461800'
'timestamp[12]' '1394465400'
'timestamp[13]' '1394469000'
'value[0]' '0.429'
'value[1]' '0.426'
'value[2]' '0.422'
'value[3]' '0.627'
'value[4]' '0.735'
'value[5]' '0.193'
'value[6]' '0.026'
'value[7]' '-0.985'
'value[8]' '-1.491'
'value[9]' '-2.196'
'value[11]' '-1.868'
'value[12]' '-1.330'
'value[13]' '-0.870'


""" """
if period not in ['day', 'week', 'month', 'year'] : if period not in ['day', 'week', 'month', 'year'] :
@@ -479,12 +478,6 @@ class Eagle(object) :
return json.loads(comm_responce) return json.loads(comm_responce)




def get_usage_data(self) :
"""
"""
comm_responce = self._send_http_comm("get_usage_data")
return json.loads(comm_responce)

def get_setting_data(self) : def get_setting_data(self) :
""" """
get settings data get settings data
@@ -528,7 +521,7 @@ class Eagle(object) :


On Success returns dict with the value : On Success returns dict with the value :
'timezone_localTime': '1394527011' 'timezone_localTime': '1394527011'
'timezone_olsonName': 'UTC/GMT',
'timezone_olsonName': 'UTC/GMT'
'timezone_status': '2' 'timezone_status': '2'
'timezone_utcOffset': 'UTC' 'timezone_utcOffset': 'UTC'
'timezone_utcTime': '1394527011' 'timezone_utcTime': '1394527011'
@@ -544,7 +537,7 @@ class Eagle(object) :
get time source for device get time source for device


On Success returns dict with value 'internet' or 'meter' : On Success returns dict with value 'internet' or 'meter' :
'time_source': 'internet'}
'time_source': 'internet'
""" """
comm_responce = self._send_http_comm("get_time_source") comm_responce = self._send_http_comm("get_time_source")
return json.loads(comm_responce) return json.loads(comm_responce)
@@ -592,10 +585,10 @@ class Eagle(object) :
get price for kWh get price for kWh


On Success returns (example): On Success returns (example):
price': '0.1300',
price': '0.1300'
price_label': 'Set by User' or '--' price_label': 'Set by User' or '--'
price_timestamp': '1394524458',
price_units': '$'}
price_timestamp': '1394524458'
price_units': '$'


returns empty dict on Error returns empty dict on Error
""" """
@@ -730,10 +723,6 @@ class Eagle(object) :


return json.loads(comm_responce) return json.loads(comm_responce)






# Support functions # Support functions


def _connect(self) : def _connect(self) :


Loading…
Cancel
Save