-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME.txt
114 lines (93 loc) · 3.64 KB
/
README.txt
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
dustnode-dustpi-gpio
====================
This is a daemon, which reads values from the dust sensor[1] and sends
the collected data home to the dustmap-server[2].
It was coded and tested on a raspberry-pi (hence the name dustpi) but
schould run on any linux system which has GPIO-ports[3] and can run
node.js[4].
Hardware
--------
Needed hardware:
- raspberry-pi
- the dust sensor[1]
- 2 resistors (2kΩ & 3kΩ)
- some cables
RaspberryPi Dust sensor
+-------------+ +-----------+
| | | |
| 5V -+---------------+- 3 |
| | | |
| GND -+-------+-------+- 1 |
| | | | |
| | ▉ 3kΩ | |
| | ▉ | |
| | | | |
| GPIO -+-------+ | |
| | | | |
| | ▉ 2kΩ | |
| | ▉ | |
| | | | |
| | +-------+- 4 |
| | | |
+-------------+ +-----------+
See the raspberrypi documentation on which pins you can use - i use those:
P1-02 ... 5V
P1-06 ... GND
P1-07 ... GPIO ( gpio_pin=4 )
Installation
------------
pi@dust-pi ~ $ git clone https://github.com/hoegaarden/dustnode-dustpi-gpio.git
pi@dust-pi ~ $ cd dustnode-dustpi-gpio
pi@dust-pi ~/dustnode-dustpi-gpio $ npm install
pi@dust-pi ~/dustnode-dustpi-gpio $ sudo ln -s `pwd`/extra/init.sh /etc/init.d/dustnode
pi@dust-pi ~/dustnode-dustpi-gpio $ sudo update-rc.d dustnode defaults
pi@dust-pi ~/dustnode-dustpi-gpio $ sudo cp extra/sudoers /etc/sudoers.d/dustnode
pi@dust-pi ~/dustnode-dustpi-gpio $ sudo /etc/init.d/dustnode start
Priviliges
----------
In the default configuration the daemon runs as nobody:nogroup. The
setup and teardown of the GPIO-port needs superuser priviliges. So for
those two cases the daemon calls itself via sudo to get the permission
to setup the port at the beginning and free all resources again at the
end. Hence the sudoers stuff ...
You can change the user/group which runs the daemon either in the
init-script or in /etc/default/dustnode.
Configuration
-------------
The configuration is should be a node-module exporting an object. By
now following keys get evaluated:
'gpio_pin'
to which GPIO-pin the dust sensor is connected
'sample_time'
the time (in seconds) we listen to the sensor and then calculate
the particel conentration for
'station_id'
identifier for this station - go ask anybody at dustmap and you'll
get an id
'station_pass'
doesn't really do anything by now but should be coming soon
'socket_path'
if defined, the daemon tries to create an unix socket and attaches
a repl to it - you can connect via "netcat -U <socket_path>" and
inspect some internals of the daemon (mostly for debugging ...)
'url_opts'
options for http.request[5] - where to send the data to
Bugs
----
This is the first demo. There are many bugs and no tests. Hopefully
this changes soon ...
TODO
----
(in no special order ...)
- error checking / handling
- test
- split into modules
- write better documentation
- write hardware documentation
- better setup-/teardown handling (read: no mo' hacks)
- ...
[1] Shinyei particle sensor PPD42 - http://www.sca-shinyei.com/particlesensor
[2] http://dustmap.org/
[3] http://en.wikipedia.org/wiki/General_Purpose_Input/Output
[4] http://nodejs.org/
[5] http://nodejs.org/api/http.html#http_http_request_options_callback