discof746 ethernet+lcd+ts2
Dependents: grove_stream_jpa_sd2 grove_stream_jpa_sd2 grove_stream_jpa_sd2-2 grove_stream_jpa_sd2-3
Diff: GroveStreams.h
- Revision:
- 0:8b675b2726b7
- Child:
- 1:e69854e65c88
diff -r 000000000000 -r 8b675b2726b7 GroveStreams.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/GroveStreams.h Thu Jan 05 18:39:43 2017 +0000 @@ -0,0 +1,139 @@ +/* + GroveStreams is a helper class to assist with pushing data into the + GroveStreams.com IoT platform. + + License: + Copyright (C) 2017 GroveStreams LLC. + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at: http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +*/ + +#ifndef GROVESTREAMS_H_ +#define GROVESTREAMS_H_ + +#include "mbed.h" +#include "EthernetInterface.h" +#include "NetworkAPI/tcp/socket.hpp" +#include "LcdDiscoF746NgTracer.h" + +class GroveStreams +{ + +protected: + EthernetInterface _eth; + LcdDiscoF746NgTracer* _pLcd; + + const char* _domain; + uint16_t _port; + const char* _apiKey; + const char* _myIPAddress; //Don't Change. Set below from DHCP. Needed by GroveStreams to verify that a device is not uploading more than once every 10s. + + +public: + + /** Constructor with apiKey and Lcd tracer + * + * \param apiKey the secret api_key for your GroveStreams organization + * \param pLcd optional. Pass NULL or and LCD for tracing + */ + GroveStreams(const char* apiKey, LcdDiscoF746NgTracer* pLcd); + + /** Constructor with apiKey and Lcd tracer. + * + * \param apiKey the secret api_key for your GroveStreams organization + */ + GroveStreams(const char* apiKey); + + /** Destructor + * + */ + ~GroveStreams(); + +protected: + int init(const char* apiKey, LcdDiscoF746NgTracer* pLcd); + void printf(const char* format, ...); + +public: + + /** Send sample data to GroveStreams. Attempts to restore dropped ethernet + * connections + * + * \param componentId The ID of the component to put the samples into + * \param samples a string that is URL Encoded and contains all of the + * samples. Place an ampersand at the beggining of each sample substring. + * The substring is &streamId=value. + * Example: &temp=6&eres=78.231&on=true&position=on+ground + * \return 0 on success + */ + unsigned long send(const char* componentId, const char* samples); + + + /** Send sample data to GroveStreams. Attempts to restore dropped ethernet + * connections + * + * \param componentId The ID of the component to put the samples into + * \param samples a string that is URL Encoded and contains all of the + * samples. Place an ampersand at the beggining of each sample substring. + * The substring is &streamId=value. + * Example: &temp=6&eres=78.231&on=true&position=on+ground + * \param resultBuffer a string that will contain the http result body + * \param resultBufferSize the size of the result buffer + * \return 0 on success + */ + unsigned long send(const char* componentId, const char* samples, char* resultBuffer, size_t resultBufferSize); + + /** Send sample data to GroveStreams. Attempts to restore dropped ethernet + * connections + * + * \param componentId The ID of the component to put the samples into + * \param samples a string that is URL Encoded and contains all of the + * samples. Place an ampersand at the beggining of each sample substring. + * The substring is &streamId=value. + * Example: &temp=6&eres=78.231&on=true&position=on+ground + * \param componentName optional (NULL). the name assigned to a newly created component. + * \param compTmplId optional (NULL). the component template ID to be used for creating a + * new component + * \param resultBuffer a string that will contain the http result body + * \param resultBufferSize the size of the result buffer + * \return 0 on success + */ + unsigned long send(const char* componentId, const char* samples, const char* componentName, const char* compTmplId, char* resultBuffer, size_t resultBufferSize); + + /** Send sample data to GroveStreams. Does not attempt to restore dropped + * ethernet connections. + * + * \param componentId The ID of the component to put the samples into + * \param samples a string that is URL Encoded and contains all of the + * samples. Place an ampersand at the beggining of each sample substring. + * The substring is &streamId=value. + * Example: &temp=6&eres=78.231&on=true&position=on+ground + * \param componentName optional (NULL). the name assigned to a newly created component. + * \param compTmplId optional (NULL). the component template ID to be used for creating a + * new component + * \param resultBuffer a string that will contain the http result body + * \param resultBufferSize the size of the result buffer + * \return 0 on success + */ + unsigned long sendNoRetry(const char* componentId, const char* samples, const char* componentName, const char* compTmplId, char* resultBuffer, size_t resultBufferSize); + + /** Starts ethernet. + * Stops ethernet if it is running before starting it. + * \return 0 on success + */ + int startEthernet(); + + /** Get the MAC address of your Ethernet interface + * \return a pointer to a string containing the MAC address + */ + const char* getMACAddress(); + +}; + +#endif /* GROVESTREAMS_H_ */ \ No newline at end of file