2013-06-28 11:08:56 +02:00
|
|
|
/*
|
|
|
|
UpdateFacebookStatus
|
|
|
|
|
2013-07-11 11:24:53 +02:00
|
|
|
Demonstrates sending a Facebook status update using Temboo from an Arduino Yun.
|
2013-06-28 11:08:56 +02:00
|
|
|
|
|
|
|
Check out the latest Arduino & Temboo examples and support docs at http://www.temboo.com/arduino
|
2014-04-03 19:56:46 +02:00
|
|
|
|
|
|
|
A Temboo account and application key are necessary to run all Temboo examples.
|
|
|
|
If you don't already have one, you can register for a free Temboo account at
|
2013-06-28 11:08:56 +02:00
|
|
|
http://www.temboo.com
|
|
|
|
|
|
|
|
In order to run this sketch, you'll need to register an application using
|
2013-07-03 09:02:59 +02:00
|
|
|
the Facebook dev console at https://developers.facebook.com/apps -- after creating
|
2013-06-28 11:08:56 +02:00
|
|
|
the app, log in to Temboo and visit https://www.temboo.com/library/Library/Facebook/Publishing/SetStatus/
|
|
|
|
to use our OAuth Wizard (or OAuth Choreos) to obtain a Facebook access token.
|
|
|
|
Substitute your access token for the placeholder value of FACEBOOK_ACCESS_TOKEN below.
|
|
|
|
|
2014-04-03 19:56:46 +02:00
|
|
|
This example assumes basic familiarity with Arduino sketches, and that your Yun
|
2013-06-28 11:08:56 +02:00
|
|
|
is connected to the Internet.
|
2014-04-03 19:56:46 +02:00
|
|
|
|
|
|
|
Want to use another social API with your Arduino Yun? We've got Twitter, Google+,
|
2013-07-11 11:24:53 +02:00
|
|
|
Instagram, Tumblr and more in our Library!
|
2013-06-28 11:08:56 +02:00
|
|
|
|
2014-04-03 19:56:46 +02:00
|
|
|
This example code is in the public domain.
|
2013-06-28 11:08:56 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <Bridge.h>
|
2013-07-08 15:09:09 +02:00
|
|
|
#include <Temboo.h>
|
2013-06-28 11:08:56 +02:00
|
|
|
#include "TembooAccount.h" // contains Temboo account information,
|
2014-04-03 19:56:46 +02:00
|
|
|
// as described in the footer comment below
|
2013-06-28 11:08:56 +02:00
|
|
|
|
|
|
|
/*** SUBSTITUTE YOUR VALUES BELOW: ***/
|
|
|
|
|
2013-07-03 09:02:59 +02:00
|
|
|
// Note that for additional security and reusability, you could
|
|
|
|
// use a #define statement to specify this value in a .h file.
|
|
|
|
|
2013-06-28 11:08:56 +02:00
|
|
|
// the Facebook Access Token, which can be obtained using the Temboo OAuth Wizard or Choreos
|
|
|
|
const String FACEBOOK_ACCESS_TOKEN = "xxxxxxxxxx";
|
|
|
|
|
|
|
|
|
2013-07-08 15:09:09 +02:00
|
|
|
int numRuns = 1; // execution count, so this sketch doesn't run forever
|
2013-06-28 11:08:56 +02:00
|
|
|
int maxRuns = 10; // the max number of times the Facebook SetStatus Choreo should run
|
|
|
|
|
|
|
|
void setup() {
|
|
|
|
Serial.begin(9600);
|
2014-04-03 19:56:46 +02:00
|
|
|
|
2013-06-28 11:08:56 +02:00
|
|
|
// For debugging, wait until a serial console is connected.
|
|
|
|
delay(4000);
|
2014-04-03 19:56:46 +02:00
|
|
|
while(!Serial);
|
2013-06-28 11:08:56 +02:00
|
|
|
Bridge.begin();
|
|
|
|
}
|
|
|
|
|
|
|
|
void loop() {
|
|
|
|
// while we haven't reached the max number of runs...
|
2013-07-08 15:09:09 +02:00
|
|
|
if (numRuns <= maxRuns) {
|
2013-06-28 11:08:56 +02:00
|
|
|
|
|
|
|
// print status
|
|
|
|
Serial.println("Running UpdateFacebookStatus - Run #" + String(numRuns++) + "...");
|
2014-04-03 19:56:46 +02:00
|
|
|
|
2013-06-28 11:08:56 +02:00
|
|
|
// Define the status message we want to post on Facebook; since Facebook
|
|
|
|
// doesn't allow duplicate status messages, we'll include a changing value.
|
|
|
|
String statusMsg = "My Arduino Yun has been running for " + String(millis()) + " milliseconds!";
|
|
|
|
|
2014-04-03 19:56:46 +02:00
|
|
|
// define the Process that will be used to call the "temboo" client
|
2013-07-08 15:09:09 +02:00
|
|
|
TembooChoreo SetStatusChoreo;
|
2013-06-28 11:08:56 +02:00
|
|
|
|
|
|
|
// invoke the Temboo client
|
2013-07-08 15:09:09 +02:00
|
|
|
// NOTE that the client must be reinvoked and repopulated with
|
|
|
|
// appropriate arguments each time its run() method is called.
|
|
|
|
SetStatusChoreo.begin();
|
2014-04-03 19:56:46 +02:00
|
|
|
|
2013-06-28 11:08:56 +02:00
|
|
|
// set Temboo account credentials
|
2013-07-08 15:09:09 +02:00
|
|
|
SetStatusChoreo.setAccountName(TEMBOO_ACCOUNT);
|
|
|
|
SetStatusChoreo.setAppKeyName(TEMBOO_APP_KEY_NAME);
|
|
|
|
SetStatusChoreo.setAppKey(TEMBOO_APP_KEY);
|
2013-06-28 11:08:56 +02:00
|
|
|
|
|
|
|
// tell the Temboo client which Choreo to run (Facebook > Publishing > SetStatus)
|
2013-07-08 15:09:09 +02:00
|
|
|
SetStatusChoreo.setChoreo("/Library/Facebook/Publishing/SetStatus");
|
2013-06-28 11:08:56 +02:00
|
|
|
|
|
|
|
// set the required choreo inputs
|
|
|
|
// see https://www.temboo.com/library/Library/Facebook/Publishing/SetStatus/
|
|
|
|
// for complete details about the inputs for this Choreo
|
2014-04-03 19:56:46 +02:00
|
|
|
|
|
|
|
SetStatusChoreo.addInput("AccessToken", FACEBOOK_ACCESS_TOKEN);
|
2013-07-08 15:09:09 +02:00
|
|
|
SetStatusChoreo.addInput("Message", statusMsg);
|
2013-06-28 11:08:56 +02:00
|
|
|
|
|
|
|
|
2014-04-03 19:56:46 +02:00
|
|
|
// tell the Process to run and wait for the results. The
|
|
|
|
// return code (returnCode) will tell us whether the Temboo client
|
2013-06-28 11:08:56 +02:00
|
|
|
// was able to send our request to the Temboo servers
|
2013-07-03 09:02:59 +02:00
|
|
|
unsigned int returnCode = SetStatusChoreo.run();
|
2014-04-03 19:56:46 +02:00
|
|
|
|
2013-06-28 11:08:56 +02:00
|
|
|
// print the response code and API response.
|
2013-07-03 09:02:59 +02:00
|
|
|
Serial.println("Response code: " + String(returnCode));
|
2013-06-28 11:08:56 +02:00
|
|
|
|
|
|
|
// note that in this case, we're just printing the raw response from Facebook.
|
|
|
|
// see the examples on using Temboo SDK output filters at http://www.temboo.com/arduino
|
2014-04-03 19:56:46 +02:00
|
|
|
// for information on how to filter this data
|
|
|
|
while(SetStatusChoreo.available()) {
|
2013-07-03 09:02:59 +02:00
|
|
|
char c = SetStatusChoreo.read();
|
|
|
|
Serial.print(c);
|
2013-06-28 11:08:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
SetStatusChoreo.close();
|
|
|
|
}
|
|
|
|
|
2013-07-03 09:02:59 +02:00
|
|
|
Serial.println("Waiting...");
|
2013-06-28 11:08:56 +02:00
|
|
|
Serial.println("");
|
|
|
|
|
2014-04-03 19:56:46 +02:00
|
|
|
delay(30000); // wait 30 seconds between SetStatus calls
|
2013-06-28 11:08:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
IMPORTANT NOTE: TembooAccount.h:
|
|
|
|
|
2013-07-03 09:02:59 +02:00
|
|
|
TembooAccount.h is a file referenced by this sketch that contains your Temboo account information.
|
|
|
|
You'll need to edit the placeholder version of TembooAccount.h included with this example sketch,
|
|
|
|
by inserting your own Temboo account name and app key information. The contents of the file should
|
|
|
|
look like:
|
2013-06-28 11:08:56 +02:00
|
|
|
|
2014-04-03 19:56:46 +02:00
|
|
|
#define TEMBOO_ACCOUNT "myTembooAccountName" // your Temboo account name
|
2013-06-28 11:08:56 +02:00
|
|
|
#define TEMBOO_APP_KEY_NAME "myFirstApp" // your Temboo app key name
|
|
|
|
#define TEMBOO_APP_KEY "xxx-xxx-xxx-xx-xxx" // your Temboo app key
|
|
|
|
|
2014-04-03 19:56:46 +02:00
|
|
|
You can find your Temboo App Key information on the Temboo website,
|
2013-06-28 11:08:56 +02:00
|
|
|
under My Account > Application Keys
|
|
|
|
|
2013-07-03 09:02:59 +02:00
|
|
|
The same TembooAccount.h file settings can be used for all Temboo SDK sketches.
|
|
|
|
|
2014-04-03 19:56:46 +02:00
|
|
|
Keeping your account information in a separate file means you can share the main .ino file without worrying
|
2013-07-09 20:07:54 +02:00
|
|
|
that you forgot to delete your credentials.
|
2013-07-03 09:02:59 +02:00
|
|
|
*/
|