The Cayenne MQTT mbed Library provides functions to easily connect to the Cayenne IoT project builder.
Fork of Cayenne-MQTT-mbed by
src/CayenneUtils/CayenneUtils.h@22:0dbabcc6e7b2, 2017-01-25 (annotated)
- Committer:
- jburhenn
- Date:
- Wed Jan 25 10:34:16 2017 -0700
- Branch:
- feature/multivalue
- Revision:
- 22:0dbabcc6e7b2
- Parent:
- 1:90dccf306268
Added support for multi-value arrays and size_t data type modifications from the Cayenne-MQTT-C library.
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
jburhenn | 0:09ef59d2d0f7 | 1 | /* |
jburhenn | 0:09ef59d2d0f7 | 2 | The MIT License(MIT) |
jburhenn | 0:09ef59d2d0f7 | 3 | |
jburhenn | 0:09ef59d2d0f7 | 4 | Cayenne MQTT Client Library |
jburhenn | 0:09ef59d2d0f7 | 5 | Copyright (c) 2016 myDevices |
jburhenn | 0:09ef59d2d0f7 | 6 | |
jburhenn | 0:09ef59d2d0f7 | 7 | Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated |
jburhenn | 0:09ef59d2d0f7 | 8 | documentation files(the "Software"), to deal in the Software without restriction, including without limitation |
jburhenn | 0:09ef59d2d0f7 | 9 | the rights to use, copy, modify, merge, publish, distribute, sublicense, and / or sell copies of the Software, |
jburhenn | 0:09ef59d2d0f7 | 10 | and to permit persons to whom the Software is furnished to do so, subject to the following conditions : |
jburhenn | 0:09ef59d2d0f7 | 11 | The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. |
jburhenn | 0:09ef59d2d0f7 | 12 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE |
jburhenn | 0:09ef59d2d0f7 | 13 | WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE AUTHORS OR |
jburhenn | 0:09ef59d2d0f7 | 14 | COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, |
jburhenn | 0:09ef59d2d0f7 | 15 | ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
jburhenn | 0:09ef59d2d0f7 | 16 | |
jburhenn | 0:09ef59d2d0f7 | 17 | */ |
jburhenn | 0:09ef59d2d0f7 | 18 | |
jburhenn | 0:09ef59d2d0f7 | 19 | #ifndef _CAYENNEUTILS_h |
jburhenn | 0:09ef59d2d0f7 | 20 | #define _CAYENNEUTILS_h |
jburhenn | 0:09ef59d2d0f7 | 21 | |
jburhenn | 0:09ef59d2d0f7 | 22 | #if defined(__cplusplus) |
jburhenn | 0:09ef59d2d0f7 | 23 | extern "C" { |
jburhenn | 0:09ef59d2d0f7 | 24 | #endif |
jburhenn | 0:09ef59d2d0f7 | 25 | |
jburhenn | 0:09ef59d2d0f7 | 26 | #if defined(WIN32_DLL) || defined(WIN64_DLL) |
jburhenn | 0:09ef59d2d0f7 | 27 | #define DLLImport __declspec(dllimport) |
jburhenn | 0:09ef59d2d0f7 | 28 | #define DLLExport __declspec(dllexport) |
jburhenn | 0:09ef59d2d0f7 | 29 | #elif defined(LINUX_SO) |
jburhenn | 0:09ef59d2d0f7 | 30 | #define DLLImport extern |
jburhenn | 0:09ef59d2d0f7 | 31 | #define DLLExport __attribute__ ((visibility ("default"))) |
jburhenn | 0:09ef59d2d0f7 | 32 | #else |
jburhenn | 0:09ef59d2d0f7 | 33 | #define DLLImport |
jburhenn | 0:09ef59d2d0f7 | 34 | #define DLLExport |
jburhenn | 0:09ef59d2d0f7 | 35 | #endif |
jburhenn | 0:09ef59d2d0f7 | 36 | |
jburhenn | 0:09ef59d2d0f7 | 37 | #include <stdio.h> |
jburhenn | 0:09ef59d2d0f7 | 38 | #include "CayenneDefines.h" |
jburhenn | 0:09ef59d2d0f7 | 39 | |
jburhenn | 0:09ef59d2d0f7 | 40 | enum CayenneReturnCode { CAYENNE_BUFFER_OVERFLOW = -2, CAYENNE_FAILURE = -1, CAYENNE_SUCCESS = 0 }; |
jburhenn | 0:09ef59d2d0f7 | 41 | |
jburhenn | 1:90dccf306268 | 42 | /** |
jburhenn | 0:09ef59d2d0f7 | 43 | * Build a specified topic string. |
jburhenn | 0:09ef59d2d0f7 | 44 | * @param[out] topicName Returned topic string |
jburhenn | 0:09ef59d2d0f7 | 45 | * @param[in] length CayenneTopic buffer length |
jburhenn | 0:09ef59d2d0f7 | 46 | * @param[in] username Cayenne username |
jburhenn | 0:09ef59d2d0f7 | 47 | * @param[in] clientID Cayennne client ID |
jburhenn | 0:09ef59d2d0f7 | 48 | * @param[in] topic Cayenne topic |
jburhenn | 0:09ef59d2d0f7 | 49 | * @param[in] channel The topic channel, use CAYENNE_NO_CHANNEL if none is required, CAYENNE_ALL_CHANNELS if a wildcard is required |
jburhenn | 0:09ef59d2d0f7 | 50 | * @return CAYENNE_SUCCESS if topic string was created, error code otherwise |
jburhenn | 0:09ef59d2d0f7 | 51 | */ |
jburhenn | 0:09ef59d2d0f7 | 52 | DLLExport int CayenneBuildTopic(char* topicName, size_t length, const char* username, const char* clientID, CayenneTopic topic, unsigned int channel); |
jburhenn | 0:09ef59d2d0f7 | 53 | |
jburhenn | 0:09ef59d2d0f7 | 54 | /** |
jburhenn | 0:09ef59d2d0f7 | 55 | * Build a specified data payload. |
jburhenn | 0:09ef59d2d0f7 | 56 | * @param[out] payload Returned payload |
jburhenn | 0:09ef59d2d0f7 | 57 | * @param[in,out] length Payload buffer length |
jburhenn | 0:09ef59d2d0f7 | 58 | * @param[in] type Optional type to use for type,unit=value payload, can be NULL |
jburhenn | 22:0dbabcc6e7b2 | 59 | * @param[in] unit Payload unit |
jburhenn | 22:0dbabcc6e7b2 | 60 | * @param[in] value Payload value |
jburhenn | 0:09ef59d2d0f7 | 61 | * @return CAYENNE_SUCCESS if topic string was created, error code otherwise |
jburhenn | 0:09ef59d2d0f7 | 62 | */ |
jburhenn | 22:0dbabcc6e7b2 | 63 | DLLExport int CayenneBuildDataPayload(char* payload, size_t* length, const char* type, const char* unit, const char* value); |
jburhenn | 0:09ef59d2d0f7 | 64 | |
jburhenn | 0:09ef59d2d0f7 | 65 | /** |
jburhenn | 0:09ef59d2d0f7 | 66 | * Build a specified response payload. |
jburhenn | 0:09ef59d2d0f7 | 67 | * @param[out] payload Returned payload |
jburhenn | 0:09ef59d2d0f7 | 68 | * @param[in,out] length Payload buffer length |
jburhenn | 0:09ef59d2d0f7 | 69 | * @param[in] id ID of message the response is for |
jburhenn | 0:09ef59d2d0f7 | 70 | * @param[in] error Optional error message, NULL for success |
jburhenn | 0:09ef59d2d0f7 | 71 | * @return CAYENNE_SUCCESS if topic string was created, error code otherwise |
jburhenn | 0:09ef59d2d0f7 | 72 | */ |
jburhenn | 0:09ef59d2d0f7 | 73 | DLLExport int CayenneBuildResponsePayload(char* payload, size_t* length, const char* id, const char* error); |
jburhenn | 0:09ef59d2d0f7 | 74 | |
jburhenn | 0:09ef59d2d0f7 | 75 | /** |
jburhenn | 0:09ef59d2d0f7 | 76 | * Parse a topic string in place. This may modify the topic string. |
jburhenn | 0:09ef59d2d0f7 | 77 | * @param[out] topic Returned Cayenne topic |
jburhenn | 0:09ef59d2d0f7 | 78 | * @param[out] channel Returned channel, CAYENNE_NO_CHANNEL if there is none |
jburhenn | 0:09ef59d2d0f7 | 79 | * @param[out] clientID Returned client ID |
jburhenn | 0:09ef59d2d0f7 | 80 | * @param[in] username Cayenne username |
jburhenn | 0:09ef59d2d0f7 | 81 | * @param[in] topicName Topic name string |
jburhenn | 0:09ef59d2d0f7 | 82 | * @param[in] length Topic name string length |
jburhenn | 0:09ef59d2d0f7 | 83 | * @return CAYENNE_SUCCESS if topic was parsed, error code otherwise |
jburhenn | 0:09ef59d2d0f7 | 84 | */ |
jburhenn | 22:0dbabcc6e7b2 | 85 | DLLExport int CayenneParseTopic(CayenneTopic* topic, unsigned int* channel, const char** clientID, const char* username, char* topicName, size_t length); |
jburhenn | 0:09ef59d2d0f7 | 86 | |
jburhenn | 0:09ef59d2d0f7 | 87 | /** |
jburhenn | 0:09ef59d2d0f7 | 88 | * Parse a null terminated payload in place. This may modify the payload string. |
jburhenn | 0:09ef59d2d0f7 | 89 | * @param[out] type Returned type, NULL if there is none |
jburhenn | 22:0dbabcc6e7b2 | 90 | * @param[out] unit Returned unit, NULL if there is none |
jburhenn | 22:0dbabcc6e7b2 | 91 | * @param[out] value Returned value, NULL if there is none |
jburhenn | 0:09ef59d2d0f7 | 92 | * @param[out] id Returned message id, empty string if there is none |
jburhenn | 0:09ef59d2d0f7 | 93 | * @param[in] topic Cayenne topic |
jburhenn | 0:09ef59d2d0f7 | 94 | * @param[in] payload Payload string, must be null terminated. |
jburhenn | 0:09ef59d2d0f7 | 95 | * @return CAYENNE_SUCCESS if topic string was created, error code otherwise |
jburhenn | 0:09ef59d2d0f7 | 96 | */ |
jburhenn | 22:0dbabcc6e7b2 | 97 | DLLExport int CayenneParsePayload(const char** type, const char** unit, const char** value, const char** id, CayenneTopic topic, char* payload); |
jburhenn | 0:09ef59d2d0f7 | 98 | |
jburhenn | 0:09ef59d2d0f7 | 99 | #if defined(__cplusplus) |
jburhenn | 0:09ef59d2d0f7 | 100 | } |
jburhenn | 0:09ef59d2d0f7 | 101 | #endif |
jburhenn | 0:09ef59d2d0f7 | 102 | |
jburhenn | 0:09ef59d2d0f7 | 103 | #endif |