1
0
mirror of https://github.com/arduino/Arduino.git synced 2025-01-10 00:46:09 +01:00

187 lines
5.0 KiB
Arduino
Raw Normal View History

2013-03-11 12:17:08 +01:00
/*
GSM Xively client
2013-03-11 12:17:08 +01:00
This sketch connects an analog sensor to Xively (http://www.xively.com)
2013-03-11 12:17:08 +01:00
using a Telefonica GSM/GPRS shield.
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 a datastream, and give it the ID
sensor1. Or change the code below to match your feed.
2013-03-11 12:17:08 +01:00
Circuit:
* Analog sensor attached to analog in 0
* GSM shield attached to an Arduino
* SIM card with a data plan
2013-03-11 12:17:08 +01:00
created 4 March 2012
by Tom Igoe
and adapted for GSM shield by David Del Peral
2013-03-11 12:17:08 +01:00
This code is in the public domain.
http://arduino.cc/en/Tutorial/GSMExamplesXivelyClient
2013-03-11 12:17:08 +01:00
*/
// libraries
#include <GSM.h>
// Xively Client data
#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:
// 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
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-03-11 12:17:08 +01:00
// connection state
boolean notConnected = true;
2013-03-11 12:17:08 +01:00
// After starting the modem with GSM.begin()
// attach the shield to the GPRS network with the APN, login and password
while (notConnected)
2013-03-11 12:17:08 +01: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);
}
}
}
void loop()
{
2013-03-11 12:17:08 +01:00
// read the analog sensor:
int sensorReading = analogRead(A0);
2013-03-11 12:17:08 +01:00
// 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);
2013-03-11 12:17:08 +01:00
}
// if there's no net connection, but there was one last time
// through the loop, then stop the client:
if (!client.connected() && lastConnected)
{
client.stop();
}
2013-03-11 12:17:08 +01:00
// if you're not connected, and ten seconds have passed since
// your last connection, then connect again and send data:
if (!client.connected() && ((millis() - lastConnectionTime) > postingInterval))
2013-03-11 12:17:08 +01:00
{
sendData(sensorReading);
2013-03-11 12:17:08 +01:00
}
2013-03-11 12:17:08 +01:00
// 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(int thisData)
{
// if there's a successful connection:
if (client.connect(server, 80))
{
Serial.println("connecting...");
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");
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: ");
// calculate the length of the sensor reading in bytes:
// 8 bytes for "sensor1," + number of digits of the data:
int thisLength = 8 + getLength(thisData);
client.println(thisLength);
// last pieces of the HTTP PUT request:
client.println("Content-Type: text/csv");
2013-03-11 12:17:08 +01:00
client.println("Connection: close");
client.println();
2013-03-11 12:17:08 +01:00
// here's the actual content of the PUT request:
client.print("sensor1,");
client.println(thisData);
}
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();
}
/*
This method calculates the number of digits in the
sensor reading. Since each digit of the ASCII decimal
representation is a byte, the number of digits equals
the number of bytes.
*/
int getLength(int someValue)
{
// there's at least one byte:
int digits = 1;
// continually divide the value by ten,
2013-03-11 12:17:08 +01:00
// adding one to the digit count for each
// time you divide, until you're at 0:
int dividend = someValue / 10;
2013-03-11 12:17:08 +01:00
while (dividend > 0)
{
dividend = dividend / 10;
2013-03-11 12:17:08 +01:00
digits++;
}
2013-03-11 12:17:08 +01:00
// return the number of digits:
return digits;
}