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 86*de4a918bSMilanka Ringwald #define BATTERY_ENERGY_STATUS_BITMASK_RFU 0xC0 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 91*de4a918bSMilanka Ringwald #define BATTERY_LEVEL_STATUS_BITMASK_RFU 0xF8 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 95*de4a918bSMilanka Ringwald #define BATTERY_LEVEL_ADDITIONAL_STATUS_BITMASK_RFU 0xFC 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 104*de4a918bSMilanka Ringwald #define BATTERY_LEVEL_POWER_STATE_BITMASK_RFU 0xC000 105e5ae30daSMilanka Ringwald 106e5ae30daSMilanka Ringwald #define BATTERY_CRITCAL_STATUS_BITMASK_CRITICAL_POWER_STATE 0x01 107e5ae30daSMilanka Ringwald #define BATTERY_CRITCAL_STATUS_BITMASK_IMMEDIATE_SERVICE_REQUIRED 0x02 108*de4a918bSMilanka Ringwald #define BATTERY_CRITCAL_STATUS_BITMASK_RFU 0xFC 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 112*de4a918bSMilanka Ringwald #define BATTERY_TIME_STATUS_BITMASK_RFU 0xFC 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 118*de4a918bSMilanka Ringwald #define BATTERY_HEALTH_STATUS_BITMASK_RFU 0xF0 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 122*de4a918bSMilanka Ringwald #define BATTERY_HEALTH_INFORMATION_BITMASK_RFU 0xFC 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 132*de4a918bSMilanka Ringwald #define BATTERY_INFORMATION_BITMASK_RFU 0xFF00 133e5ae30daSMilanka Ringwald 134e5ae30daSMilanka Ringwald #define BATTERY_INFROMATION_FEATURE_BITMASK_REPLACEABLE 0x01 135e5ae30daSMilanka Ringwald #define BATTERY_INFROMATION_FEATURE_BITMASK_RECHARGEABLE 0x02 136*de4a918bSMilanka Ringwald #define BATTERY_INFROMATION_FEATURE_BITMASK_RFU 0xFC 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 203*de4a918bSMilanka Ringwald typedef enum { 204*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_UNKNOWN = 0, 205*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_ALKALINE, // (ZINC–MANGANESE DIOXIDE) 206*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_LEAD_ACID, 207*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_LITHIUM_LIFES2, // (LITHIUM-IRON DISULFIDE) 208*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_LITHIUM_LIMNO2, // (LITHIUM-MANGANESE DIOXIDE) 209*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_LITHIUM_ION_LI, 210*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_LITHIUM_POLYMER, 211*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_NICKEL_OXYHYDROXIDE_NIOX, // (ZINC-MANGANESE DIOXIDE/OXY NICKEL HYDROXIDE) 212*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_NICKEL_CADMIUM_NICD, 213*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_NICKEL_METAL_HYDRIDE_NIMH, 214*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_SILVER_OXIDE_AGZN, // (SILVER-ZINC) 215*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_ZINC_CHLORIDE, 216*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_ZINC_AIR, 217*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_ZINC_CARBON, 218*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_RFU_START = 14, 219*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_RFU_END = 254, 220*de4a918bSMilanka Ringwald BATTERY_CHEMISTRY_OTHER = 255 221*de4a918bSMilanka Ringwald } battery_chemistry_t; 222*de4a918bSMilanka Ringwald 223db9fdd68SMilanka Ringwald typedef struct { 224db9fdd68SMilanka Ringwald uint16_t flags; 225db9fdd68SMilanka Ringwald uint8_t features; 226db9fdd68SMilanka Ringwald 227db9fdd68SMilanka Ringwald uint32_t manufacture_date_days; 228db9fdd68SMilanka Ringwald uint32_t expiration_date_days; 229db9fdd68SMilanka Ringwald 230db9fdd68SMilanka Ringwald uint16_t designed_capacity_kWh_medfloat16; 231db9fdd68SMilanka Ringwald uint16_t low_energy_kWh_medfloat16; 232db9fdd68SMilanka Ringwald uint16_t critical_energy_kWh_medfloat16; 233*de4a918bSMilanka Ringwald battery_chemistry_t chemistry; 234db9fdd68SMilanka Ringwald uint16_t nominal_voltage_medfloat16; 235db9fdd68SMilanka Ringwald uint8_t aggregation_group; // 0: not in group, 255: RFU 236db9fdd68SMilanka Ringwald } battery_information_t; 237d62aa1c5SMilanka Ringwald 238d62aa1c5SMilanka Ringwald typedef struct battery_service_v1 { 239d62aa1c5SMilanka Ringwald btstack_linked_item_t item; 240d62aa1c5SMilanka Ringwald 241d62aa1c5SMilanka Ringwald // service 242d62aa1c5SMilanka Ringwald uint16_t start_handle; 243d62aa1c5SMilanka Ringwald uint16_t end_handle; 244d62aa1c5SMilanka Ringwald uint8_t index; 245d62aa1c5SMilanka Ringwald 246d62aa1c5SMilanka Ringwald att_service_handler_t service_handler; 247d62aa1c5SMilanka Ringwald 248e5ae30daSMilanka Ringwald bas_characteristic_t characteristics[BAS_CHARACTERISTIC_INDEX_NUM]; 249e5ae30daSMilanka Ringwald 250d62aa1c5SMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_LEVEL 251e16068dbSMilanka Ringwald uint8_t battery_level; 252d62aa1c5SMilanka Ringwald 253e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_LEVEL_STATUS 254db9fdd68SMilanka Ringwald const battery_level_status_t * level_status; 255e5ae30daSMilanka Ringwald 256e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_ESTIMATED_SERVICE_DATE 257e5ae30daSMilanka Ringwald uint32_t estimated_service_date_days; 258e5ae30daSMilanka Ringwald 259e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_CRITCAL_STATUS 260e24f316cSMilanka Ringwald uint8_t critcal_status_flags; 261e5ae30daSMilanka Ringwald 262e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_ENERGY_STATUS 263db9fdd68SMilanka Ringwald const battery_energy_status_t * energy_status; 264e5ae30daSMilanka Ringwald 265e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_TIME_STATUS 266db9fdd68SMilanka Ringwald const battery_time_status_t * time_status; 267e5ae30daSMilanka Ringwald 268e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_HEALTH_STATUS 269db9fdd68SMilanka Ringwald const battery_health_status_t * health_status; 270e5ae30daSMilanka Ringwald 271e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_HEALTH_INFORMATION 272db9fdd68SMilanka Ringwald const battery_health_information_t * health_information; 273e5ae30daSMilanka Ringwald 274e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_INFORMATION 275db9fdd68SMilanka Ringwald const battery_information_t * information; 276e5ae30daSMilanka Ringwald 277e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_MANUFACTURER_NAME_STRING 278db9fdd68SMilanka Ringwald const char * manufacturer_name; 279e5ae30daSMilanka Ringwald 280e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_MODEL_NUMBER_STRING 281db9fdd68SMilanka Ringwald const char * model_number; 282e5ae30daSMilanka Ringwald 283e5ae30daSMilanka Ringwald // ORG_BLUETOOTH_CHARACTERISTIC_SERIAL_NUMBER_STRING 284db9fdd68SMilanka Ringwald const char * serial_number; 285e5ae30daSMilanka Ringwald 286d62aa1c5SMilanka Ringwald uint8_t connections_max_num; 287d62aa1c5SMilanka Ringwald battery_service_v1_server_connection_t * connections; 288d62aa1c5SMilanka Ringwald } battery_service_v1_t; 289d62aa1c5SMilanka Ringwald 290d62aa1c5SMilanka Ringwald /* API_START */ 291d62aa1c5SMilanka Ringwald 292d62aa1c5SMilanka Ringwald /** 293d62aa1c5SMilanka Ringwald * @brief Init Battery Service Server with ATT DB 294d62aa1c5SMilanka Ringwald */ 295d62aa1c5SMilanka Ringwald void battery_service_v1_server_init(void); 296d62aa1c5SMilanka Ringwald 297d62aa1c5SMilanka Ringwald void battery_service_v1_server_register(battery_service_v1_t * service, battery_service_v1_server_connection_t * connections, uint8_t connection_max_num); 298d62aa1c5SMilanka Ringwald 299d62aa1c5SMilanka Ringwald void battery_service_v1_server_deregister(battery_service_v1_t * service); 300ac8c27c4SMilanka Ringwald 301d62aa1c5SMilanka Ringwald /** 302e16068dbSMilanka Ringwald * @brief Update battery level 303e16068dbSMilanka Ringwald * @note Triggers notification if subscribed 304ac8c27c4SMilanka Ringwald * @param service 305e16068dbSMilanka Ringwald * @param battery_level in range 0-100 306e16068dbSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 307d62aa1c5SMilanka Ringwald */ 308e16068dbSMilanka Ringwald uint8_t battery_service_v1_server_set_battery_level(battery_service_v1_t * service,uint8_t battery_level); 309e16068dbSMilanka Ringwald 310e16068dbSMilanka Ringwald /** 311e16068dbSMilanka Ringwald * @brief Update battery level status 312e16068dbSMilanka Ringwald * @note Triggers notification or indication if subscribed 313e16068dbSMilanka Ringwald * @param service 314e16068dbSMilanka Ringwald * @param battery_level_status in range 0-100 315e16068dbSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 316e16068dbSMilanka Ringwald */ 317e16068dbSMilanka Ringwald uint8_t battery_service_v1_server_set_battery_level_status(battery_service_v1_t * service, const battery_level_status_t * battery_level_status); 318ac8c27c4SMilanka Ringwald 319e24f316cSMilanka Ringwald /** 320*de4a918bSMilanka Ringwald * @brief Update battery estimated service date as days elapsed since the Epoch (Jan 1, 1970) 321e24f316cSMilanka Ringwald * @note Triggers notification or indication if subscribed 322e24f316cSMilanka Ringwald * @param service 323e24f316cSMilanka Ringwald * @param estimated_service_date_days 324e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 325e24f316cSMilanka Ringwald */ 326e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_estimated_service_date_days(battery_service_v1_t * service, uint32_t estimated_service_date_days); 327e24f316cSMilanka Ringwald 328e24f316cSMilanka Ringwald /** 329e24f316cSMilanka Ringwald * @brief Update battery critcal status flags 330e24f316cSMilanka Ringwald * @note Triggers indication if subscribed 331e24f316cSMilanka Ringwald * @param service 332e24f316cSMilanka Ringwald * @param critcal_status_flags 333e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 334e24f316cSMilanka Ringwald */ 335e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_critcal_status_flags(battery_service_v1_t * service, uint8_t critcal_status_flags); 336e24f316cSMilanka Ringwald 337e24f316cSMilanka Ringwald /** 338e24f316cSMilanka Ringwald * @brief Update battery energy status 339e24f316cSMilanka Ringwald * @note Triggers notification or indication if subscribed 340e24f316cSMilanka Ringwald * @param service 341e24f316cSMilanka Ringwald * @param energy_status 342e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 343e24f316cSMilanka Ringwald */ 344e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_energy_status(battery_service_v1_t * service, const battery_energy_status_t * energy_status); 345e24f316cSMilanka Ringwald 346e24f316cSMilanka Ringwald /** 347e24f316cSMilanka Ringwald * @brief Update battery time status 348e24f316cSMilanka Ringwald * @note Triggers notification or indication if subscribed 349e24f316cSMilanka Ringwald * @param service 350e24f316cSMilanka Ringwald * @param time_status 351e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 352e24f316cSMilanka Ringwald */ 353e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_time_status(battery_service_v1_t * service, const battery_time_status_t * time_status); 354e24f316cSMilanka Ringwald 355e24f316cSMilanka Ringwald /** 356e24f316cSMilanka Ringwald * @brief Update battery health status 357e24f316cSMilanka Ringwald * @note Triggers notification or indication if subscribed 358e24f316cSMilanka Ringwald * @param service 359e24f316cSMilanka Ringwald * @param health_status 360e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 361e24f316cSMilanka Ringwald */ 362e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_health_status(battery_service_v1_t * service, const battery_health_status_t * health_status); 363e24f316cSMilanka Ringwald 364e24f316cSMilanka Ringwald /** 365e24f316cSMilanka Ringwald * @brief Update battery health information 366e24f316cSMilanka Ringwald * @note Triggers indication if subscribed 367e24f316cSMilanka Ringwald * @param service 368e24f316cSMilanka Ringwald * @param health_information 369e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 370e24f316cSMilanka Ringwald */ 371e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_health_information(battery_service_v1_t * service, const battery_health_information_t * health_information); 372e24f316cSMilanka Ringwald 373e24f316cSMilanka Ringwald /** 374e24f316cSMilanka Ringwald * @brief Update battery information 375e24f316cSMilanka Ringwald * @note Triggers indication if subscribed 376e24f316cSMilanka Ringwald * @param service 377e24f316cSMilanka Ringwald * @param information 378e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 379e24f316cSMilanka Ringwald */ 380e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_information(battery_service_v1_t * service, const battery_information_t * information); 381e24f316cSMilanka Ringwald 382e24f316cSMilanka Ringwald /** 383e24f316cSMilanka Ringwald * @brief Update manufacturer name 384e24f316cSMilanka Ringwald * @note Triggers indication if subscribed 385e24f316cSMilanka Ringwald * @param service 386e24f316cSMilanka Ringwald * @param manufacturer_name 387e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 388e24f316cSMilanka Ringwald */ 389e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_manufacturer_name(battery_service_v1_t * service, const char * manufacturer_name); 390e24f316cSMilanka Ringwald 391e24f316cSMilanka Ringwald /** 392e24f316cSMilanka Ringwald * @brief Update model_number 393e24f316cSMilanka Ringwald * @note Triggers indication if subscribed 394e24f316cSMilanka Ringwald * @param service 395e24f316cSMilanka Ringwald * @param model number 396e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 397e24f316cSMilanka Ringwald */ 398e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_model_number(battery_service_v1_t * service, const char * model_number); 399e24f316cSMilanka Ringwald 400e24f316cSMilanka Ringwald /** 401e24f316cSMilanka Ringwald * @brief Update serial_number 402e24f316cSMilanka Ringwald * @note Triggers indication if subscribed 403e24f316cSMilanka Ringwald * @param service 404e24f316cSMilanka Ringwald * @param serial number 405e24f316cSMilanka Ringwald * @return ERROR_CODE_SUCCESS if value is valid, otherwise ERROR_CODE_PARAMETER_OUT_OF_MANDATORY_RANGE 406e24f316cSMilanka Ringwald */ 407e24f316cSMilanka Ringwald uint8_t battery_service_v1_server_set_serial_number(battery_service_v1_t * service, const char * serial_number); 408d62aa1c5SMilanka Ringwald 409d62aa1c5SMilanka Ringwald void battery_service_v1_server_deinit(void); 410d62aa1c5SMilanka Ringwald 411d62aa1c5SMilanka Ringwald /* API_END */ 412d62aa1c5SMilanka Ringwald 413d62aa1c5SMilanka Ringwald #if defined __cplusplus 414d62aa1c5SMilanka Ringwald } 415d62aa1c5SMilanka Ringwald #endif 416d62aa1c5SMilanka Ringwald 417d62aa1c5SMilanka Ringwald #endif 418d62aa1c5SMilanka Ringwald 419