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/include/m2mreporthandler.h
- Committer:
- edamame22
- Date:
- 2017-04-13
- Revision:
- 0:29983394c6b6
File content as of revision 0:29983394c6b6:
/* * 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. */ #ifndef M2MREPORTHANDLER_H #define M2MREPORTHANDLER_H // Support for std args #include <stdint.h> #include "mbed-client/m2mconfig.h" #include "mbed-client/m2mbase.h" #include "mbed-client/m2mtimerobserver.h" #include "mbed-client/m2mresourceinstance.h" #include "mbed-client/m2mvector.h" #include "mbed-client/m2mtimer.h" //FORWARD DECLARATION class M2MReportObserver; class M2MTimer; class M2MResourceInstance; /** * @brief M2MReportHandler. * This class is handles all the observation related operations. */ class M2MReportHandler: public M2MTimerObserver { private: // Prevents the use of assignment operator by accident. M2MReportHandler& operator=( const M2MReportHandler& /*other*/ ); public: M2MReportHandler(M2MReportObserver &observer); public: /** * Enum defining which write attributes are set. */ enum { Cancel = 1, Pmin = 2, Pmax = 4, Lt = 8, Gt = 16, St = 32 }; /** * Destructor */ virtual ~M2MReportHandler(); /** * @brief Sets that object is under observation. * @param Value for the observation. * @param handler, Handler object for sending * observation callbacks. */ void set_under_observation(bool observed); /** * @brief Sets the value of the given resource. * @param value, Value of the observed resource. */ void set_value(float value); /** * @brief Sets notification trigger. * @param obj_instance_id, Object instance id that has changed */ void set_notification_trigger(uint16_t obj_instance_id = 0); /** * @brief Parses the received query for notification * attribute. * @param query Query to be parsed for attributes. * @param type Type of the Base Object. * @param resource_type Type of the Resource. * @return true if required attributes are present else false. */ bool parse_notification_attribute(const char *query, M2MBase::BaseType type, M2MResourceInstance::ResourceType resource_type = M2MResourceInstance::OPAQUE); /** * @brief Set back to default values. */ void set_default_values(); /** * @brief Return write attribute flags. */ uint8_t attribute_flags(); protected : // from M2MTimerObserver virtual void timer_expired(M2MTimerObserver::Type type = M2MTimerObserver::Notdefined); private: bool set_notification_attribute(const char* option, M2MBase::BaseType type, M2MResourceInstance::ResourceType resource_type); /** * @brief Schedule a report, if the pmin is exceeded * then report immediately else store the state to be * reported once the time fires. */ void schedule_report(); /** * @brief Reports a sample that satisfies the reporting criteria. */ void report(); /** * @brief Manage timers for pmin and pmax. */ void handle_timers(); /** * @brief Check whether notification params can be accepted. */ bool check_attribute_validity(); /** * @brief Stop pmin & pmax timers. */ void stop_timers(); /** * @brief Check if current value match threshold values. * @return True if notify can be send otherwise false. */ bool check_threshold_values(); /** * @brief Check whether current value matches with GT & LT. * @return True if current value match with GT or LT values. */ bool check_gt_lt_params(); private: M2MReportObserver &_observer; uint8_t _attribute_state; bool _notify; bool _pmin_exceeded; bool _pmax_exceeded; M2MTimer _pmin_timer; M2MTimer _pmax_timer; int32_t _pmax; int32_t _pmin; float _current_value; float _gt; float _lt; float _st; float _high_step; float _low_step; float _last_value; m2m::Vector<uint16_t> _changed_instance_ids; friend class Test_M2MReportHandler; }; #endif // M2MREPORTHANDLER_H