xref: /btstack/src/ble/gatt-service/battery_service_v1_server.h (revision d62aa1c5d3ca2e81d5ccc8cd6238a39f2faf6875)
1*d62aa1c5SMilanka Ringwald /*
2*d62aa1c5SMilanka Ringwald  * Copyright (C) 2024 BlueKitchen GmbH
3*d62aa1c5SMilanka Ringwald  *
4*d62aa1c5SMilanka Ringwald  * Redistribution and use in source and binary forms, with or without
5*d62aa1c5SMilanka Ringwald  * modification, are permitted provided that the following conditions
6*d62aa1c5SMilanka Ringwald  * are met:
7*d62aa1c5SMilanka Ringwald  *
8*d62aa1c5SMilanka Ringwald  * 1. Redistributions of source code must retain the above copyright
9*d62aa1c5SMilanka Ringwald  *    notice, this list of conditions and the following disclaimer.
10*d62aa1c5SMilanka Ringwald  * 2. Redistributions in binary form must reproduce the above copyright
11*d62aa1c5SMilanka Ringwald  *    notice, this list of conditions and the following disclaimer in the
12*d62aa1c5SMilanka Ringwald  *    documentation and/or other materials provided with the distribution.
13*d62aa1c5SMilanka Ringwald  * 3. Neither the name of the copyright holders nor the names of
14*d62aa1c5SMilanka Ringwald  *    contributors may be used to endorse or promote products derived
15*d62aa1c5SMilanka Ringwald  *    from this software without specific prior written permission.
16*d62aa1c5SMilanka Ringwald  * 4. Any redistribution, use, or modification is done solely for
17*d62aa1c5SMilanka Ringwald  *    personal benefit and not for any commercial purpose or for
18*d62aa1c5SMilanka Ringwald  *    monetary gain.
19*d62aa1c5SMilanka Ringwald  *
20*d62aa1c5SMilanka Ringwald  * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS
21*d62aa1c5SMilanka Ringwald  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22*d62aa1c5SMilanka Ringwald  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23*d62aa1c5SMilanka Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BLUEKITCHEN
24*d62aa1c5SMilanka Ringwald  * GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25*d62aa1c5SMilanka Ringwald  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
26*d62aa1c5SMilanka Ringwald  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
27*d62aa1c5SMilanka Ringwald  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
28*d62aa1c5SMilanka Ringwald  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
29*d62aa1c5SMilanka Ringwald  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
30*d62aa1c5SMilanka Ringwald  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31*d62aa1c5SMilanka Ringwald  * SUCH DAMAGE.
32*d62aa1c5SMilanka Ringwald  *
33*d62aa1c5SMilanka Ringwald  * Please inquire about commercial licensing options at
34*d62aa1c5SMilanka Ringwald  * [email protected]
35*d62aa1c5SMilanka Ringwald  *
36*d62aa1c5SMilanka Ringwald  */
37*d62aa1c5SMilanka Ringwald 
38*d62aa1c5SMilanka Ringwald /**
39*d62aa1c5SMilanka Ringwald  * @title Battery Service Server v1.1
40*d62aa1c5SMilanka Ringwald  *
41*d62aa1c5SMilanka Ringwald  */
42*d62aa1c5SMilanka Ringwald 
43*d62aa1c5SMilanka Ringwald #ifndef BATTERY_SERVICE_V1_SERVER_H
44*d62aa1c5SMilanka Ringwald #define BATTERY_SERVICE_V1_SERVER_H
45*d62aa1c5SMilanka Ringwald 
46*d62aa1c5SMilanka Ringwald #include <stdint.h>
47*d62aa1c5SMilanka Ringwald 
48*d62aa1c5SMilanka Ringwald #if defined __cplusplus
49*d62aa1c5SMilanka Ringwald extern "C" {
50*d62aa1c5SMilanka Ringwald #endif
51*d62aa1c5SMilanka Ringwald 
52*d62aa1c5SMilanka Ringwald /**
53*d62aa1c5SMilanka Ringwald  * @text The Battery Service allows to query your device's battery level in a standardized way.
54*d62aa1c5SMilanka Ringwald  *
55*d62aa1c5SMilanka Ringwald  * To use with your application, add `#import <battery_service.gatt>` to your .gatt file.
56*d62aa1c5SMilanka Ringwald  * After adding it to your .gatt file, you call *battery_service_server_init(value)* with the
57*d62aa1c5SMilanka Ringwald  * current value of your battery. The valid range for the battery level is 0-100.
58*d62aa1c5SMilanka Ringwald  *
59*d62aa1c5SMilanka Ringwald  * If the battery level changes, you can call *battery_service_server_set_battery_value(value)*.
60*d62aa1c5SMilanka Ringwald  * The service supports sending Notifications if the client enables them.
61*d62aa1c5SMilanka Ringwald  */
62*d62aa1c5SMilanka Ringwald struct battery_service_v1;
63*d62aa1c5SMilanka Ringwald 
64*d62aa1c5SMilanka Ringwald typedef struct {
65*d62aa1c5SMilanka Ringwald     hci_con_handle_t con_handle;
66*d62aa1c5SMilanka Ringwald 
67*d62aa1c5SMilanka Ringwald     btstack_context_callback_registration_t  scheduled_tasks_callback;
68*d62aa1c5SMilanka Ringwald     uint8_t scheduled_tasks;
69*d62aa1c5SMilanka Ringwald 
70*d62aa1c5SMilanka Ringwald     // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_LEVEL
71*d62aa1c5SMilanka Ringwald     uint16_t battery_value_client_configuration;
72*d62aa1c5SMilanka Ringwald     struct battery_service_v1 * service;
73*d62aa1c5SMilanka Ringwald } battery_service_v1_server_connection_t;
74*d62aa1c5SMilanka Ringwald 
75*d62aa1c5SMilanka Ringwald 
76*d62aa1c5SMilanka Ringwald typedef struct battery_service_v1 {
77*d62aa1c5SMilanka Ringwald     btstack_linked_item_t item;
78*d62aa1c5SMilanka Ringwald 
79*d62aa1c5SMilanka Ringwald     // service
80*d62aa1c5SMilanka Ringwald     uint16_t start_handle;
81*d62aa1c5SMilanka Ringwald     uint16_t end_handle;
82*d62aa1c5SMilanka Ringwald     uint8_t index;
83*d62aa1c5SMilanka Ringwald 
84*d62aa1c5SMilanka Ringwald     att_service_handler_t    service_handler;
85*d62aa1c5SMilanka Ringwald 
86*d62aa1c5SMilanka Ringwald     // ORG_BLUETOOTH_CHARACTERISTIC_BATTERY_LEVEL
87*d62aa1c5SMilanka Ringwald     uint16_t battery_value_handle;
88*d62aa1c5SMilanka Ringwald     uint16_t battery_value_client_configuration_handle;
89*d62aa1c5SMilanka Ringwald     uint8_t  battery_value;
90*d62aa1c5SMilanka Ringwald 
91*d62aa1c5SMilanka Ringwald     uint8_t connections_max_num;
92*d62aa1c5SMilanka Ringwald     battery_service_v1_server_connection_t * connections;
93*d62aa1c5SMilanka Ringwald } battery_service_v1_t;
94*d62aa1c5SMilanka Ringwald 
95*d62aa1c5SMilanka Ringwald /* API_START */
96*d62aa1c5SMilanka Ringwald 
97*d62aa1c5SMilanka Ringwald /**
98*d62aa1c5SMilanka Ringwald  * @brief Init Battery Service Server with ATT DB
99*d62aa1c5SMilanka Ringwald  */
100*d62aa1c5SMilanka Ringwald void battery_service_v1_server_init(void);
101*d62aa1c5SMilanka Ringwald 
102*d62aa1c5SMilanka Ringwald void battery_service_v1_server_register(battery_service_v1_t *service, battery_service_v1_server_connection_t *connections, uint8_t connection_max_num);
103*d62aa1c5SMilanka Ringwald 
104*d62aa1c5SMilanka Ringwald void battery_service_v1_server_deregister(battery_service_v1_t *service);
105*d62aa1c5SMilanka Ringwald /**
106*d62aa1c5SMilanka Ringwald  * @brief Update battery value
107*d62aa1c5SMilanka Ringwald  * @note triggers notifications if subscribed
108*d62aa1c5SMilanka Ringwald  * @param battery_value in range 0-100
109*d62aa1c5SMilanka Ringwald  */
110*d62aa1c5SMilanka Ringwald void battery_service_v1_server_set_battery_value(battery_service_v1_t * service, uint8_t value);
111*d62aa1c5SMilanka Ringwald 
112*d62aa1c5SMilanka Ringwald void battery_service_v1_server_deinit(void);
113*d62aa1c5SMilanka Ringwald 
114*d62aa1c5SMilanka Ringwald /* API_END */
115*d62aa1c5SMilanka Ringwald 
116*d62aa1c5SMilanka Ringwald #if defined __cplusplus
117*d62aa1c5SMilanka Ringwald }
118*d62aa1c5SMilanka Ringwald #endif
119*d62aa1c5SMilanka Ringwald 
120*d62aa1c5SMilanka Ringwald #endif
121*d62aa1c5SMilanka Ringwald 
122