mbed Connector Interface simplification API on top of mbed-client
Fork of mbedConnectorInterfaceV3 by
NOTE:
This repo has been replaced with https://github.com/ARMmbed/mbedConnectorInterface. No further updates will occur with this repo. Please use the github repo instead. Thanks!
mbed-connector-interface/DynamicResource.h
- Committer:
- ansond
- Date:
- 2016-06-14
- Revision:
- 27:b8aaf7dc7023
- Parent:
- 15:c11dbe4d354c
- Child:
- 28:cf32aa9842ce
File content as of revision 27:b8aaf7dc7023:
/** * @file DynamicResource.h * @brief mbed CoAP Endpoint Dynamic Resource class * @author Doug Anson/Chris Paola * @version 1.0 * @see * * Copyright (c) 2014 * * 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 __DYNAMIC_RESOURCE_H__ #define __DYNAMIC_RESOURCE_H__ // Base Class #include "mbed-connector-interface/Resource.h" // DataWrapper support #include "mbed-connector-interface/DataWrapper.h" /** DynamicResource class */ class DynamicResource : public Resource<string> { public: /** Default constructor (char strings) @param logger input logger instance for this resource @param obj_name input the Object @param name input the Resource URI/Name @param res_type input type for the Resource @param res_mask input the resource enablement mask (GET, PUT, etc...) @param observable input the resource is Observable (default: FALSE) */ DynamicResource(const Logger *logger,const char *obj_name,const char *res_name,const char *res_type,uint8_t res_mask,const bool observable = false,const ResourceType type = STRING); /** Default constructor (char strings) @param logger input logger instance for this resource @param obj_name input the Object @param name input the Resource URI/Name @param res_type input type for the Resource @param value input initial value for the Resource @param res_mask input the resource enablement mask (GET, PUT, etc...) @param observable input the resource is Observable (default: FALSE) */ DynamicResource(const Logger *logger,const char *obj_name,const char *res_name,const char *res_type,const string value,uint8_t res_mask,const bool observable = false,const ResourceType type = STRING); /** constructor with string buffer for name @param logger input logger instance for this resource @param obj_name input the Object @param name input the Resource URI/Name @param res_type input type for the Resource @param value input initial value for the Resource @param res_mask input the resource enablement mask (GET, PUT, etc...) @param observable input the resource is Observable (default: FALSE) */ DynamicResource(const Logger *logger,const string obj_name,const string res_name,const string res_type,const string value,uint8_t res_mask,const bool observable = false,const ResourceType type = STRING); /** Copy constructor @param resource input the DynamicResource that is to be deep copied */ DynamicResource(const DynamicResource &resource); /** Destructor */ virtual ~DynamicResource(); /** Bind resource to endpoint @param ep input endpoint instance pointer */ virtual void bind(void *ep); /** Process the CoAP message @param op input the CoAP Verb (operation) @param type input clarification of the M2MBase instance being passed in (Object vs. ObjectInstance vs. Resource vs. ResourceInstance) @param args input arguments (unused) @return 0 - success, 1 - failure */ uint8_t process(M2MBase::Operation op,M2MBase::BaseType type,void *args = NULL); /** Resource value getter (REQUIRED: must be implemented in derived class as all Binders MUST support and implement GET) @returns string value of the resource */ virtual string get(); /** Resource value setter (PUT) (OPTIONAL: defaulted noop if not derived. Binders MAY implement PUT if needed) @param string value of the resource */ virtual void put(const string value); /** Resource value setter (POST) (OPTIONAL: defaulted noop if not derived. Binders MAY implement POST if needed) @param void * args for the post() operation */ virtual void post(void *args); /** Resource value deleter (OPTIONAL: defaulted noop if not derived. Binders MAY implement DELETE if needed) @param void * args for the del() operation */ virtual void del(void *args); /** Send notification of new data @param data input the new data to update @returns 1 - success, 0 - failure */ int notify(const string data); /** Determine whether this dynamic resource is observable or not @returns true - is observable, false - otherwise */ bool isObservable() { return this->m_observable; } /** Set the observer pointer @param observer input the pointer to the ResourceObserver observing this resource */ void setObserver(void *observer); /** Set the content format for responses @param content_format short integer CoAP content-format ID */ void setContentFormat(uint8_t content_format); /** Set the max-age for cache control of responses in a proxy cache @param maxage short integer CoAP max-age in seconds */ void setMaxAge(uint8_t maxage); /** Set the data wrapper @param data_wrapper input the data wrapper instance */ void setDataWrapper(DataWrapper *data_wrapper) { this->m_data_wrapper = data_wrapper; } /** observe the resource */ virtual void observe(); /** get the base resource representation */ M2MResource *getResource(); /** Process a POST message for Resources */ void process_resource_post(void *args); /** Determine if we are connected or not */ bool isConnected(); /** Determine if we are registered or not */ bool isRegistered(); protected: int notify(uint8_t *data,int data_length); DataWrapper *getDataWrapper() { return this->m_data_wrapper; } bool m_observable; private: string m_res_type; // a string description of our resource type (i.e. "Counter", etc...) ResourceType m_type; // the core type of our resource (i.e. String, Integer, etc...) uint8_t m_res_mask; uint8_t m_obs_number; DataWrapper *m_data_wrapper; void *m_observer; uint8_t m_maxage; uint8_t m_content_format; M2MResource *m_res; void *m_ep; // convenience method to create a string from the NSDL CoAP data buffers... string coapDataToString(uint8_t *coap_data_ptr,int coap_data_ptr_length); int coapDataToInteger(uint8_t *coap_data_ptr,int coap_data_ptr_length); float coapDataToFloat(uint8_t *coap_data_ptr,int coap_data_ptr_length); void *coapDataToOpaque(uint8_t *coap_data_ptr,int coap_data_ptr_length); }; #endif // __DYNAMIC_RESOURCE_H__