mqtt specific components for the impact mbed endpoint library

Dependents:   mbed_mqtt_endpoint_ublox_ethernet mbed_mqtt_endpoint_ublox_cellular mbed_mqtt_endpoint_nxp

Committer:
ansond
Date:
Fri Sep 26 05:16:26 2014 +0000
Revision:
56:789a1a8c5ebe
Parent:
5:1ba6e68bf50e
updates for new logger name

Who changed what in which revision?

UserRevisionLine numberNew contents of line
ansond 0:a3fc1c6ef150 1 /* Copyright C2013 Doug Anson, MIT License
ansond 0:a3fc1c6ef150 2 *
ansond 0:a3fc1c6ef150 3 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
ansond 0:a3fc1c6ef150 4 * and associated documentation files the "Software", to deal in the Software without restriction,
ansond 0:a3fc1c6ef150 5 * including without limitation the rights to use, copy, modify, merge, publish, distribute,
ansond 0:a3fc1c6ef150 6 * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
ansond 0:a3fc1c6ef150 7 * furnished to do so, subject to the following conditions:
ansond 0:a3fc1c6ef150 8 *
ansond 0:a3fc1c6ef150 9 * The above copyright notice and this permission notice shall be included in all copies or
ansond 0:a3fc1c6ef150 10 * substantial portions of the Software.
ansond 0:a3fc1c6ef150 11 *
ansond 0:a3fc1c6ef150 12 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
ansond 0:a3fc1c6ef150 13 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
ansond 0:a3fc1c6ef150 14 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
ansond 0:a3fc1c6ef150 15 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
ansond 0:a3fc1c6ef150 16 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
ansond 0:a3fc1c6ef150 17 */
ansond 0:a3fc1c6ef150 18
ansond 0:a3fc1c6ef150 19 #ifndef _EMULATED_RESOURCE_FACTORY_H_
ansond 0:a3fc1c6ef150 20 #define _EMULATED_RESOURCE_FACTORY_H_
ansond 0:a3fc1c6ef150 21
ansond 0:a3fc1c6ef150 22 // Base Class
ansond 0:a3fc1c6ef150 23 #include "ResourceFactory.h"
ansond 0:a3fc1c6ef150 24
ansond 0:a3fc1c6ef150 25 // Emulated callback structure
ansond 0:a3fc1c6ef150 26 typedef void (*EmulatedCallbackPointer)();
ansond 0:a3fc1c6ef150 27
ansond 56:789a1a8c5ebe 28 // Logger support
ansond 56:789a1a8c5ebe 29 #include "Logger.h"
ansond 0:a3fc1c6ef150 30
ansond 0:a3fc1c6ef150 31 // Resource Initializer callback structure
ansond 0:a3fc1c6ef150 32 typedef void (*resourceInitializer)(Resource *);
ansond 0:a3fc1c6ef150 33
ansond 5:1ba6e68bf50e 34 class EmulatedResourceFactory : public ResourceFactory {
ansond 0:a3fc1c6ef150 35 public:
ansond 56:789a1a8c5ebe 36 EmulatedResourceFactory(Logger *logger,void *endpoint);
ansond 0:a3fc1c6ef150 37 virtual ~EmulatedResourceFactory();
ansond 0:a3fc1c6ef150 38
ansond 5:1ba6e68bf50e 39 virtual void createResources(char *endpoint_name) = 0;
ansond 0:a3fc1c6ef150 40
ansond 0:a3fc1c6ef150 41 bool setResourceValue(char *name, char *value);
ansond 0:a3fc1c6ef150 42
ansond 0:a3fc1c6ef150 43 protected:
ansond 0:a3fc1c6ef150 44 virtual void createResource(char *endpoint_name,char *name,char *value,void *cb);
ansond 0:a3fc1c6ef150 45 virtual void createResource(char *name,char *value);
ansond 0:a3fc1c6ef150 46 void createResource(char *name,char *value,void *io,void *notused);
ansond 0:a3fc1c6ef150 47 };
ansond 0:a3fc1c6ef150 48
ansond 0:a3fc1c6ef150 49
ansond 0:a3fc1c6ef150 50 #endif // _EMULATED_RESOURCE_FACTORY_H_