xref: /btstack/src/ble/att_server.h (revision 3deb3ec68039c68a16974dffc53343233662f909)
1*3deb3ec6SMatthias Ringwald /*
2*3deb3ec6SMatthias Ringwald  * Copyright (C) 2014 BlueKitchen GmbH
3*3deb3ec6SMatthias Ringwald  *
4*3deb3ec6SMatthias Ringwald  * Redistribution and use in source and binary forms, with or without
5*3deb3ec6SMatthias Ringwald  * modification, are permitted provided that the following conditions
6*3deb3ec6SMatthias Ringwald  * are met:
7*3deb3ec6SMatthias Ringwald  *
8*3deb3ec6SMatthias Ringwald  * 1. Redistributions of source code must retain the above copyright
9*3deb3ec6SMatthias Ringwald  *    notice, this list of conditions and the following disclaimer.
10*3deb3ec6SMatthias Ringwald  * 2. Redistributions in binary form must reproduce the above copyright
11*3deb3ec6SMatthias Ringwald  *    notice, this list of conditions and the following disclaimer in the
12*3deb3ec6SMatthias Ringwald  *    documentation and/or other materials provided with the distribution.
13*3deb3ec6SMatthias Ringwald  * 3. Neither the name of the copyright holders nor the names of
14*3deb3ec6SMatthias Ringwald  *    contributors may be used to endorse or promote products derived
15*3deb3ec6SMatthias Ringwald  *    from this software without specific prior written permission.
16*3deb3ec6SMatthias Ringwald  * 4. Any redistribution, use, or modification is done solely for
17*3deb3ec6SMatthias Ringwald  *    personal benefit and not for any commercial purpose or for
18*3deb3ec6SMatthias Ringwald  *    monetary gain.
19*3deb3ec6SMatthias Ringwald  *
20*3deb3ec6SMatthias Ringwald  * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS
21*3deb3ec6SMatthias Ringwald  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22*3deb3ec6SMatthias Ringwald  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23*3deb3ec6SMatthias Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
24*3deb3ec6SMatthias Ringwald  * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25*3deb3ec6SMatthias Ringwald  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
26*3deb3ec6SMatthias Ringwald  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
27*3deb3ec6SMatthias Ringwald  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
28*3deb3ec6SMatthias Ringwald  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
29*3deb3ec6SMatthias Ringwald  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
30*3deb3ec6SMatthias Ringwald  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31*3deb3ec6SMatthias Ringwald  * SUCH DAMAGE.
32*3deb3ec6SMatthias Ringwald  *
33*3deb3ec6SMatthias Ringwald  * Please inquire about commercial licensing options at
34*3deb3ec6SMatthias Ringwald  * [email protected]
35*3deb3ec6SMatthias Ringwald  *
36*3deb3ec6SMatthias Ringwald  */
37*3deb3ec6SMatthias Ringwald #ifndef __ATT_SERVER_H
38*3deb3ec6SMatthias Ringwald #define __ATT_SERVER_H
39*3deb3ec6SMatthias Ringwald 
40*3deb3ec6SMatthias Ringwald #include "btstack.h"
41*3deb3ec6SMatthias Ringwald #include <stdint.h>
42*3deb3ec6SMatthias Ringwald #include "att.h"
43*3deb3ec6SMatthias Ringwald 
44*3deb3ec6SMatthias Ringwald #if defined __cplusplus
45*3deb3ec6SMatthias Ringwald extern "C" {
46*3deb3ec6SMatthias Ringwald #endif
47*3deb3ec6SMatthias Ringwald 
48*3deb3ec6SMatthias Ringwald /* API_START */
49*3deb3ec6SMatthias Ringwald /*
50*3deb3ec6SMatthias Ringwald  * @brief setup ATT server
51*3deb3ec6SMatthias Ringwald  * @param db attribute database created by compile-gatt.ph
52*3deb3ec6SMatthias Ringwald  * @param read_callback, see att.h, can be NULL
53*3deb3ec6SMatthias Ringwald  * @param write_callback, see attl.h, can be NULL
54*3deb3ec6SMatthias Ringwald  */
55*3deb3ec6SMatthias Ringwald void att_server_init(uint8_t const * db, att_read_callback_t read_callback, att_write_callback_t write_callback);
56*3deb3ec6SMatthias Ringwald 
57*3deb3ec6SMatthias Ringwald /*
58*3deb3ec6SMatthias Ringwald  * @brief register packet handler for general HCI Events like connect, diconnect, etc.
59*3deb3ec6SMatthias Ringwald  * @param handler
60*3deb3ec6SMatthias Ringwald  */
61*3deb3ec6SMatthias Ringwald void att_server_register_packet_handler(btstack_packet_handler_t handler);
62*3deb3ec6SMatthias Ringwald 
63*3deb3ec6SMatthias Ringwald /*
64*3deb3ec6SMatthias Ringwald  * @brief tests if a notification or indication can be send right now
65*3deb3ec6SMatthias Ringwald  * @return 1, if packet can be sent
66*3deb3ec6SMatthias Ringwald  */
67*3deb3ec6SMatthias Ringwald int  att_server_can_send(void);
68*3deb3ec6SMatthias Ringwald 
69*3deb3ec6SMatthias Ringwald /*
70*3deb3ec6SMatthias Ringwald  * @brief notify client about attribute value change
71*3deb3ec6SMatthias Ringwald  * @return 0 if ok, error otherwise
72*3deb3ec6SMatthias Ringwald  */
73*3deb3ec6SMatthias Ringwald int att_server_notify(uint16_t handle, uint8_t *value, uint16_t value_len);
74*3deb3ec6SMatthias Ringwald 
75*3deb3ec6SMatthias Ringwald /*
76*3deb3ec6SMatthias Ringwald  * @brief indicate value change to client. client is supposed to reply with an indication_response
77*3deb3ec6SMatthias Ringwald  * @return 0 if ok, error otherwise
78*3deb3ec6SMatthias Ringwald  */
79*3deb3ec6SMatthias Ringwald int att_server_indicate(uint16_t handle, uint8_t *value, uint16_t value_len);
80*3deb3ec6SMatthias Ringwald 
81*3deb3ec6SMatthias Ringwald /* API_END */
82*3deb3ec6SMatthias Ringwald 
83*3deb3ec6SMatthias Ringwald #if defined __cplusplus
84*3deb3ec6SMatthias Ringwald }
85*3deb3ec6SMatthias Ringwald #endif
86*3deb3ec6SMatthias Ringwald 
87*3deb3ec6SMatthias Ringwald #endif // __ATT_SERVER_H
88