Doug Anson / mbedConnectorInterfaceV3
Revision:
13:9edad7677211
Parent:
0:1f1f55e73248
Child:
15:c11dbe4d354c
--- a/mbed-connector-interface/DynamicResource.h	Thu Mar 10 16:02:04 2016 +0000
+++ b/mbed-connector-interface/DynamicResource.h	Wed Jun 08 22:32:08 2016 +0000
@@ -1,197 +1,208 @@
-/**
- * @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);
-
-    /**
-    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);
-
-    /**
-    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);
-
-    /**
-    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 p input pointer to the endpoint resources necessary for binding
-    */
-    virtual M2MObject *bind(void *p);
-
-    /**
-    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)
-    @return 0 - success, 1 - failure
-    */
-    uint8_t process(M2MBase::Operation op,M2MBase::BaseType type);
-
-    /**
-    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() = 0;
-
-    /**
-    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 string value of the resource
-    */
-    virtual void post(const string value);
-
-    /**
-    Resource value deleter (OPTIONAL: defaulted noop if not derived. Binders MAY implement DELETE if needed)
-    @param string value of the resource
-    */
-    virtual void del(const string value);
-
-    /**
-    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
-    */
-    M2MBase *getResource();
-    
-    /**
-    Process a POST message for Resources
-    */
-    void process_resource_post(void *args);
-
-protected:
-    int notify(uint8_t *data,int data_length);
-    DataWrapper *getDataWrapper() { return this->m_data_wrapper; }
-    bool              m_observable;
-
-private:
-
-    string                 			   m_res_type;
-    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;
-    M2MObject      			   *m_object; 
-    M2MObjectInstance       *m_obj_instance;
-    M2MResource				   *m_res;
-    void                                *m_op_processor;
-
-    // convenience method to create a string from the NSDL CoAP data buffers...
-    string coapDataToString(uint8_t *coap_data_ptr,int coap_data_ptr_length);
-};
-
-#endif // __DYNAMIC_RESOURCE_H__
+/**
+ * @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);
+
+    /**
+    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);
+
+    /**
+    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);
+
+    /**
+    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 p input pointer to the endpoint resources necessary for binding
+    */
+    virtual M2MObject *bind(void *p);
+
+    /**
+    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() = 0;
 
+    /**
+    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
+    */
+    M2MBase *getResource();
+    
+    /**
+    Process a POST message for Resources
+    */
+    void process_resource_post(void *args);
+    
+    /**
+    Process a DELETE message for Resources
+    */
+    void process_resource_delete(void *args);
+    
+    /**
+    Determine if we are connected or not
+    */
+    bool isConnected();
+
+protected:
+    int notify(uint8_t *data,int data_length);
+    DataWrapper *getDataWrapper() { return this->m_data_wrapper; }
+    bool              m_observable;
+
+private:
+
+    string                 			   m_res_type;
+    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;
+    M2MObject      			   *m_object; 
+    M2MObjectInstance       *m_obj_instance;
+    M2MResource				   *m_res;
+    void                                *m_op_processor;
+
+    // convenience method to create a string from the NSDL CoAP data buffers...
+    string coapDataToString(uint8_t *coap_data_ptr,int coap_data_ptr_length);
+};
+
+#endif // __DYNAMIC_RESOURCE_H__
+