This is an example of BLE GATT Client, which receives broadcast data from BLE_Server_BME280 ( a GATT server) , then transfers values up to mbed Device Connector (cloud).
Please refer details about BLEClient_mbedDevConn below. https://github.com/soramame21/BLEClient_mbedDevConn
The location of required BLE GATT server, BLE_Server_BME280, is at here. https://developer.mbed.org/users/edamame22/code/BLE_Server_BME280/
mbed-client/source/m2mfirmware.cpp
- Committer:
- Ren Boting
- Date:
- 2017-09-05
- Revision:
- 2:b894b3508057
- Parent:
- 0:29983394c6b6
File content as of revision 2:b894b3508057:
/* * Copyright (c) 2015 ARM Limited. All rights reserved. * SPDX-License-Identifier: Apache-2.0 * 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. */ #include "mbed-client/m2mfirmware.h" #include "mbed-client/m2mconstants.h" #include "mbed-client/m2mobject.h" #include "mbed-client/m2mobjectinstance.h" #include "mbed-client/m2mresource.h" #include "include/nsdlaccesshelper.h" #define BUFFER_SIZE 21 #define TRACE_GROUP "mClt" M2MFirmware* M2MFirmware::_instance = NULL; M2MFirmware* M2MFirmware::get_instance() { if(_instance == NULL) { _instance = new M2MFirmware(); } return _instance; } void M2MFirmware::delete_instance() { delete _instance; _instance = NULL; } M2MFirmware::M2MFirmware() : M2MObject(M2M_FIRMWARE_ID, stringdup(M2M_FIRMWARE_ID)) { M2MBase::set_register_uri(false); M2MBase::set_operation(M2MBase::GET_PUT_ALLOWED); _firmware_instance = M2MObject::create_object_instance(); if(_firmware_instance) { _firmware_instance->set_operation(M2MBase::GET_PUT_ALLOWED); create_mandatory_resources(); } } M2MFirmware::~M2MFirmware() { } // Conditionally put the static part of parameter struct into flash. // Unfortunately this can't be done yet by default as there is old API which // may be used to modify the values in sn_nsdl_static_resource_parameters_s. #ifdef MEMORY_OPTIMIZED_API #define STATIC_PARAM_TYPE const #else #define STATIC_PARAM_TYPE #endif #define PACKAGE_PATH FIRMWARE_PATH_PREFIX FIRMWARE_PACKAGE STATIC_PARAM_TYPE static sn_nsdl_static_resource_parameters_s firmware_package_params_static = { (char*)OMA_RESOURCE_TYPE, // resource_type_ptr (char*)"", // interface_description_ptr (uint8_t*)PACKAGE_PATH, // path (uint8_t*)"", // resource 5, // strlen("5/0/0") 0, // resourcelen false, // external_memory_block SN_GRS_DYNAMIC, // mode false // free_on_delete }; #define PACKAGE_URI_PATH FIRMWARE_PATH_PREFIX FIRMWARE_PACKAGE_URI STATIC_PARAM_TYPE static sn_nsdl_static_resource_parameters_s firmware_package_uri_params_static = { (char*)OMA_RESOURCE_TYPE, // resource_type_ptr (char*)"", // interface_description_ptr (uint8_t*)PACKAGE_URI_PATH, // path (uint8_t*)"", // resource 5, // strlen("5/0/1") 0, // resourcelen false, // external_memory_block SN_GRS_DYNAMIC, // mode false // free_on_delete }; #define UPDATE_PATH FIRMWARE_PATH_PREFIX FIRMWARE_UPDATE STATIC_PARAM_TYPE static sn_nsdl_static_resource_parameters_s firmware_update_params_static = { (char*)OMA_RESOURCE_TYPE, // resource_type_ptr (char*)"", // interface_description_ptr (uint8_t*)UPDATE_PATH, // path (uint8_t*)"", // resource 5, // strlen(5/0/2) 0, // resourcelen false, // external_memory_block SN_GRS_DYNAMIC, // mode false // free_on_delete }; #define STATE_URI_PATH FIRMWARE_PATH_PREFIX FIRMWARE_STATE STATIC_PARAM_TYPE static sn_nsdl_static_resource_parameters_s firmware_state_params_static = { (char*)OMA_RESOURCE_TYPE, // resource_type_ptr (char*)"", // interface_description_ptr (uint8_t*)STATE_URI_PATH, // path (uint8_t*)"0", // resource 5, // strlen("5/0/3") 1, // resourcelen false, // external_memory_block SN_GRS_DYNAMIC, // mode false // free_on_delete }; #define UPDATE_RESULT_PATH FIRMWARE_PATH_PREFIX FIRMWARE_UPDATE_RESULT STATIC_PARAM_TYPE static sn_nsdl_static_resource_parameters_s firmware_update_result_params_static = { (char*)OMA_RESOURCE_TYPE, // resource_type_ptr (char*)"", // interface_description_ptr (uint8_t*)UPDATE_RESULT_PATH, // path (uint8_t*)"0", // resource 5, // strlen(5/0/5) 1, // resourcelen false, // external_memory_block SN_GRS_DYNAMIC, // mode false // free_on_delete }; static sn_nsdl_dynamic_resource_parameters_s firmware_package_params_dynamic = { __nsdl_c_callback, &firmware_package_params_static, {NULL, NULL}, // link COAP_CONTENT_OMA_PLAIN_TEXT_TYPE, // coap_content_type M2MBase::PUT_ALLOWED, // access 0, // registered false, // publish_uri false, // free_on_delete true // observable }; static sn_nsdl_dynamic_resource_parameters_s firmware_package_uri_params_dynamic = { __nsdl_c_callback, &firmware_package_uri_params_static, {NULL, NULL}, // link COAP_CONTENT_OMA_PLAIN_TEXT_TYPE, // coap_content_type M2MBase::PUT_ALLOWED, // access 0, // registered false, // publish_uri false, // free_on_delete true // observable }; static sn_nsdl_dynamic_resource_parameters_s firmware_update_params_dynamic = { __nsdl_c_callback, &firmware_update_params_static, {NULL, NULL}, // link COAP_CONTENT_OMA_PLAIN_TEXT_TYPE, // coap_content_type M2MBase::NOT_ALLOWED, // access 0, // registered false, // publish_uri false, // free_on_delete true // observable }; static sn_nsdl_dynamic_resource_parameters_s firmware_state_params_dynamic = { __nsdl_c_callback, &firmware_state_params_static, {NULL, NULL}, // link COAP_CONTENT_OMA_PLAIN_TEXT_TYPE, // coap_content_type M2MBase::GET_ALLOWED, // access 0, // registered false, // publish_uri false, // free_on_delete true // observable }; static sn_nsdl_dynamic_resource_parameters_s firmware_update_result_params_dynamic = { __nsdl_c_callback, &firmware_update_result_params_static, {NULL, NULL}, // link COAP_CONTENT_OMA_PLAIN_TEXT_TYPE, // coap_content_type M2MBase::GET_ALLOWED, // access 0, // registered false, // publish_uri false, // free_on_delete true // observable }; const static M2MBase::lwm2m_parameters firmware_package_params = { 0, // max_age 0, // instance_id 0, // name_id (char*)FIRMWARE_PACKAGE, // name &firmware_package_params_dynamic, M2MBase::Resource, // base_type false // free_on_delete }; const static M2MBase::lwm2m_parameters firmware_package_uri_params = { 0, // max_age 0, // instance_id 0, // name_id (char*)FIRMWARE_PACKAGE_URI, // name &firmware_package_uri_params_dynamic, M2MBase::Resource, // base_type false // free_on_delete }; const static M2MBase::lwm2m_parameters firmware_update_params = { 0, // max_age 0, // instance_id 0, // name_id (char*)FIRMWARE_UPDATE, // name &firmware_update_params_dynamic, M2MBase::Resource, // base_type false // free_on_delete }; const static M2MBase::lwm2m_parameters firmware_state_params = { 0, // max_age 0, // instance_id 0, // name_id (char*)FIRMWARE_STATE, // name &firmware_state_params_dynamic, M2MBase::Resource, // base_type false // free_on_delete }; const static M2MBase::lwm2m_parameters firmware_update_result_params = { 0, // max_age 0, // instance_id 0, // name_id (char*)FIRMWARE_UPDATE_RESULT, // name &firmware_update_result_params_dynamic, M2MBase::Resource, // base_type false // free_on_delete }; void M2MFirmware::create_mandatory_resources() { _firmware_instance->set_coap_content_type(COAP_CONTENT_OMA_TLV_TYPE); M2MResource* res; // todo: // perhaps we should have a API for batch creation of objects by using a array // of lwm2m_parameters. res = _firmware_instance->create_dynamic_resource(&firmware_package_params, M2MResourceInstance::OPAQUE, false); res = _firmware_instance->create_dynamic_resource(&firmware_package_uri_params, M2MResourceInstance::STRING, false); res = _firmware_instance->create_dynamic_resource(&firmware_update_params, M2MResourceInstance::OPAQUE, false); res = _firmware_instance->create_dynamic_resource(&firmware_state_params, M2MResourceInstance::INTEGER, true); res = _firmware_instance->create_dynamic_resource(&firmware_update_result_params, M2MResourceInstance::INTEGER, true); } M2MResource* M2MFirmware::create_resource(FirmwareResource resource, const String &value) { M2MResource* res = NULL; const char* firmware_id_ptr = ""; M2MBase::Operation operation = M2MBase::GET_ALLOWED; if(!is_resource_present(resource)) { switch(resource) { case PackageName: firmware_id_ptr = FIRMWARE_PACKAGE_NAME; break; case PackageVersion: firmware_id_ptr = FIRMWARE_PACKAGE_VERSION; break; default: break; } } String firmware_id(firmware_id_ptr); if(!firmware_id.empty() && value.size() < 256) { if(_firmware_instance) { res = _firmware_instance->create_dynamic_resource(firmware_id, OMA_RESOURCE_TYPE, M2MResourceInstance::STRING, false); if(res) { res->set_register_uri(false); res->set_operation(operation); if(value.empty()) { res->clear_value(); } else { res->set_value((const uint8_t*)value.c_str(), (uint32_t)value.length()); } } } } return res; } M2MResource* M2MFirmware::create_resource(FirmwareResource resource, int64_t value) { M2MResource* res = NULL; const char* firmware_id_ptr = ""; M2MBase::Operation operation = M2MBase::GET_ALLOWED; if(!is_resource_present(resource)) { switch(resource) { case UpdateSupportedObjects: if(check_value_range(resource, value)) { firmware_id_ptr = FIRMWARE_UPDATE_SUPPORTED_OBJECTS; operation = M2MBase::GET_PUT_ALLOWED; } break; default: break; } } const String firmware_id(firmware_id_ptr); if(!firmware_id.empty()) { if(_firmware_instance) { res = _firmware_instance->create_dynamic_resource(firmware_id, OMA_RESOURCE_TYPE, M2MResourceInstance::INTEGER, false); if(res) { res->set_register_uri(false); res->set_operation(operation); res->set_value(value); } } } return res; } bool M2MFirmware::set_resource_value(FirmwareResource resource, const String &value) { bool success = false; M2MResource* res = get_resource(resource); if(res) { if(M2MFirmware::PackageUri == resource || M2MFirmware::PackageName == resource || M2MFirmware::PackageVersion == resource) { if (value.size() < 256) { if(value.empty()) { res->clear_value(); success = true; } else { success = res->set_value((const uint8_t*)value.c_str(),(uint32_t)value.length()); } } } } return success; } bool M2MFirmware::set_resource_value(FirmwareResource resource, int64_t value) { bool success = false; M2MResource* res = get_resource(resource); if(res) { if(M2MFirmware::State == resource || M2MFirmware::UpdateSupportedObjects == resource || M2MFirmware::UpdateResult == resource) { // If it is any of the above resource // set the value of the resource. if (check_value_range(resource, value)) { success = res->set_value(value); } } } return success; } bool M2MFirmware::set_resource_value(FirmwareResource resource, const uint8_t *value, const uint32_t length) { bool success = false; M2MResource* res = get_resource(resource); if(res) { if(M2MFirmware::Package == resource) { success = res->set_value(value,length); } } return success; } bool M2MFirmware::is_resource_present(FirmwareResource resource) const { bool success = false; M2MResource* res = get_resource(resource); if(res) { success = true; } return success; } const char* M2MFirmware::resource_name(FirmwareResource resource) { const char* res_name = ""; switch(resource) { case Package: res_name = FIRMWARE_PACKAGE; break; case PackageUri: res_name = FIRMWARE_PACKAGE_URI; break; case Update: res_name = FIRMWARE_UPDATE; break; case State: res_name = FIRMWARE_STATE; break; case UpdateSupportedObjects: res_name = FIRMWARE_UPDATE_SUPPORTED_OBJECTS; break; case UpdateResult: res_name = FIRMWARE_UPDATE_RESULT; break; case PackageName: res_name = FIRMWARE_PACKAGE_NAME; break; case PackageVersion: res_name = FIRMWARE_PACKAGE_VERSION; break; } return res_name; } uint16_t M2MFirmware::per_resource_count(FirmwareResource res) const { uint16_t count = 0; if(_firmware_instance) { count = _firmware_instance->resource_count(resource_name(res)); } return count; } uint16_t M2MFirmware::total_resource_count() const { uint16_t count = 0; if(_firmware_instance) { count = _firmware_instance->resources().size(); } return count; } uint32_t M2MFirmware::resource_value_buffer(FirmwareResource resource, uint8_t *&data) const { uint32_t size = 0; M2MResource* res = get_resource(resource); if(res) { if(M2MFirmware::Package == resource) { res->get_value(data,size); } } return size; } M2MResource* M2MFirmware::get_resource(FirmwareResource res) const { M2MResource* res_object = NULL; if(_firmware_instance) { const char* res_name_ptr = ""; switch(res) { case Package: res_name_ptr = FIRMWARE_PACKAGE; break; case PackageUri: res_name_ptr = FIRMWARE_PACKAGE_URI; break; case Update: res_name_ptr = FIRMWARE_UPDATE; break; case State: res_name_ptr = FIRMWARE_STATE; break; case UpdateSupportedObjects: res_name_ptr = FIRMWARE_UPDATE_SUPPORTED_OBJECTS; break; case UpdateResult: res_name_ptr = FIRMWARE_UPDATE_RESULT; break; case PackageName: res_name_ptr = FIRMWARE_PACKAGE_NAME; break; case PackageVersion: res_name_ptr = FIRMWARE_PACKAGE_VERSION; break; } res_object = _firmware_instance->resource(res_name_ptr); } return res_object; } bool M2MFirmware::delete_resource(FirmwareResource resource) { bool success = false; if(M2MFirmware::UpdateSupportedObjects == resource || M2MFirmware::PackageName == resource || M2MFirmware::PackageVersion == resource) { if(_firmware_instance) { success = _firmware_instance->remove_resource(resource_name(resource)); } } return success; } int64_t M2MFirmware::resource_value_int(FirmwareResource resource) const { int64_t value = -1; M2MResource* res = get_resource(resource); if(res) { if(M2MFirmware::State == resource || M2MFirmware::UpdateSupportedObjects == resource || M2MFirmware::UpdateResult == resource) { value = res->get_value_int(); } } return value; } String M2MFirmware::resource_value_string(FirmwareResource resource) const { String value = ""; M2MResource* res = get_resource(resource); if(res) { if(M2MFirmware::PackageUri == resource || M2MFirmware::PackageName == resource || M2MFirmware::PackageVersion == resource) { value = res->get_value_string(); } } return value; } bool M2MFirmware::check_value_range(FirmwareResource resource, int64_t value) const { bool success = false; switch (resource) { case UpdateSupportedObjects: if(value == 0 || value == 1) { success = true; } break; case State: if (value >= 0 && value <= 3) { success = true; M2MResource* updateRes = get_resource(M2MFirmware::Update); if (updateRes){ if (value == M2MFirmware::Downloaded) { updateRes->set_operation(M2MBase::POST_ALLOWED); } else { updateRes->set_operation(M2MBase::NOT_ALLOWED); } } } break; case UpdateResult: if (value >= 0 && value <= 7) { success = true; } break; default: break; } return success; }