Mistake on this page? Email us
m2mbase.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2015 ARM Limited. All rights reserved.
3  * SPDX-License-Identifier: Apache-2.0
4  * Licensed under the Apache License, Version 2.0 (the License); you may
5  * not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an AS IS BASIS, WITHOUT
12  * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 #ifndef M2M_BASE_H
17 #define M2M_BASE_H
18 
19 // Support for std args
20 #include <stdint.h>
21 #include "mbed-client/m2mconfig.h"
26 #include "nsdl-c/sn_nsdl.h"
27 #include "sn_coap_header.h"
28 #include "nsdl-c/sn_nsdl_lib.h"
29 
30 //FORWARD DECLARATION
31 struct sn_coap_hdr_;
32 typedef sn_coap_hdr_ sn_coap_hdr_s;
33 struct nsdl_s;
34 struct sn_nsdl_addr_;
35 typedef sn_nsdl_addr_ sn_nsdl_addr_s;
36 
38 typedef void(*value_updated_callback2) (const char* object_name);
40 class M2MReportHandler;
41 
42 class M2MObjectInstance;
43 class M2MObject;
44 class M2MResource;
45 class M2MEndpoint;
46 
47 
54 class M2MBase : public M2MReportObserver {
55 
56 public:
57 
61  typedef enum {
62  Object = 0x0,
63  Resource = 0x1,
64  ObjectInstance = 0x2,
65  ResourceInstance = 0x3
66 #ifdef MBED_CLOUD_CLIENT_EDGE_EXTENSION
67  ,ObjectDirectory = 0x4
68 #endif
69  } BaseType;
70 
74  typedef enum {
75  None = 0x0,
76  R_Attribute = 0x01,
77  OI_Attribute = 0x02,
78  OIR_Attribute = 0x03,
79  O_Attribute = 0x04,
80  OR_Attribute = 0x05,
81  OOI_Attribute = 0x06,
82  OOIR_Attribute = 0x07
83  } Observation;
84 
85 
89  typedef enum {
90  Static,
91  Dynamic,
92  Directory
93  }Mode;
94 
98  typedef enum {
99  STRING,
100  INTEGER,
101  FLOAT,
102  BOOLEAN,
103  OPAQUE,
104  TIME,
105  OBJLINK
106  }DataType;
107 
112  typedef enum {
113  NOT_ALLOWED = 0x00,
114  GET_ALLOWED = 0x01,
115  PUT_ALLOWED = 0x02,
116  GET_PUT_ALLOWED = 0x03,
117  POST_ALLOWED = 0x04,
118  GET_POST_ALLOWED = 0x05,
119  PUT_POST_ALLOWED = 0x06,
120  GET_PUT_POST_ALLOWED = 0x07,
121  DELETE_ALLOWED = 0x08,
122  GET_DELETE_ALLOWED = 0x09,
123  PUT_DELETE_ALLOWED = 0x0A,
124  GET_PUT_DELETE_ALLOWED = 0x0B,
125  POST_DELETE_ALLOWED = 0x0C,
126  GET_POST_DELETE_ALLOWED = 0x0D,
127  PUT_POST_DELETE_ALLOWED = 0x0E,
128  GET_PUT_POST_DELETE_ALLOWED = 0x0F
129  }Operation;
130 
135  typedef enum {
136  MESSAGE_STATUS_INIT = 0, // Initial state.
137  MESSAGE_STATUS_BUILD_ERROR, // CoAP message building fails.
138  MESSAGE_STATUS_RESEND_QUEUE_FULL, // CoAP resend queue full.
139  MESSAGE_STATUS_SENT, // Message sent to the server but ACK not yet received.
140  MESSAGE_STATUS_DELIVERED, // Received ACK from server.
141  MESSAGE_STATUS_SEND_FAILED, // Message sending failed.
142  MESSAGE_STATUS_SUBSCRIBED, // Server has started the observation
143  MESSAGE_STATUS_UNSUBSCRIBED, // Server has stopped the observation (RESET message or GET with observe 1)
144  MESSAGE_STATUS_REJECTED // Server has rejected the response
146 
147  typedef enum {
148  NOTIFICATION = 0,
149  DELAYED_POST_RESPONSE,
150  BLOCK_SUBSCRIBE,
151  PING,
152  DELAYED_RESPONSE
153  } MessageType;
154 
155  enum MaxPathSize {
156  MAX_NAME_SIZE = 64,
157  MAX_INSTANCE_SIZE = 5,
158 
159  MAX_PATH_SIZE = ((MAX_NAME_SIZE * 2) + (MAX_INSTANCE_SIZE * 2) + 3 + 1),
160  MAX_PATH_SIZE_2 = ((MAX_NAME_SIZE * 2) + MAX_INSTANCE_SIZE + 2 + 1),
161  MAX_PATH_SIZE_3 = (MAX_NAME_SIZE + (MAX_INSTANCE_SIZE * 2) + 2 + 1),
162  MAX_PATH_SIZE_4 = (MAX_NAME_SIZE + MAX_INSTANCE_SIZE + 1 + 1)
163  };
164 
165  // The setter for this callback (set_notification_delivery_status_cb()) is in m2m_deprecated
166  // category, but it can not be used here as then the GCC will scream for the declaration of
167  // setter, not just from references of it.
168  typedef void(*notification_delivery_status_cb) (const M2MBase& base,
169  const NotificationDeliveryStatus status,
170  void *client_args);
171 
172  typedef void(*message_delivery_status_cb) (const M2MBase& base,
173  const MessageDeliveryStatus status,
174  const MessageType type,
175  void *client_args);
176 
177 #ifdef ENABLE_ASYNC_REST_RESPONSE
178 
188  typedef void (*handle_async_coap_request_cb)(const M2MBase &base,
190  const uint8_t *token,
191  const uint8_t token_len,
192  const uint8_t *buffer,
193  size_t buffer_size,
194  void *client_args);
195 #endif // ENABLE_ASYNC_REST_RESPONSE
196 
199  typedef struct lwm2m_parameters {
200  //add multiple_instances
201  uint32_t max_age; // todo: add flag
205  union {
206  char* name; //for backwards compatibility
207  uint16_t instance_id; // XXX: this is not properly aligned now, need to reorder these after the elimination is done
208  } identifier;
209  sn_nsdl_dynamic_resource_parameters_s *dynamic_resource_params;
210  BaseType base_type : 3;
211  M2MBase::DataType data_type : 3;
212  bool multiple_instance;
219  bool identifier_int_type;
223 
224 protected:
225 
226  // Prevents the use of default constructor.
227  M2MBase();
228 
229  // Prevents the use of assignment operator.
230  M2MBase& operator=( const M2MBase& /*other*/ );
231 
232  // Prevents the use of copy constructor
233  M2MBase( const M2MBase& /*other*/ );
234 
244  M2MBase(const String &name,
246 #ifndef DISABLE_RESOURCE_TYPE
247  const String &resource_type,
248 #endif
249  char *path,
250  bool external_blockwise_store,
251  bool multiple_instance,
252  M2MBase::DataType type = M2MBase::OBJLINK);
253 
254  M2MBase(const lwm2m_parameters_s* s);
255 
256 public:
257 
261  virtual ~M2MBase();
262 
267  void set_operation(M2MBase::Operation operation);
268 
269 #if !defined(MEMORY_OPTIMIZED_API) || defined(RESOURCE_ATTRIBUTES_LIST)
270 
274 #if !defined(DISABLE_INTERFACE_DESCRIPTION) || defined(RESOURCE_ATTRIBUTES_LIST)
275  void set_interface_description(const String &description);
276 
281  void set_interface_description(const char *description);
282 
287  const char* interface_description() const;
288 #endif
289 #if !defined(DISABLE_RESOURCE_TYPE) || defined(RESOURCE_ATTRIBUTES_LIST)
290 
294  virtual void set_resource_type(const String &resource_type);
295 
300  virtual void set_resource_type(const char *resource_type);
301 
306  const char* resource_type() const;
307 #endif
308 #endif
309 
315  void set_coap_content_type(const uint16_t content_type);
316 
321  void set_observable(bool observable);
322 
332  void set_auto_observable(bool auto_observable);
333 
339 
345 
352  void set_under_observation(bool observed,
353  M2MObservationHandler *handler);
358  virtual M2MObservationHandler* observation_handler() const = 0;
359 
364  virtual void set_observation_handler(M2MObservationHandler *handler) = 0;
365 
370  void set_instance_id(const uint16_t instance_id);
371 
376  void set_max_age(const uint32_t max_age);
377 
382  M2MBase::BaseType base_type() const;
383 
389 
394  const char* name() const;
395 
400  int32_t name_id() const;
401 
406  uint16_t instance_id() const;
407 
412  const char* uri_path() const;
413 
418  uint16_t coap_content_type() const;
419 
424  bool is_observable() const;
425 
430  bool is_auto_observable() const;
431 
437 
442  Mode mode() const;
443 
448  uint16_t observation_number() const;
449 
454  uint32_t max_age() const;
455 
456 #if defined (MBED_CONF_MBED_CLIENT_ENABLE_OBSERVATION_PARAMETERS) && (MBED_CONF_MBED_CLIENT_ENABLE_OBSERVATION_PARAMETERS == 1)
457 
463  virtual bool handle_observation_attribute(const char *query);
464 #endif
465 
474  virtual sn_coap_hdr_s* handle_get_request(nsdl_s *nsdl,
475  sn_coap_hdr_s *received_coap_header,
486  virtual sn_coap_hdr_s* handle_put_request(nsdl_s *nsdl,
487  sn_coap_hdr_s *received_coap_header,
489  bool &execute_value_updated);
490 
500  virtual sn_coap_hdr_s* handle_post_request(nsdl_s *nsdl,
501  sn_coap_hdr_s *received_coap_header,
503  bool &execute_value_updated,
504  sn_nsdl_addr_s *address = NULL);
505 
512  void send_notification_delivery_status(const M2MBase& object, const NotificationDeliveryStatus status);
513 
517  void send_message_delivery_status(const M2MBase& object, const MessageDeliveryStatus status, const MessageType type);
518 
523  void set_register_uri(bool register_uri);
524 
529  bool register_uri();
530 
535  bool is_under_observation() const;
536 
544 
551  bool set_value_updated_function(value_updated_callback2 callback);
552 
557  bool is_value_updated_function_set() const;
558 
563  void execute_value_updated(const String& name);
564 
569  size_t resource_name_length() const;
570 
575  sn_nsdl_dynamic_resource_parameters_s* get_nsdl_resource() const;
576 
582 
583 #ifdef ENABLE_ASYNC_REST_RESPONSE
584 
593  bool send_async_response_with_code(const uint8_t *payload,
594  size_t payload_len,
595  const uint8_t* token,
596  const uint8_t token_len,
598 
606  bool set_async_coap_request_cb(handle_async_coap_request_cb callback, void *client_args);
607 
608 #endif //ENABLE_ASYNC_REST_RESPONSE
609 
614  uint16_t get_notification_msgid() const m2m_deprecated;
615 
621  void set_notification_msgid(uint16_t msgid) m2m_deprecated;
622 
628  bool set_notification_delivery_status_cb(notification_delivery_status_cb callback, void *client_args) m2m_deprecated;
629 
636  bool set_message_delivery_status_cb(message_delivery_status_cb callback, void *client_args);
637 
638 #ifdef MBED_CLOUD_CLIENT_EDGE_EXTENSION
639  static char* create_path(const M2MEndpoint &parent, const char *name);
640 #endif
641  static char* create_path(const M2MObject &parent, const char *name);
642  static char* create_path(const M2MObject &parent, uint16_t object_instance);
643  static char* create_path(const M2MResource &parent, uint16_t resource_instance);
644  static char* create_path(const M2MResource &parent, const char *name);
645  static char* create_path(const M2MObjectInstance &parent, const char *name);
646 
647 #ifdef MBED_CLOUD_CLIENT_EDGE_EXTENSION
648 
654  virtual void set_deleted();
655 
656 
661  virtual bool is_deleted();
662 
663 #endif // MBED_CLOUD_CLIENT_EDGE_EXTENSION
664 
665 protected: // from M2MReportObserver
666 
667  virtual bool observation_to_be_sent(const m2m::Vector<uint16_t> &changed_instance_ids,
668  uint16_t obs_number,
669  bool send_object = false);
670 
675  void set_base_type(M2MBase::BaseType type);
676 
681  static void* memory_alloc(uint32_t size);
682 
687  static void memory_free(void *ptr);
688 
694  static char* alloc_string_copy(const char* source);
695 
702  static uint8_t* alloc_string_copy(const uint8_t* source, uint32_t size);
703 
709  static uint8_t* alloc_copy(const uint8_t* source, uint32_t size);
710 
711  // validate string length to be [min_length..max_length]
712  static bool validate_string_length(const String &string, size_t min_length, size_t max_length);
713  static bool validate_string_length(const char* string, size_t min_length, size_t max_length);
714 
719  M2MReportHandler* create_report_handler();
720 
725  M2MReportHandler* report_handler() const;
726 
727  static bool build_path(StringBuffer<MAX_PATH_SIZE> &buffer, const char *s1, uint16_t i1, const char *s2, uint16_t i2);
728 
729  static bool build_path(StringBuffer<MAX_PATH_SIZE_2> &buffer, const char *s1, uint16_t i1, const char *s2);
730 
731  static bool build_path(StringBuffer<MAX_PATH_SIZE_3> &buffer, const char *s1, uint16_t i1, uint16_t i2);
732 
733  static bool build_path(StringBuffer<MAX_PATH_SIZE_4> &buffer, const char *s1, uint16_t i1);
734 
735  static char* stringdup(const char* s);
736 
743  void free_resources();
744 
749  NotificationDeliveryStatus get_notification_delivery_status() const m2m_deprecated;
750 
754  void clear_notification_delivery_status() m2m_deprecated;
755 
761  void get_observation_token(uint8_t *token, uint8_t &token_length) const;
762 
768  void set_observation_token(const uint8_t *token,
769  const uint8_t length);
770 
777  virtual void set_changed();
778 
782  virtual M2MBase *get_parent() const;
783 
790  static bool is_blockwise_needed(const nsdl_s *nsdl, uint32_t payload_len);
791 
800  void handle_observation(nsdl_s *nsdl,
801  const sn_coap_hdr_s &received_coap_header,
802  sn_coap_hdr_s &coap_response,
804  sn_coap_msg_code_e &response_code);
805 
809  void cancel_observation();
810 
817  void start_observation(const sn_coap_hdr_s &received_coap_header, M2MObservationHandler *observation_handler);
818 
819 #ifdef ENABLE_ASYNC_REST_RESPONSE
820 
827  void call_async_coap_request_callback(sn_coap_hdr_s *coap_request,
828  M2MBase::Operation operation,
829  bool &handled);
830 
835  bool is_async_coap_request_callback_set();
836 
837 #endif //ENABLE_ASYNC_REST_RESPONSE
838 
839 private:
840 
841  static bool is_integer(const String &value);
842 
843  static bool is_integer(const char *value);
844 
845  static char* create_path_base(const M2MBase &parent, const char *name);
846 
847  lwm2m_parameters_s *_sn_resource;
848  M2MReportHandler *_report_handler; // TODO: can be broken down to smaller classes with inheritance.
849 
850 friend class Test_M2MBase;
851 friend class Test_M2MObject;
852 friend class M2MNsdlInterface;
853 friend class M2MInterfaceFactory;
854 friend class M2MObject;
855 };
856 
857 #endif // M2M_BASE_H
bool set_message_delivery_status_cb(message_delivery_status_cb callback, void *client_args)
Sets the function that is executed when message state changes. Currently this is used to track notifi...
sn_nsdl_dynamic_resource_parameters_s * get_nsdl_resource() const
Returns the resource information.
Mode
Enum defining a resource type.
Definition: m2mbase.h:89
Definition: m2mobject.h:35
Definition: m2mobservationhandler.h:30
virtual void set_changed()
The data has changed and it needs to be updated into Device Management. Current implementation mainta...
const char * interface_description() const
Returns the interface description of the object.
size_t resource_name_length() const
Returns length of the object name.
int32_t name_id() const
Returns the object name in integer.
void set_observable(bool observable)
Sets the observable mode for the object.
void free_resources()
Delete the resource structures owned by this object. Note: this needs to be called separately from ea...
void get_observation_token(uint8_t *token, uint8_t &token_length) const
Provides the observation token of the object.
bool is_value_updated_function_set() const
Returns whether a callback function is set or not.
Definition: m2mbase.h:54
void set_register_uri(bool register_uri)
Sets whether this resource is published to server or not.
void set_base_type(M2MBase::BaseType type)
Sets the base type for an object.
void set_under_observation(bool observed, M2MObservationHandler *handler)
Sets the object under observation.
static uint8_t * alloc_copy(const uint8_t *source, uint32_t size)
Allocate (size) amount of memory, copy size bytes into it.
M2MBase::Operation operation() const
Returns the operation type of the object.
void send_notification_delivery_status(const M2MBase &object, const NotificationDeliveryStatus status)
Executes the function that is set in "set_notification_delivery_status_cb". Note: the setter for this...
Observation
Enum to define observation level.
Definition: m2mbase.h:74
Definition: m2mobjectinstance.h:42
virtual sn_coap_hdr_s * handle_get_request(nsdl_s *nsdl, sn_coap_hdr_s *received_coap_header, M2MObservationHandler *observation_handler=NULL)
Handles GET request for the registered objects.
BaseType
Enum to define the type of object.
Definition: m2mbase.h:61
M2MBase::lwm2m_parameters_s * get_lwm2m_parameters() const
Returns the resource structure.
uint16_t observation_number() const
Returns the observation number.
bool register_uri()
Returns whether this resource is published to server or not.
Definition: m2mstringbuffer.h:30
bool is_under_observation() const
Returns whether this resource is under observation or not.
header for StringBuffer.
virtual ~M2MBase()
Destructor.
virtual sn_coap_hdr_s * handle_put_request(nsdl_s *nsdl, sn_coap_hdr_s *received_coap_header, M2MObservationHandler *observation_handler, bool &execute_value_updated)
Handles PUT request for the registered objects.
LwM2M parameters.
Definition: m2mbase.h:199
header for M2MReportObserver
virtual void set_observation_handler(M2MObservationHandler *handler)=0
Sets the observation handler.
virtual bool observation_to_be_sent(const m2m::Vector< uint16_t > &changed_instance_ids, uint16_t obs_number, bool send_object=false)
An observation callback to be sent to the server due to a change in the observed parameter.
CoAP response code values.
static void memory_free(void *ptr)
Memory free functions required for libCoap.
M2MReportHandler * create_report_handler()
Create Report Handler object.
static bool is_blockwise_needed(const nsdl_s *nsdl, uint32_t payload_len)
Checks whether blockwise is needed to send resource value to server.
void cancel_observation()
Cancels the ongoing observation.
bool is_auto_observable() const
Returns the auto observation status of the object.
void set_notification_msgid(uint16_t msgid) m2m_deprecated
Sets the notification message id. This is used to map RESET and EMPTY ACK messages.
DataType
Enum defining a resource data type.
Definition: m2mbase.h:98
bool set_value_updated_function(value_updated_callback callback)
Sets the function that is executed when this object receives a PUT or POST command.
Header for function pointer classes.
Definition: m2mreportobserver.h:27
const char * uri_path() const
Returns the path of the object.
Mode mode() const
Returns the mode of the resource.
bool set_notification_delivery_status_cb(notification_delivery_status_cb callback, void *client_args) m2m_deprecated
Sets the function that is executed when notification message state changes.
void set_interface_description(const String &description)
Sets the interface description of the object.
NotificationDeliveryStatus get_notification_delivery_status() const m2m_deprecated
Returns notification send status.
virtual sn_coap_hdr_s * handle_post_request(nsdl_s *nsdl, sn_coap_hdr_s *received_coap_header, M2MObservationHandler *observation_handler, bool &execute_value_updated, sn_nsdl_addr_s *address=NULL)
Handles GET request for the registered objects.
File defining all system build time configuration used by mbed-client.
A simple C++ Vector class, used as replacement for std::vector.
Definition: m2mvector.h:29
coap_response_code_e
Definition: coap_response.h:26
uint16_t coap_content_type() const
Returns the CoAP content type of the object.
bool read_write_callback_set
If set, all the read and write operations are handled in callbacks and the resource value is not stor...
Definition: m2mbase.h:220
void set_instance_id(const uint16_t instance_id)
Sets the instance ID of the object.
virtual M2MBase * get_parent() const
Returns the owner object. Can return NULL if the object has no parent.
void set_auto_observable(bool auto_observable)
Sets the object to be auto-observable.
uint16_t get_notification_msgid() const m2m_deprecated
Returns the notification message id.
M2MReportHandler * report_handler() const
Returns the Report Handler object.
Definition: m2mresource.h:38
struct M2MBase::lwm2m_parameters lwm2m_parameters_s
LwM2M parameters.
void set_operation(M2MBase::Operation operation)
Sets the operation type for an object.
void send_message_delivery_status(const M2MBase &object, const MessageDeliveryStatus status, const MessageType type)
Executes the function that is set in "set_message_delivery_status_cb".
void set_observation_token(const uint8_t *token, const uint8_t length)
Sets the observation token value.
virtual void remove_observation_level(M2MBase::Observation observation_level)
Removes the observation level for the object.
virtual void add_observation_level(M2MBase::Observation observation_level)
Adds the observation level for the object.
const char * resource_type() const
Returns the resource type of the object.
M2MBase::Observation observation_level() const
Returns the observation level of the object.
Definition: m2minterfacefactory.h:35
bool is_observable() const
Returns the observation status of the object.
bool free_on_delete
true if struct is dynamically allocated and it and its members (name) are to be freed on destructor...
Definition: m2mbase.h:213
static void * memory_alloc(uint32_t size)
Memory allocation required for libCoap.
Operation
Enum defining an operation that can be supported by a given resource.
Definition: m2mbase.h:112
void execute_value_updated(const String &name)
Calls the function that is set in the "set_value_updated_function".
void set_coap_content_type(const uint16_t content_type)
Sets the CoAP content type of the object.
Definition: coap_response.h:30
virtual M2MObservationHandler * observation_handler() const =0
Returns the Observation Handler object.
void handle_observation(nsdl_s *nsdl, const sn_coap_hdr_s &received_coap_header, sn_coap_hdr_s &coap_response, M2MObservationHandler *observation_handler, sn_coap_msg_code_e &response_code)
Handles subscription request.
MessageDeliveryStatus
Enum defining an status codes that can happen when sending confirmable message.
Definition: m2mbase.h:135
virtual void set_resource_type(const String &resource_type)
Sets the resource type of the object.
void clear_notification_delivery_status() m2m_deprecated
Clears the notification send status to initial state.
Definition: functionpointer.h:113
Parameter identifier.
void set_max_age(const uint32_t max_age)
Sets the max age for the resource value to be cached.
void start_observation(const sn_coap_hdr_s &received_coap_header, M2MObservationHandler *observation_handler)
Start the observation.
static char * alloc_string_copy(const char *source)
Allocate and make a copy of given zero terminated string. This is functionally equivalent with strdup...