-
Notifications
You must be signed in to change notification settings - Fork 184
/
Copy pathenv_log_final.py
113 lines (90 loc) · 3.55 KB
/
env_log_final.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
#!/usr/bin/env python
'''
FILE NAME
env_log.py
1. WHAT IT DOES
Takes a reading from a DHT sensor and records the values in an SQLite3 database using a Raspberry Pi.
2. REQUIRES
* Any Raspberry Pi
* A DHT sensor
* A 10kOhm resistor
* Jumper wires
3. ORIGINAL WORK
Raspberry Full stack 2015, Peter Dalmaris
4. HARDWARE
D17: Data pin for sensor
5. SOFTWARE
Command line terminal
Simple text editor
Libraries:
import sqlite3
import sys
import Adafruit_DHT
6. WARNING!
None
7. CREATED
8. TYPICAL OUTPUT
No text output. Two new records are inserted in the database when the script is executed
// 9. COMMENTS
--
// 10. END
'''
import os
from twilio.rest import Client
import sqlite3
import sys
#import Adafruit_DHT
import board
import adafruit_dht
from time import gmtime, strftime
import gspread
from oauth2client.service_account import ServiceAccountCredentials
import RPi.GPIO as GPIO ## Import GPIO Library
def text_alert(device_id, temp, hum):
account_sid = os.environ["TWILIO_ACCOUNT_SID"]
auth_token = os.environ["TWILIO_AUTH_TOKEN"]
my_twilio_phone_number = os.environ["TWILIO_PHONE_NUMBER"]
receive_phone_number = os.environ["MY_PHONE_NUMBER"]
deg_sign = u"\N{DEGREE SIGN}"
report = f'Device {device_id} reported a temperature of {temp}{deg_sign}C and {hum}% humidity.'
client = Client(account_sid, auth_token)
client.messages.create(to = receive_phone_number,
from_ = my_twilio_phone_number,
body = report)
def log_values(sensor_id, temp, hum):
GPIO.output(pin, GPIO.HIGH) ## Turn on GPIO pin (HIGH)
conn=sqlite3.connect('/var/www/lab_app/lab_app.db') #It is important to provide an
#absolute path to the database
#file, otherwise Cron won't be
#able to find it!
curs=conn.cursor()
curs.execute("""INSERT INTO temperatures values(datetime(CURRENT_TIMESTAMP, 'localtime'), (?), (?))""", (sensor_id,temp)) #This will store the new record at UTC
curs.execute("""INSERT INTO humidities values(datetime(CURRENT_TIMESTAMP, 'localtime'), (?), (?))""", (sensor_id,hum)) #This will store the new record at UTC
conn.commit()
conn.close()
# Create a new record in the Google Sheet
scope = ['https://spreadsheets.google.com/feeds','https://www.googleapis.com/auth/drive']
creds = ServiceAccountCredentials.from_json_keyfile_name('/var/www/lab_app/raspberry-pi-full-stack-1-f37054328cf5.json', scope)
client = gspread.authorize(creds)
sheet = client.open('Temperature and Humidity').sheet1
row = [strftime("%Y-%m-%d %H:%M:%S", gmtime()),sensor_id,round(temp,2),round(hum,2)]
sheet.append_row(row)
#text_alert(sensor_id, temp, hum)
GPIO.output(pin, GPIO.LOW) ## Turn off GPIO pin (LOW)
GPIO.setwarnings(False)
pin = 4 ## We're working with GPIO pin 4 (board pin 7)
GPIO.setup(pin, GPIO.OUT) ## Set pin 7 to OUTPUT
#humidity, temperature = Adafruit_DHT.read_retry(Adafruit_DHT.AM2302, 17)
dhtDevice = adafruit_dht.DHT22(board.D17)
temperature = dhtDevice.temperature
humidity = dhtDevice.humidity
# If you don't have a sensor but still wish to run this program, comment out all the
# sensor related lines, and uncomment the following lines (these will produce random
# numbers for the temperature and humidity variables):
# import random
# humidity = random.randint(1,100)
# temperature = random.randint(10,30)
if humidity is not None and temperature is not None:
log_values("1", temperature, humidity)
else:
log_values("1", -999, -999)