2012-03-02 16:30:06 -05:00
|
|
|
/*
|
2012-09-08 15:49:37 -04:00
|
|
|
Wifi Pachube sensor client with Strings
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2012-09-08 15:49:37 -04:00
|
|
|
This sketch connects an analog sensor to Pachube (http://www.pachube.com)
|
2012-03-02 16:30:06 -05:00
|
|
|
using a Arduino Wifi shield.
|
2013-10-21 09:58:40 +02:00
|
|
|
|
|
|
|
This example is written for a network using WPA encryption. For
|
2012-03-04 17:04:51 -05:00
|
|
|
WEP or WPA, change the Wifi.begin() call accordingly.
|
2013-10-21 09:58:40 +02:00
|
|
|
|
|
|
|
This example has been updated to use version 2.0 of the pachube.com API.
|
2012-03-04 17:04:51 -05:00
|
|
|
To make it work, create a feed with a datastream, and give it the ID
|
|
|
|
sensor1. Or change the code below to match your feed.
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2012-03-02 16:30:06 -05:00
|
|
|
This example uses the String library, which is part of the Arduino core from
|
2013-10-21 09:58:40 +02:00
|
|
|
version 0019.
|
|
|
|
|
2012-03-02 16:30:06 -05:00
|
|
|
Circuit:
|
|
|
|
* Analog sensor attached to analog in 0
|
|
|
|
* Wifi shield attached to pins 10, 11, 12, 13
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2012-04-23 11:26:58 -04:00
|
|
|
created 16 Mar 2012
|
2012-06-06 11:28:21 +02:00
|
|
|
modified 31 May 2012
|
2012-03-02 16:30:06 -05:00
|
|
|
by Tom Igoe
|
2012-09-08 15:49:37 -04:00
|
|
|
modified 8 Sept 2012
|
|
|
|
by Scott Fitzgerald
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2012-03-02 16:30:06 -05:00
|
|
|
This code is in the public domain.
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2012-03-02 16:30:06 -05:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <SPI.h>
|
|
|
|
#include <WiFi.h>
|
|
|
|
|
|
|
|
#define APIKEY "YOUR API KEY GOES HERE" // replace your pachube api key here
|
2012-03-09 21:43:49 -05:00
|
|
|
#define FEEDID 00000 // replace your feed ID
|
2012-03-13 13:00:14 -04:00
|
|
|
#define USERAGENT "My Arduino Project" // user agent is the project name
|
2012-03-02 16:30:06 -05:00
|
|
|
|
2013-10-21 09:58:40 +02:00
|
|
|
char ssid[] = "yourNetwork"; // your network SSID (name)
|
2012-03-02 16:30:06 -05:00
|
|
|
char pass[] = "secretPassword"; // your network password
|
2012-03-13 13:00:14 -04:00
|
|
|
|
|
|
|
int status = WL_IDLE_STATUS;
|
2012-03-02 16:30:06 -05:00
|
|
|
|
|
|
|
// initialize the library instance:
|
|
|
|
WiFiClient client;
|
2012-03-13 13:00:14 -04:00
|
|
|
|
|
|
|
// if you don't want to use DNS (and reduce your sketch size)
|
|
|
|
// use the numeric IP instead of the name for the server:
|
2012-09-08 15:49:37 -04:00
|
|
|
//IPAddress server(216,52,233,121); // numeric IP for api.pachube.com
|
|
|
|
char server[] = "api.pachube.com"; // name address for pachube API
|
2012-03-02 16:30:06 -05:00
|
|
|
|
2012-03-09 21:43:49 -05:00
|
|
|
unsigned long lastConnectionTime = 0; // last time you connected to the server, in milliseconds
|
|
|
|
boolean lastConnected = false; // state of the connection last time through the main loop
|
2013-10-21 09:58:40 +02:00
|
|
|
const unsigned long postingInterval = 10 * 1000; //delay between updates to pachube.com
|
2012-03-02 16:30:06 -05:00
|
|
|
|
|
|
|
void setup() {
|
2012-06-06 17:31:14 +02:00
|
|
|
//Initialize serial and wait for port to open:
|
2013-10-21 09:58:40 +02:00
|
|
|
Serial.begin(9600);
|
2012-06-06 17:31:14 +02:00
|
|
|
while (!Serial) {
|
|
|
|
; // wait for serial port to connect. Needed for Leonardo only
|
|
|
|
}
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2012-06-06 11:28:21 +02:00
|
|
|
// check for the presence of the shield:
|
|
|
|
if (WiFi.status() == WL_NO_SHIELD) {
|
2013-10-21 09:58:40 +02:00
|
|
|
Serial.println("WiFi shield not present");
|
2012-06-06 11:28:21 +02:00
|
|
|
// don't continue:
|
2013-10-21 09:58:40 +02:00
|
|
|
while (true);
|
|
|
|
}
|
2013-07-19 16:34:44 +02:00
|
|
|
|
|
|
|
String fv = WiFi.firmwareVersion();
|
2013-10-21 09:58:40 +02:00
|
|
|
if ( fv != "1.1.0" )
|
2013-07-19 16:34:44 +02:00
|
|
|
Serial.println("Please upgrade the firmware");
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2012-04-23 11:26:58 -04:00
|
|
|
// attempt to connect to Wifi network:
|
2013-10-21 09:58:40 +02:00
|
|
|
while ( status != WL_CONNECTED) {
|
2012-04-23 11:26:58 -04:00
|
|
|
Serial.print("Attempting to connect to SSID: ");
|
|
|
|
Serial.println(ssid);
|
2013-10-21 09:58:40 +02:00
|
|
|
// Connect to WPA/WPA2 network. Change this line if using open or WEP network:
|
2012-04-23 11:26:58 -04:00
|
|
|
status = WiFi.begin(ssid, pass);
|
2012-06-06 11:28:21 +02:00
|
|
|
|
2012-04-23 11:26:58 -04:00
|
|
|
// wait 10 seconds for connection:
|
|
|
|
delay(10000);
|
2013-10-21 09:58:40 +02:00
|
|
|
}
|
2012-04-23 11:26:58 -04:00
|
|
|
// you're connected now, so print out the status:
|
|
|
|
printWifiStatus();
|
2012-03-02 16:30:06 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void loop() {
|
|
|
|
// read the analog sensor:
|
2013-10-21 09:58:40 +02:00
|
|
|
int sensorReading = analogRead(A0);
|
2012-03-02 16:30:06 -05:00
|
|
|
// convert the data to a String to send it:
|
2012-03-04 17:04:51 -05:00
|
|
|
|
2012-03-02 16:30:06 -05:00
|
|
|
String dataString = "sensor1,";
|
2012-03-04 17:04:51 -05:00
|
|
|
dataString += sensorReading;
|
2012-03-02 16:30:06 -05:00
|
|
|
|
|
|
|
// you can append multiple readings to this String if your
|
|
|
|
// pachube feed is set up to handle multiple values:
|
|
|
|
int otherSensorReading = analogRead(A1);
|
|
|
|
dataString += "\nsensor2,";
|
|
|
|
dataString += otherSensorReading;
|
|
|
|
|
|
|
|
// if there's incoming data from the net connection.
|
|
|
|
// send it out the serial port. This is for debugging
|
|
|
|
// purposes only:
|
2012-06-07 13:51:48 +02:00
|
|
|
while (client.available()) {
|
2012-03-02 16:30:06 -05:00
|
|
|
char c = client.read();
|
|
|
|
Serial.print(c);
|
|
|
|
}
|
|
|
|
|
|
|
|
// if there's no net connection, but there was one last time
|
|
|
|
// through the loop, then stop the client:
|
|
|
|
if (!client.connected() && lastConnected) {
|
|
|
|
Serial.println();
|
|
|
|
Serial.println("disconnecting.");
|
|
|
|
client.stop();
|
|
|
|
}
|
|
|
|
|
|
|
|
// if you're not connected, and ten seconds have passed since
|
2013-10-21 09:58:40 +02:00
|
|
|
// your last connection, then connect again and send data:
|
|
|
|
if (!client.connected() && (millis() - lastConnectionTime > postingInterval)) {
|
2012-03-02 16:30:06 -05:00
|
|
|
sendData(dataString);
|
|
|
|
}
|
|
|
|
// store the state of the connection for next time through
|
|
|
|
// the loop:
|
|
|
|
lastConnected = client.connected();
|
|
|
|
}
|
|
|
|
|
|
|
|
// this method makes a HTTP connection to the server:
|
|
|
|
void sendData(String thisData) {
|
|
|
|
// if there's a successful connection:
|
2012-03-09 21:43:49 -05:00
|
|
|
if (client.connect(server, 80)) {
|
2012-03-02 16:30:06 -05:00
|
|
|
Serial.println("connecting...");
|
|
|
|
// send the HTTP PUT request:
|
|
|
|
client.print("PUT /v2/feeds/");
|
|
|
|
client.print(FEEDID);
|
|
|
|
client.println(".csv HTTP/1.1");
|
2012-09-08 15:49:37 -04:00
|
|
|
client.println("Host: api.pachube.com");
|
2012-05-14 16:56:35 -04:00
|
|
|
client.print("X-ApiKey: ");
|
2012-03-02 16:30:06 -05:00
|
|
|
client.println(APIKEY);
|
|
|
|
client.print("User-Agent: ");
|
|
|
|
client.println(USERAGENT);
|
|
|
|
client.print("Content-Length: ");
|
2012-03-13 13:00:14 -04:00
|
|
|
client.println(thisData.length());
|
2012-03-02 16:30:06 -05:00
|
|
|
|
|
|
|
// last pieces of the HTTP PUT request:
|
2012-03-13 13:00:14 -04:00
|
|
|
client.println("Content-Type: text/csv");
|
|
|
|
client.println("Connection: close");
|
|
|
|
client.println();
|
2012-03-02 16:30:06 -05:00
|
|
|
|
|
|
|
// here's the actual content of the PUT request:
|
|
|
|
client.println(thisData);
|
2013-10-21 09:58:40 +02:00
|
|
|
}
|
2012-03-02 16:30:06 -05:00
|
|
|
else {
|
|
|
|
// if you couldn't make a connection:
|
|
|
|
Serial.println("connection failed");
|
|
|
|
Serial.println();
|
|
|
|
Serial.println("disconnecting.");
|
|
|
|
client.stop();
|
|
|
|
}
|
2012-03-13 13:00:14 -04:00
|
|
|
// note the time that the connection was made or attempted:
|
2012-03-09 21:43:49 -05:00
|
|
|
lastConnectionTime = millis();
|
2012-03-02 16:30:06 -05:00
|
|
|
}
|
2012-03-13 13:00:14 -04:00
|
|
|
|
2012-03-16 10:38:20 -04:00
|
|
|
|
|
|
|
void printWifiStatus() {
|
|
|
|
// print the SSID of the network you're attached to:
|
|
|
|
Serial.print("SSID: ");
|
|
|
|
Serial.println(WiFi.SSID());
|
|
|
|
|
|
|
|
// print your WiFi shield's IP address:
|
|
|
|
IPAddress ip = WiFi.localIP();
|
|
|
|
Serial.print("IP Address: ");
|
|
|
|
Serial.println(ip);
|
|
|
|
|
|
|
|
// print the received signal strength:
|
|
|
|
long rssi = WiFi.RSSI();
|
|
|
|
Serial.print("signal strength (RSSI):");
|
|
|
|
Serial.print(rssi);
|
|
|
|
Serial.println(" dBm");
|
|
|
|
}
|
|
|
|
|
2012-04-23 11:26:58 -04:00
|
|
|
|