2013-03-11 12:17:08 +01:00
|
|
|
/*
|
2013-11-08 15:46:27 +01:00
|
|
|
Xively client with Strings
|
2013-03-11 12:17:08 +01:00
|
|
|
|
2013-11-08 15:46:27 +01:00
|
|
|
This sketch connects two analog sensors to Xively (http://www.xively.com)
|
2013-03-11 12:17:08 +01:00
|
|
|
through a Telefonica GSM/GPRS shield.
|
|
|
|
|
2013-11-08 15:46:27 +01:00
|
|
|
This example has been updated to use version 2.0 of the Xively.com API.
|
2013-03-11 12:17:08 +01:00
|
|
|
To make it work, create a feed with two datastreams, and give them the IDs
|
|
|
|
sensor1 and sensor2. Or change the code below to match your feed.
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2013-03-11 12:17:08 +01: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.
|
|
|
|
|
2013-03-11 12:17:08 +01:00
|
|
|
Circuit:
|
|
|
|
* Analog sensors attached to A0 and A1
|
|
|
|
* GSM shield attached to an Arduino
|
|
|
|
* SIM card with a data plan
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2013-03-11 12:17:08 +01:00
|
|
|
created 8 March 2012
|
|
|
|
by Tom Igoe
|
|
|
|
and adapted for GSM shield by David Del Peral
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2013-03-11 12:17:08 +01:00
|
|
|
This code is in the public domain.
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2013-03-11 12:17:08 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
// Include the GSM library
|
|
|
|
#include <GSM.h>
|
|
|
|
|
2013-11-08 15:46:27 +01:00
|
|
|
// Xively login information
|
|
|
|
#define APIKEY "YOUR API KEY GOES HERE" // replace your xively api key here
|
2013-03-11 12:17:08 +01:00
|
|
|
#define FEEDID 00000 // replace your feed ID
|
|
|
|
#define USERAGENT "My Project" // user agent is the project name
|
|
|
|
|
|
|
|
// PIN Number
|
|
|
|
#define PINNUMBER ""
|
|
|
|
|
|
|
|
// APN data
|
|
|
|
#define GPRS_APN "GPRS_APN" // replace your GPRS APN
|
|
|
|
#define GPRS_LOGIN "login" // replace with your GPRS login
|
|
|
|
#define GPRS_PASSWORD "password" // replace with your GPRS password
|
|
|
|
|
|
|
|
// initialize the library instance
|
|
|
|
GSMClient client;
|
|
|
|
GPRS gprs;
|
|
|
|
GSM gsmAccess;
|
|
|
|
|
|
|
|
// if you don't want to use DNS (and reduce your sketch size)
|
|
|
|
// use the numeric IP instead of the name for the server:
|
2013-11-08 15:46:27 +01:00
|
|
|
// IPAddress server(216,52,233,121); // numeric IP for api.xively.com
|
|
|
|
char server[] = "api.xively.com"; // name address for Xively API
|
2013-03-11 12:17:08 +01: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-11-08 15:46:27 +01:00
|
|
|
const unsigned long postingInterval = 10*1000; // delay between updates to Xively.com
|
2013-03-11 12:17:08 +01:00
|
|
|
|
|
|
|
void setup()
|
|
|
|
{
|
|
|
|
// initialize serial communications and wait for port to open:
|
|
|
|
Serial.begin(9600);
|
|
|
|
while (!Serial) {
|
|
|
|
; // wait for serial port to connect. Needed for Leonardo only
|
|
|
|
}
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2013-03-11 12:17:08 +01:00
|
|
|
// connection state
|
|
|
|
boolean notConnected = true;
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2013-03-11 12:17:08 +01:00
|
|
|
// After starting the modem with GSM.begin()
|
2013-10-21 09:58:40 +02:00
|
|
|
// attach the shield to the GPRS network with the APN, login and password
|
|
|
|
while (notConnected)
|
2013-03-11 12:17:08 +01:00
|
|
|
{
|
2013-10-21 09:58:40 +02:00
|
|
|
if ((gsmAccess.begin(PINNUMBER) == GSM_READY) &
|
|
|
|
(gprs.attachGPRS(GPRS_APN, GPRS_LOGIN, GPRS_PASSWORD) == GPRS_READY))
|
2013-03-11 12:17:08 +01:00
|
|
|
notConnected = false;
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Serial.println("Not connected");
|
|
|
|
delay(1000);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Serial.println("Connected to GPRS network");
|
|
|
|
}
|
|
|
|
|
|
|
|
void loop()
|
|
|
|
{
|
|
|
|
// read the sensor on A0
|
2013-10-21 09:58:40 +02:00
|
|
|
int sensorReading = analogRead(A0);
|
|
|
|
|
2013-03-11 12:17:08 +01:00
|
|
|
// convert the data to a String
|
|
|
|
String dataString = "sensor1,";
|
|
|
|
dataString += sensorReading;
|
|
|
|
|
|
|
|
// you can append multiple readings to this String to
|
2013-11-08 15:46:27 +01:00
|
|
|
// send the xively feed multiple values
|
2013-03-11 12:17:08 +01:00
|
|
|
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
|
|
|
|
if (client.available())
|
|
|
|
{
|
|
|
|
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
|
|
|
|
// your last connection, then connect again and send data
|
2013-10-21 09:58:40 +02:00
|
|
|
if (!client.connected() && (millis() - lastConnectionTime > postingInterval))
|
2013-03-11 12:17:08 +01: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:
|
|
|
|
if (client.connect(server, 80))
|
|
|
|
{
|
|
|
|
Serial.println("connecting...");
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2013-03-11 12:17:08 +01:00
|
|
|
// send the HTTP PUT request:
|
|
|
|
client.print("PUT /v2/feeds/");
|
|
|
|
client.print(FEEDID);
|
|
|
|
client.println(".csv HTTP/1.1");
|
2013-11-08 15:46:27 +01:00
|
|
|
client.println("Host: api.xively.com");
|
2013-03-11 12:17:08 +01:00
|
|
|
client.print("X-ApiKey: ");
|
|
|
|
client.println(APIKEY);
|
|
|
|
client.print("User-Agent: ");
|
|
|
|
client.println(USERAGENT);
|
|
|
|
client.print("Content-Length: ");
|
|
|
|
client.println(thisData.length());
|
|
|
|
|
|
|
|
// last pieces of the HTTP PUT request
|
2013-04-05 19:13:27 +02:00
|
|
|
client.println("Content-Type: text/csv");
|
|
|
|
client.println("Connection: close");
|
2013-03-11 12:17:08 +01:00
|
|
|
client.println();
|
2013-10-21 09:58:40 +02:00
|
|
|
|
2013-03-11 12:17:08 +01:00
|
|
|
// here's the actual content of the PUT request
|
|
|
|
client.println(thisData);
|
2013-10-21 09:58:40 +02:00
|
|
|
}
|
2013-03-11 12:17:08 +01:00
|
|
|
else
|
|
|
|
{
|
|
|
|
// if you couldn't make a connection
|
|
|
|
Serial.println("connection failed");
|
|
|
|
Serial.println();
|
|
|
|
Serial.println("disconnecting.");
|
|
|
|
client.stop();
|
|
|
|
}
|
|
|
|
// note the time that the connection was made or attempted:
|
|
|
|
lastConnectionTime = millis();
|
|
|
|
}
|