Mistake on this page? Email us
m2mobjectinstance.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_OBJECT_INSTANCE_H
17 #define M2M_OBJECT_INSTANCE_H
18 
19 #include "mbed-client/m2mvector.h"
21 
22 //FORWARD DECLARATION
23 typedef Vector<M2MResource *> M2MResourceList;
24 typedef Vector<M2MResourceInstance *> M2MResourceInstanceList;
25 
26 
27 class M2MObject;
28 
42 class M2MObjectInstance : public M2MBase
43 {
44 
45 friend class M2MObject;
46 
47 private:
53  const String &resource_type,
54  char *path,
55  bool external_blockwise_store = false);
56 
57  M2MObjectInstance(M2MObject& parent, const lwm2m_parameters_s* static_res);
58 
59  // Prevents the use of default constructor.
61 
62  // Prevents the use of assignment operator.
63  M2MObjectInstance& operator=( const M2MObjectInstance& /*other*/ );
64 
65  // Prevents the use of copy constructor.
66  M2MObjectInstance( const M2MObjectInstance& /*other*/ );
67 
71  virtual ~M2MObjectInstance();
72 
73 public:
74 
81 
95  M2MResource* create_static_resource(const String &resource_name,
96  const String &resource_type,
98  const uint8_t *value,
99  const uint8_t value_length,
100  bool multiple_instance = false,
101  bool external_blockwise_store = false);
102 
116  M2MResource* create_dynamic_resource(const String &resource_name,
117  const String &resource_type,
119  bool observable,
120  bool multiple_instance = false,
121  bool external_blockwise_store = false);
122 
136  M2MResource* create_dynamic_resource(const uint16_t resource_name,
137  const char *resource_type,
139  bool observable,
140  bool multiple_instance = false,
141  bool external_blockwise_store = false);
142 
149  bool observable);
150 
163  M2MResourceInstance* create_static_resource_instance(const String &resource_name,
164  const String &resource_type,
166  const uint8_t *value,
167  const uint8_t value_length,
168  uint16_t instance_id,
169  bool external_blockwise_store = false);
170 
183  M2MResourceInstance* create_dynamic_resource_instance(const String &resource_name,
184  const String &resource_type,
186  bool observable,
187  uint16_t instance_id,
188  bool external_blockwise_store = false);
189 
197  bool remove_resource(const String &name);
198 
204  bool remove_resource(const char *name);
205 
212  bool remove_resource_instance(const String &resource_name,
213  uint16_t instance_id);
214 
220  M2MResource* resource(const uint16_t resource_id) const;
221 
222  M2MResource* resource(const String &name) const;
223 
224  M2MResource* resource(const char *resource) const;
225 
230  const M2MResourceList& resources() const;
231 
236  uint16_t resource_count() const;
237 
245  uint16_t resource_count(const String& resource) const;
246 
252  uint16_t resource_count(const char *resource) const;
253 
259 
264  virtual void remove_observation_level(M2MBase::Observation observation_level);
265 
271 
276  virtual void set_observation_handler(M2MObservationHandler *handler);
277 
286  virtual sn_coap_hdr_s* handle_get_request(nsdl_s *nsdl,
287  sn_coap_hdr_s *received_coap_header,
288  M2MObservationHandler *observation_handler = NULL);
298  virtual sn_coap_hdr_s* handle_put_request(nsdl_s *nsdl,
299  sn_coap_hdr_s *received_coap_header,
300  M2MObservationHandler *observation_handler,
301  bool &execute_value_updated);
302 
312  virtual sn_coap_hdr_s* handle_post_request(nsdl_s *nsdl,
313  sn_coap_hdr_s *received_coap_header,
314  M2MObservationHandler *observation_handler,
315  bool &execute_value_updated,
316  sn_nsdl_addr_s *address = NULL);
317 
318  inline M2MObject& get_parent_object() const;
319 
320  // callback used from M2MResource/M2MResourceInstance
321  void notification_update(M2MBase::Observation observation_level);
322 
323 protected:
324  virtual M2MBase *get_parent() const;
325 
326 private:
327 
335 
336 private:
337 
338  M2MObject &_parent;
339 
340  M2MResourceList _resource_list; // owned
341 
342  friend class Test_M2MObjectInstance;
343  friend class Test_M2MObject;
344  friend class Test_M2MDevice;
345  friend class Test_M2MSecurity;
346  friend class Test_M2MServer;
347  friend class Test_M2MInterfaceFactory;
348  friend class Test_M2MNsdlInterface;
349  friend class Test_M2MTLVSerializer;
350  friend class Test_M2MTLVDeserializer;
351  friend class Test_M2MBase;
352  friend class Test_M2MResource;
353  friend class Test_M2MResourceInstance;
354  friend class Test_M2MReportHandler;
355  friend class TestFactory;
356 };
357 
358 inline M2MObject& M2MObjectInstance::get_parent_object() const
359 {
360  return _parent;
361 }
362 
363 #endif // M2M_OBJECT_INSTANCE_H
Definition: m2mobject.h:35
Definition: m2mobservationhandler.h:30
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.
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 POST request for the registered objects.
Definition: m2mbase.h:54
M2MResource * create_static_resource(const lwm2m_parameters_s *static_res, M2MResourceInstance::ResourceType type)
TODO!
Observation
Enum to define observation level.
Definition: m2mbase.h:74
virtual void add_observation_level(M2MBase::Observation observation_level)
Adds the observation level for the object.
const char * name() const
Returns the object name.
Definition: m2mobjectinstance.h:42
ResourceType
Definition: m2mresourcebase.h:70
uint16_t resource_count() const
Returns the total number of resources with the object.
LwM2M parameters.
Definition: m2mbase.h:199
virtual M2MObservationHandler * observation_handler() const
Returns the Observation Handler object.
bool remove_resource(const String &name)
Removes the resource with the given name.
header for M2MResource.
DataType
Enum defining a resource data type.
Definition: m2mbase.h:98
M2MResourceInstance * create_static_resource_instance(const String &resource_name, const String &resource_type, M2MResourceInstance::ResourceType type, const uint8_t *value, const uint8_t value_length, uint16_t instance_id, bool external_blockwise_store=false)
Creates a static resource instance for a given mbed Client Inteface object. With this, the client can respond to server&#39;s GET methods with the provided value.
bool remove_resource_instance(const String &resource_name, uint16_t instance_id)
Removes the resource instance with the given name.
Definition: m2mresourceinstance.h:38
header for m2m::Vector
M2MResource * resource(const uint16_t resource_id) const
Returns the resource with the given name.
virtual void set_observation_handler(M2MObservationHandler *handler)
Sets the observation handler.
virtual M2MBase * get_parent() const
Returns the owner object. Can return NULL if the object has no parent.
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.
M2MResourceInstance * create_dynamic_resource_instance(const String &resource_name, const String &resource_type, M2MResourceInstance::ResourceType type, bool observable, uint16_t instance_id, bool external_blockwise_store=false)
Creates a dynamic resource instance for a given mbed Client Inteface object. With this...
Definition: m2mresource.h:38
const M2MResourceList & resources() const
Returns a list of M2MResourceBase objects.
const char * resource_type() const
Returns the resource type of the object.
M2MBase::Observation observation_level() const
Returns the observation level of the object.
M2MResource * create_dynamic_resource(const String &resource_name, const String &resource_type, M2MResourceInstance::ResourceType type, bool observable, bool multiple_instance=false, bool external_blockwise_store=false)
Creates a dynamic resource for a given mbed Client Inteface object. With this, the client can respond...
uint16_t instance_id() const
Returns the object&#39;s instance ID.
virtual void remove_observation_level(M2MBase::Observation observation_level)
Removes the observation level from the object.
void execute_value_updated(const String &name)
Calls the function that is set in the "set_value_updated_function".