1d62aa1c5SMilanka Ringwald /* 2d62aa1c5SMilanka Ringwald * Copyright (C) 2024 BlueKitchen GmbH 3d62aa1c5SMilanka Ringwald * 4d62aa1c5SMilanka Ringwald * Redistribution and use in source and binary forms, with or without 5d62aa1c5SMilanka Ringwald * modification, are permitted provided that the following conditions 6d62aa1c5SMilanka Ringwald * are met: 7d62aa1c5SMilanka Ringwald * 8d62aa1c5SMilanka Ringwald * 1. Redistributions of source code must retain the above copyright 9d62aa1c5SMilanka Ringwald * notice, this list of conditions and the following disclaimer. 10d62aa1c5SMilanka Ringwald * 2. Redistributions in binary form must reproduce the above copyright 11d62aa1c5SMilanka Ringwald * notice, this list of conditions and the following disclaimer in the 12d62aa1c5SMilanka Ringwald * documentation and/or other materials provided with the distribution. 13d62aa1c5SMilanka Ringwald * 3. Neither the name of the copyright holders nor the names of 14d62aa1c5SMilanka Ringwald * contributors may be used to endorse or promote products derived 15d62aa1c5SMilanka Ringwald * from this software without specific prior written permission. 16d62aa1c5SMilanka Ringwald * 4. Any redistribution, use, or modification is done solely for 17d62aa1c5SMilanka Ringwald * personal benefit and not for any commercial purpose or for 18d62aa1c5SMilanka Ringwald * monetary gain. 19d62aa1c5SMilanka Ringwald * 20d62aa1c5SMilanka Ringwald * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS 21d62aa1c5SMilanka Ringwald * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 22d62aa1c5SMilanka Ringwald * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 23d62aa1c5SMilanka Ringwald * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BLUEKITCHEN 24d62aa1c5SMilanka Ringwald * GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 25d62aa1c5SMilanka Ringwald * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 26d62aa1c5SMilanka Ringwald * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 27d62aa1c5SMilanka Ringwald * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 28d62aa1c5SMilanka Ringwald * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 29d62aa1c5SMilanka Ringwald * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 30d62aa1c5SMilanka Ringwald * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 31d62aa1c5SMilanka Ringwald * SUCH DAMAGE. 32d62aa1c5SMilanka Ringwald * 33d62aa1c5SMilanka Ringwald * Please inquire about commercial licensing options at 34d62aa1c5SMilanka Ringwald * [email protected] 35d62aa1c5SMilanka Ringwald * 36d62aa1c5SMilanka Ringwald */ 37d62aa1c5SMilanka Ringwald 38d62aa1c5SMilanka Ringwald /** 39d62aa1c5SMilanka Ringwald * @title Battery Service Server v1.1 40d62aa1c5SMilanka Ringwald * 41d62aa1c5SMilanka Ringwald */ 42d62aa1c5SMilanka Ringwald 43d62aa1c5SMilanka Ringwald #ifndef BATTERY_SERVICE_V1_SERVER_H 44d62aa1c5SMilanka Ringwald #define BATTERY_SERVICE_V1_SERVER_H 45d62aa1c5SMilanka Ringwald 46d62aa1c5SMilanka Ringwald #include <stdint.h> 47d62aa1c5SMilanka Ringwald 48d62aa1c5SMilanka Ringwald #if defined __cplusplus 49d62aa1c5SMilanka Ringwald extern "C" { 50d62aa1c5SMilanka Ringwald #endif 51d62aa1c5SMilanka Ringwald 52d62aa1c5SMilanka Ringwald /** 53d62aa1c5SMilanka Ringwald * @text The Battery Service allows to query your device's battery level in a standardized way. 54d62aa1c5SMilanka Ringwald * 55d62aa1c5SMilanka Ringwald * To use with your application, add `#import <battery_service.gatt>` to your .gatt file. 56d62aa1c5SMilanka Ringwald * After adding it to your .gatt file, you call *battery_service_server_init(value)* with the 57d62aa1c5SMilanka Ringwald * current value of your battery. The valid range for the battery level is 0-100. 58d62aa1c5SMilanka Ringwald * 59d62aa1c5SMilanka Ringwald * If the battery level changes, you can call *battery_service_server_set_battery_value(value)*. 60d62aa1c5SMilanka Ringwald * The service supports sending Notifications if the client enables them. 61d62aa1c5SMilanka Ringwald */ 62e5ae30daSMilanka Ringwald 63e5ae30daSMilanka Ringwald typedef enum { 64e5ae30daSMilanka Ringwald BAS_CHARACTERISTIC_INDEX_BATTERY_LEVEL = 0, 65e5ae30daSMilanka Ringwald BAS_CHARACTERISTIC_INDEX_BATTERY_LEVEL_STATUS, 66e5ae30daSMilanka Ringwald BAS_CHARACTERISTIC_INDEX_ESTIMATED_SERVICE_DATE, 67e5ae30daSMilanka Ringwald BAS_CHARACTERISTIC_INDEX_BATTERY_CRITCAL_STATUS, 68e5ae30daSMilanka Ringwald BAS_CHARACTERISTIC_INDEX_BATTERY_ENERGY_STATUS, 69e5ae30daSMilanka Ringwald BAS_CHARACTERISTIC_INDEX_BATTERY_TIME_STATUS, 70e5ae30daSMilanka Ringwald BAS_CHARACTERISTIC_INDEX_BATTERY_HEALTH_STATUS, 71e5ae30daSMilanka Ringwald BAS_CHARACTERISTIC_INDEX_BATTERY_HEALTH_INFORMATION, 72e5ae30daSMilanka Ringwald BAS_CHARACTERISTIC_INDEX_BATTERY_INFORMATION, 73e5ae30daSMilanka Ringwald BAS_CHARACTERISTIC_INDEX_MANUFACTURER_NAME_STRING, 74e5ae30daSMilanka Ringwald BAS_CHARACTERISTIC_INDEX_MODEL_NUMBER_STRING, 75e5ae30daSMilanka Ringwald BAS_CHARACTERISTIC_INDEX_SERIAL_NUMBER_STRING, 76e5ae30daSMilanka Ringwald BAS_CHARACTERISTIC_INDEX_NUM 77e5ae30daSMilanka Ringwald } bas_characteristic_index_t; 78e5ae30daSMilanka Ringwald 79e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_ENERGY_STATUS flags: 80e5ae30daSMilanka Ringwald #define BATTERY_ENERGY_STATUS_BITMASK_EXTERNAL_SOURCE_POWER_PRESENT 0x01 81e5ae30daSMilanka Ringwald #define BATTERY_ENERGY_STATUS_BITMASK_PRESENT_VOLTAGE_PRESENT 0x02 82e5ae30daSMilanka Ringwald #define BATTERY_ENERGY_STATUS_BITMASK_AVAILABLE_ENERGY_PRESENT 0x04 83e5ae30daSMilanka Ringwald #define BATTERY_ENERGY_STATUS_BITMASK_AVAILABLE_BATTERY_CAPACITY_PRESENT 0x08 84e5ae30daSMilanka Ringwald #define BATTERY_ENERGY_STATUS_BITMASK_CHARGE_RATE_PRESENT 0x10 85e5ae30daSMilanka Ringwald #define BATTERY_ENERGY_STATUS_BITMASK_AVAILABLE_ENERGY_AT_LAST_CHARGE_PRESENT 0x20 86e5ae30daSMilanka Ringwald #define BATTERY_ENERGY_STATUS_BITMASK_RFU 0x40 87e5ae30daSMilanka Ringwald 88e5ae30daSMilanka Ringwald #define BATTERY_LEVEL_STATUS_BITMASK_IDENTIFIER_PRESENT 0x01 89e5ae30daSMilanka Ringwald #define BATTERY_LEVEL_STATUS_BITMASK_BATTERY_LEVEL_PRESENT 0x02 90e5ae30daSMilanka Ringwald #define BATTERY_LEVEL_STATUS_BITMASK_ADDITIONAL_STATUS_PRESENT 0x04 91e5ae30daSMilanka Ringwald #define BATTERY_LEVEL_STATUS_BITMASK_RFU 0x08 92e5ae30daSMilanka Ringwald 93038930d0SMilanka Ringwald #define BATTERY_LEVEL_ADDITIONAL_STATUS_BITMASK_SERVICE_REQUIRED 0x01 // 0 = No, 1 = Yes, 2 = Unknown, 3 = RFU 94038930d0SMilanka Ringwald #define BATTERY_LEVEL_ADDITIONAL_STATUS_BITMASK_BATTERY_FAULT 0x02 // 0 = No or Unknown, 1 = Yes 95038930d0SMilanka Ringwald #define BATTERY_LEVEL_ADDITIONAL_STATUS_BITMASK_RFU 0x04 96038930d0SMilanka Ringwald 97e5ae30daSMilanka Ringwald #define BATTERY_LEVEL_POWER_STATE_BITMASK_EXTERNAL_BATTERY_PRESENT 0x0001 // 0 = No, 1 = Yes 98e5ae30daSMilanka Ringwald #define BATTERY_LEVEL_POWER_STATE_BITMASK_WIRED_EXTERNAL_POWER_SOURCE_CONNECTED 0x0004 // 0 = No, 1 = Yes, 2 = Unknown, 3 = RFU 99e5ae30daSMilanka Ringwald #define BATTERY_LEVEL_POWER_STATE_BITMASK_WIRELESS_EXTERNAL_POWER_SOURCE_CONNECTED 0x0010 // 0 = No, 1 = Yes, 2 = Unknown, 3 = RFU 100e5ae30daSMilanka Ringwald #define BATTERY_LEVEL_POWER_STATE_BITMASK_BATTERY_CHARGE_STATE 0x0040 // 0 = Unknown, 1 = Charging, 2 = Discharging: Active 3 = Discharging: Inactive 101e5ae30daSMilanka Ringwald #define BATTERY_LEVEL_POWER_STATE_BITMASK_BATTERY_CHARGE_LEVEL 0x0100 // 0 = Unknown, 1 = Good, 2 = Low, 3 = Critical 102e5ae30daSMilanka Ringwald #define BATTERY_LEVEL_POWER_STATE_BITMASK_CHARGING_TYPE 0x0400 // 0 = Unknown or Not Charging 1 = Constant Current, 2 = Constant Voltage, 3 = Trickle, 4 = Float, 5–7 = RFU 103e5ae30daSMilanka Ringwald #define BATTERY_LEVEL_POWER_STATE_BITMASK_CHARGING_FAULT_REASON 0x2000 // Bit 12: Battery, Bit 13: External Power source, Bit 14: Other 104e5ae30daSMilanka Ringwald #define BATTERY_LEVEL_POWER_STATE_BITMASK_RFU 0x4000 105e5ae30daSMilanka Ringwald 106e5ae30daSMilanka Ringwald #define BATTERY_CRITCAL_STATUS_BITMASK_CRITICAL_POWER_STATE 0x01 107e5ae30daSMilanka Ringwald #define BATTERY_CRITCAL_STATUS_BITMASK_IMMEDIATE_SERVICE_REQUIRED 0x02 108e5ae30daSMilanka Ringwald #define BATTERY_CRITCAL_STATUS_BITMASK_RFU 0x04 109e5ae30daSMilanka Ringwald 110e5ae30daSMilanka Ringwald #define BATTERY_TIME_STATUS_BITMASK_TIME_UNTIL_DISCHARGED_ON_STANDBY_PRESENT 0x01 111e5ae30daSMilanka Ringwald #define BATTERY_TIME_STATUS_BITMASK_TIME_UNTIL_RECHARGED_PRESENT 0x02 112e5ae30daSMilanka Ringwald #define BATTERY_TIME_STATUS_BITMASK_RFU 0x04 113e5ae30daSMilanka Ringwald 114e5ae30daSMilanka Ringwald #define BATTERY_HEALTH_STATUS_BITMASK_HEALTH_SUMMARY_PRESENT 0x01 115e5ae30daSMilanka Ringwald #define BATTERY_HEALTH_STATUS_BITMASK_CYCLE_COUNT_PRESENT 0x02 116e5ae30daSMilanka Ringwald #define BATTERY_HEALTH_STATUS_BITMASK_CURRENT_TEMPERATURE_PRESENT 0x04 117e5ae30daSMilanka Ringwald #define BATTERY_HEALTH_STATUS_BITMASK_DEEP_DISCHARGE_COUNT_PRESENT 0x08 118e5ae30daSMilanka Ringwald #define BATTERY_HEALTH_STATUS_BITMASK_RFU 0x10 119e5ae30daSMilanka Ringwald 120e5ae30daSMilanka Ringwald #define BATTERY_HEALTH_INFORMATION_BITMASK_CYCLE_COUNT_DESIGNED_LIFETIME_PRESENT 0x01 121e5ae30daSMilanka Ringwald #define BATTERY_HEALTH_INFORMATION_BITMASK_DESIGNED_OPERATING_TEMPERATURE_PRESENT 0x02 122e5ae30daSMilanka Ringwald #define BATTERY_HEALTH_INFORMATION_BITMASK_RFU 0x04 123e5ae30daSMilanka Ringwald 124e5ae30daSMilanka Ringwald #define BATTERY_INFORMATION_BITMASK_MANUFACTURE_DATE_PRESENT 0x0001 125e5ae30daSMilanka Ringwald #define BATTERY_INFORMATION_BITMASK_EXPIRATION_DATE_PRESENT 0x0002 126e5ae30daSMilanka Ringwald #define BATTERY_INFORMATION_BITMASK_DESIGNED_CAPACITY_PRESENT 0x0004 127e5ae30daSMilanka Ringwald #define BATTERY_INFORMATION_BITMASK_LOW_ENERGY_PRESENT 0x0008 128e5ae30daSMilanka Ringwald #define BATTERY_INFORMATION_BITMASK_CRITICAL_ENERGY_PRESENT 0x0010 129e5ae30daSMilanka Ringwald #define BATTERY_INFORMATION_BITMASK_CHEMISTRY_PRESENT 0x0020 130e5ae30daSMilanka Ringwald #define BATTERY_INFORMATION_BITMASK_NOMINAL_VOLTAGE_PRESENT 0x0040 131e5ae30daSMilanka Ringwald #define BATTERY_INFORMATION_BITMASK_AGGREGATION_GROUP_PRESENT 0x0080 132e5ae30daSMilanka Ringwald #define BATTERY_INFORMATION_BITMASK_RFU 0x0100 133e5ae30daSMilanka Ringwald 134e5ae30daSMilanka Ringwald #define BATTERY_INFROMATION_FEATURE_BITMASK_REPLACEABLE 0x01 135e5ae30daSMilanka Ringwald #define BATTERY_INFROMATION_FEATURE_BITMASK_RECHARGEABLE 0x02 136e5ae30daSMilanka Ringwald #define BATTERY_INFROMATION_FEATURE_BITMASK_RFU 0x04 137e5ae30daSMilanka Ringwald 138d62aa1c5SMilanka Ringwald struct battery_service_v1; 139d62aa1c5SMilanka Ringwald 140d62aa1c5SMilanka Ringwald typedef struct { 141d62aa1c5SMilanka Ringwald hci_con_handle_t con_handle; 142d62aa1c5SMilanka Ringwald 143d62aa1c5SMilanka Ringwald btstack_context_callback_registration_t scheduled_tasks_callback; 144038930d0SMilanka Ringwald uint16_t scheduled_tasks; 145e5ae30daSMilanka Ringwald uint16_t configurations[BAS_CHARACTERISTIC_INDEX_NUM]; 146d62aa1c5SMilanka Ringwald 147d62aa1c5SMilanka Ringwald struct battery_service_v1 * service; 148d62aa1c5SMilanka Ringwald } battery_service_v1_server_connection_t; 149d62aa1c5SMilanka Ringwald 150e5ae30daSMilanka Ringwald typedef struct { 151e5ae30daSMilanka Ringwald uint16_t value_handle; 152e5ae30daSMilanka Ringwald uint16_t client_configuration_handle; 153e5ae30daSMilanka Ringwald } bas_characteristic_t; 154e5ae30daSMilanka Ringwald 155db9fdd68SMilanka Ringwald typedef struct { 156db9fdd68SMilanka Ringwald uint8_t flags; 157db9fdd68SMilanka Ringwald uint16_t power_state_flags; 158db9fdd68SMilanka Ringwald 159db9fdd68SMilanka Ringwald uint16_t identifier; 160db9fdd68SMilanka Ringwald uint8_t battery_level; 161db9fdd68SMilanka Ringwald uint8_t additional_status_flags; 162db9fdd68SMilanka Ringwald } battery_level_status_t; 163db9fdd68SMilanka Ringwald 164db9fdd68SMilanka Ringwald typedef struct { 165db9fdd68SMilanka Ringwald uint8_t flags; 166db9fdd68SMilanka Ringwald uint16_t external_source_power_medfloat16; 167db9fdd68SMilanka Ringwald uint16_t present_voltage_medfloat16; 168db9fdd68SMilanka Ringwald uint16_t available_energy_medfloat16; 169db9fdd68SMilanka Ringwald uint16_t available_battery_capacity_medfloat16; 170db9fdd68SMilanka Ringwald uint16_t charge_rate_medfloat16; 171db9fdd68SMilanka Ringwald uint16_t available_energy_at_last_charge_medfloat16; 172db9fdd68SMilanka Ringwald } battery_energy_status_t; 173db9fdd68SMilanka Ringwald 174db9fdd68SMilanka Ringwald typedef struct { 175db9fdd68SMilanka Ringwald uint8_t flags; 176db9fdd68SMilanka Ringwald 177db9fdd68SMilanka Ringwald // A value of 0xFFFFFF represents: Unknown 178db9fdd68SMilanka Ringwald // A value of 0xFFFFFE represents: Greater than 0xFFFFFD 179db9fdd68SMilanka Ringwald uint32_t time_until_discharged_minutes; 180db9fdd68SMilanka Ringwald uint32_t time_until_discharged_on_standby_minutes; 181db9fdd68SMilanka Ringwald uint32_t time_until_recharged_minutes; 182db9fdd68SMilanka Ringwald } battery_time_status_t; 183db9fdd68SMilanka Ringwald 184db9fdd68SMilanka Ringwald typedef struct { 185db9fdd68SMilanka Ringwald uint8_t flags; 186db9fdd68SMilanka Ringwald 187db9fdd68SMilanka Ringwald uint8_t summary; // Allowed range is 0 to 100. 188db9fdd68SMilanka Ringwald uint16_t cycle_count; 189db9fdd68SMilanka Ringwald int8_t current_temperature_degree_celsius; 190db9fdd68SMilanka Ringwald uint16_t deep_discharge_count; 191db9fdd68SMilanka Ringwald } battery_health_status_t; 192db9fdd68SMilanka Ringwald 193db9fdd68SMilanka Ringwald typedef struct { 194db9fdd68SMilanka Ringwald uint8_t flags; 195db9fdd68SMilanka Ringwald uint16_t cycle_count_designed_lifetime; 196db9fdd68SMilanka Ringwald 197db9fdd68SMilanka Ringwald // A raw value of 0x7F represents: Greater than 126. 198db9fdd68SMilanka Ringwald // A raw value of 0x80 represents: Less than -127. 199db9fdd68SMilanka Ringwald int8_t min_designed_operating_temperature_degree_celsius; 200db9fdd68SMilanka Ringwald int8_t max_designed_operating_temperature_degree_celsius; 201db9fdd68SMilanka Ringwald } battery_health_information_t; 202db9fdd68SMilanka Ringwald 203db9fdd68SMilanka Ringwald typedef struct { 204db9fdd68SMilanka Ringwald uint16_t flags; 205db9fdd68SMilanka Ringwald uint8_t features; 206db9fdd68SMilanka Ringwald 207db9fdd68SMilanka Ringwald uint32_t manufacture_date_days; 208db9fdd68SMilanka Ringwald uint32_t expiration_date_days; 209db9fdd68SMilanka Ringwald 210db9fdd68SMilanka Ringwald uint16_t designed_capacity_kWh_medfloat16; 211db9fdd68SMilanka Ringwald uint16_t low_energy_kWh_medfloat16; 212db9fdd68SMilanka Ringwald uint16_t critical_energy_kWh_medfloat16; 213db9fdd68SMilanka Ringwald uint8_t chemistry; 214db9fdd68SMilanka Ringwald uint16_t nominal_voltage_medfloat16; 215db9fdd68SMilanka Ringwald uint8_t aggregation_group; // 0: not in group, 255: RFU 216db9fdd68SMilanka Ringwald } battery_information_t; 217d62aa1c5SMilanka Ringwald 218d62aa1c5SMilanka Ringwald typedef struct battery_service_v1 { 219d62aa1c5SMilanka Ringwald btstack_linked_item_t item; 220d62aa1c5SMilanka Ringwald 221d62aa1c5SMilanka Ringwald // service 222d62aa1c5SMilanka Ringwald uint16_t start_handle; 223d62aa1c5SMilanka Ringwald uint16_t end_handle; 224d62aa1c5SMilanka Ringwald uint8_t index; 225d62aa1c5SMilanka Ringwald 226d62aa1c5SMilanka Ringwald att_service_handler_t service_handler; 227d62aa1c5SMilanka Ringwald 228e5ae30daSMilanka Ringwald bas_characteristic_t characteristics[BAS_CHARACTERISTIC_INDEX_NUM]; 229e5ae30daSMilanka Ringwald 230d62aa1c5SMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_LEVEL 231e16068dbSMilanka Ringwald uint8_t battery_level; 232d62aa1c5SMilanka Ringwald 233e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_LEVEL_STATUS 234db9fdd68SMilanka Ringwald const battery_level_status_t * level_status; 235e5ae30daSMilanka Ringwald 236e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_ESTIMATED_SERVICE_DATE 237e5ae30daSMilanka Ringwald uint32_t estimated_service_date_days; 238e5ae30daSMilanka Ringwald 239e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_CRITCAL_STATUS 240*e24f316cSMilanka Ringwald uint8_t critcal_status_flags; 241e5ae30daSMilanka Ringwald 242e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_ENERGY_STATUS 243db9fdd68SMilanka Ringwald const battery_energy_status_t * energy_status; 244e5ae30daSMilanka Ringwald 245e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_TIME_STATUS 246db9fdd68SMilanka Ringwald const battery_time_status_t * time_status; 247e5ae30daSMilanka Ringwald 248e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_HEALTH_STATUS 249db9fdd68SMilanka Ringwald const battery_health_status_t * health_status; 250e5ae30daSMilanka Ringwald 251e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_HEALTH_INFORMATION 252db9fdd68SMilanka Ringwald const battery_health_information_t * health_information; 253e5ae30daSMilanka Ringwald 254e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_INFORMATION 255db9fdd68SMilanka Ringwald const battery_information_t * information; 256e5ae30daSMilanka Ringwald 257e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_MANUFACTURER_NAME_STRING 258db9fdd68SMilanka Ringwald const char * manufacturer_name; 259e5ae30daSMilanka Ringwald 260e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_MODEL_NUMBER_STRING 261db9fdd68SMilanka Ringwald const char * model_number; 262e5ae30daSMilanka Ringwald 263e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_SERIAL_NUMBER_STRING 264db9fdd68SMilanka Ringwald const char * serial_number; 265e5ae30daSMilanka Ringwald 266d62aa1c5SMilanka Ringwald uint8_t connections_max_num; 267d62aa1c5SMilanka Ringwald battery_service_v1_server_connection_t * connections; 268d62aa1c5SMilanka Ringwald } battery_service_v1_t; 269d62aa1c5SMilanka Ringwald 270d62aa1c5SMilanka Ringwald /* API_START */ 271d62aa1c5SMilanka Ringwald 272d62aa1c5SMilanka Ringwald /** 273d62aa1c5SMilanka Ringwald * @brief Init Battery Service Server with ATT DB 274d62aa1c5SMilanka Ringwald */ 275d62aa1c5SMilanka Ringwald void battery_service_v1_server_init(void); 276d62aa1c5SMilanka Ringwald 277d62aa1c5SMilanka Ringwald void battery_service_v1_server_register(battery_service_v1_t * service, battery_service_v1_server_connection_t * connections, uint8_t connection_max_num); 278d62aa1c5SMilanka Ringwald 279d62aa1c5SMilanka Ringwald void battery_service_v1_server_deregister(battery_service_v1_t * service); 280ac8c27c4SMilanka Ringwald 281d62aa1c5SMilanka Ringwald /** 282e16068dbSMilanka Ringwald * @brief Update battery level 283e16068dbSMilanka Ringwald * @note Triggers notification if subscribed 284ac8c27c4SMilanka Ringwald * @param service 285e16068dbSMilanka Ringwald * @param battery_level in range 0-100 286e16068dbSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 287d62aa1c5SMilanka Ringwald */ 288e16068dbSMilanka Ringwald uint8_t battery_service_v1_server_set_battery_level(battery_service_v1_t * service,uint8_t battery_level); 289e16068dbSMilanka Ringwald 290e16068dbSMilanka Ringwald /** 291e16068dbSMilanka Ringwald * @brief Update battery level status 292e16068dbSMilanka Ringwald * @note Triggers notification or indication if subscribed 293e16068dbSMilanka Ringwald * @param service 294e16068dbSMilanka Ringwald * @param battery_level_status in range 0-100 295e16068dbSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 296e16068dbSMilanka Ringwald */ 297e16068dbSMilanka Ringwald uint8_t battery_service_v1_server_set_battery_level_status(battery_service_v1_t * service, const battery_level_status_t * battery_level_status); 298ac8c27c4SMilanka Ringwald 299*e24f316cSMilanka Ringwald /** 300*e24f316cSMilanka Ringwald * @brief Update battery estimated service date 301*e24f316cSMilanka Ringwald * @note Triggers notification or indication if subscribed 302*e24f316cSMilanka Ringwald * @param service 303*e24f316cSMilanka Ringwald * @param estimated_service_date_days 304*e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 305*e24f316cSMilanka Ringwald */ 306*e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_estimated_service_date_days(battery_service_v1_t * service, uint32_t estimated_service_date_days); 307*e24f316cSMilanka Ringwald 308*e24f316cSMilanka Ringwald /** 309*e24f316cSMilanka Ringwald * @brief Update battery critcal status flags 310*e24f316cSMilanka Ringwald * @note Triggers indication if subscribed 311*e24f316cSMilanka Ringwald * @param service 312*e24f316cSMilanka Ringwald * @param critcal_status_flags 313*e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 314*e24f316cSMilanka Ringwald */ 315*e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_critcal_status_flags(battery_service_v1_t * service, uint8_t critcal_status_flags); 316*e24f316cSMilanka Ringwald 317*e24f316cSMilanka Ringwald /** 318*e24f316cSMilanka Ringwald * @brief Update battery energy status 319*e24f316cSMilanka Ringwald * @note Triggers notification or indication if subscribed 320*e24f316cSMilanka Ringwald * @param service 321*e24f316cSMilanka Ringwald * @param energy_status 322*e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 323*e24f316cSMilanka Ringwald */ 324*e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_energy_status(battery_service_v1_t * service, const battery_energy_status_t * energy_status); 325*e24f316cSMilanka Ringwald 326*e24f316cSMilanka Ringwald /** 327*e24f316cSMilanka Ringwald * @brief Update battery time status 328*e24f316cSMilanka Ringwald * @note Triggers notification or indication if subscribed 329*e24f316cSMilanka Ringwald * @param service 330*e24f316cSMilanka Ringwald * @param time_status 331*e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 332*e24f316cSMilanka Ringwald */ 333*e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_time_status(battery_service_v1_t * service, const battery_time_status_t * time_status); 334*e24f316cSMilanka Ringwald 335*e24f316cSMilanka Ringwald /** 336*e24f316cSMilanka Ringwald * @brief Update battery health status 337*e24f316cSMilanka Ringwald * @note Triggers notification or indication if subscribed 338*e24f316cSMilanka Ringwald * @param service 339*e24f316cSMilanka Ringwald * @param health_status 340*e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 341*e24f316cSMilanka Ringwald */ 342*e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_health_status(battery_service_v1_t * service, const battery_health_status_t * health_status); 343*e24f316cSMilanka Ringwald 344*e24f316cSMilanka Ringwald /** 345*e24f316cSMilanka Ringwald * @brief Update battery health information 346*e24f316cSMilanka Ringwald * @note Triggers indication if subscribed 347*e24f316cSMilanka Ringwald * @param service 348*e24f316cSMilanka Ringwald * @param health_information 349*e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 350*e24f316cSMilanka Ringwald */ 351*e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_health_information(battery_service_v1_t * service, const battery_health_information_t * health_information); 352*e24f316cSMilanka Ringwald 353*e24f316cSMilanka Ringwald /** 354*e24f316cSMilanka Ringwald * @brief Update battery information 355*e24f316cSMilanka Ringwald * @note Triggers indication if subscribed 356*e24f316cSMilanka Ringwald * @param service 357*e24f316cSMilanka Ringwald * @param information 358*e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 359*e24f316cSMilanka Ringwald */ 360*e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_information(battery_service_v1_t * service, const battery_information_t * information); 361*e24f316cSMilanka Ringwald 362*e24f316cSMilanka Ringwald /** 363*e24f316cSMilanka Ringwald * @brief Update manufacturer name 364*e24f316cSMilanka Ringwald * @note Triggers indication if subscribed 365*e24f316cSMilanka Ringwald * @param service 366*e24f316cSMilanka Ringwald * @param manufacturer_name 367*e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 368*e24f316cSMilanka Ringwald */ 369*e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_manufacturer_name(battery_service_v1_t * service, const char * manufacturer_name); 370*e24f316cSMilanka Ringwald 371*e24f316cSMilanka Ringwald /** 372*e24f316cSMilanka Ringwald * @brief Update model_number 373*e24f316cSMilanka Ringwald * @note Triggers indication if subscribed 374*e24f316cSMilanka Ringwald * @param service 375*e24f316cSMilanka Ringwald * @param model number 376*e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 377*e24f316cSMilanka Ringwald */ 378*e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_model_number(battery_service_v1_t * service, const char * model_number); 379*e24f316cSMilanka Ringwald 380*e24f316cSMilanka Ringwald /** 381*e24f316cSMilanka Ringwald * @brief Update serial_number 382*e24f316cSMilanka Ringwald * @note Triggers indication if subscribed 383*e24f316cSMilanka Ringwald * @param service 384*e24f316cSMilanka Ringwald * @param serial number 385*e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 386*e24f316cSMilanka Ringwald */ 387*e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_serial_number(battery_service_v1_t * service, const char * serial_number); 388d62aa1c5SMilanka Ringwald 389d62aa1c5SMilanka Ringwald void battery_service_v1_server_deinit(void); 390d62aa1c5SMilanka Ringwald 391d62aa1c5SMilanka Ringwald /* API_END */ 392d62aa1c5SMilanka Ringwald 393d62aa1c5SMilanka Ringwald #if defined __cplusplus 394d62aa1c5SMilanka Ringwald } 395d62aa1c5SMilanka Ringwald #endif 396d62aa1c5SMilanka Ringwald 397d62aa1c5SMilanka Ringwald #endif 398d62aa1c5SMilanka Ringwald 399