-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathship_log.py
127 lines (107 loc) · 5.19 KB
/
ship_log.py
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
import requests # pip3 install requests
from datetime import datetime
import time
from class_database_mgt import DatabaseManager
from class_config_mgt import ConfigManager
import logging
# Set up logging
logging.basicConfig(format="%(asctime)s %(message)s", level=logging.INFO)
logger = logging.getLogger(__name__)
from class_file_lock import FileLock
class logShipping:
@staticmethod
def transfer_to_central_log(db_manager):
# Connect to the local SQLite database
db_manager = DatabaseManager('measurement.db')
config_manager = ConfigManager("config.json")
if not config_manager.is_registered():
logger.info(f"Not registered")
url = 'http://www.carbonactive.org/cgi-bin/register_device.py'
try:
logger.info(f"Not registered")
response = requests.get(url)
response.raise_for_status() # This will raise an HTTPError for bad responses (4xx or 5xx)
# You can now process the response if needed
device_data = response.json() # Or response.text if it's not JSON
# Do something with device_data
logger.info(device_data)
config_manager.set_registered()
config_manager.set_device_id(device_data["device_id"])
db_manager.update_device_id(device_data["device_id"])
except requests.exceptions.HTTPError as http_err:
logger.error(f"HTTP error occurred: {http_err}")
except Exception as err:
logger.error(f"An error occurred: {err}")
# Query local database for new entries
new_entries = db_manager.select_measurements_by_transferred(0)
logger.info(f"Number of new entries to transfer: {len(new_entries)}")
# Send new entries to central log
lock = FileLock("logShipping", lock_dir='locks') # Use a dedicated directory for lock files
locked_or_waiting=lock.get_lock_status()
if locked_or_waiting:
print(f"locked files are {lock.get_lock_files}")
return
if not lock.acquire_lock(wait=False):
return false
for entry in new_entries:
logger.info(entry)
locked_or_waiting=lock.get_lock_status()
if locked_or_waiting:
print(f"locked files are {lock.get_lock_files}")
lock.release_lock(force=True)
return
data = {
'device_id': entry['device_id'],
'date': entry['date'],
'sensor': entry['sensor'],
'latitude': entry['latitude'],
'longitude': entry['longitude'],
'type': entry['type'],
'value': entry['value']
}
#url = 'http://192.168.1.162:8000/cgi-bin/sensor_data_logger.py'
#url = 'http://192.168.1.162:5000/sensor_data'
url = 'http://www.carbonactive.org/cgi-bin/sensor_data_logger.py'
try:
response = requests.post(url, json=data)
logger.info(f"Response status code: {response.status_code}")
if response.status_code == 200:
logger.info(f"Entry ID {entry['id']} and value {entry['value']} transferred successfully")
try:
# Mark the transferred entries in the local database
db_manager.update_measurements_to_transferred(entry['id'])
except Exception as e:
logger.error(f"Error updating transfer column {e}")
logger.error(f"Transferring data: {data}")
db_manager.conn.commit()
logger.info("Data transferred successfully to central log")
else:
logger.error(f"Failed to transfer data to central log: {response.text}, url = {url}")
logger.error(f"Transferring data: {data}")
lock.release_lock(force=True)
break # Exit loop on failure to transfer
except requests.exceptions.RequestException as e:
logger.error(f"Exception occurred during data transfer: {e}")
logger.error("Server might be down. Retrying later ...")
lock.release_lock(force=True)
break # Exit loop on network issue
print("Next loop")
lock.release_lock(force=True)
print("Exit loop")
# Close connections
#db_manager.conn.close()
# Call the function to start transferring entries to the central log
if __name__ == "__main__":
# Make sure lock file is released before starting
lock = FileLock("logShipping", lock_dir='locks') # Use a dedicated directory for lock files
lock.release_lock(force=True)
# Connect to the local SQLite database
db_manager = DatabaseManager('measurement.db')
try:
while True:
logShipping.transfer_to_central_log(db_manager)
logger.info("Waiting ....")
time.sleep(15)
finally:
# Close connections
db_manager.conn.close()