xref: /btstack/src/ble/gatt-service/scan_parameters_service_server.h (revision 1ea30d1b446f98d1f402813e0d01452037f1e414)
1ffb44729SMilanka Ringwald /*
2ffb44729SMilanka Ringwald  * Copyright (C) 2018 BlueKitchen GmbH
3ffb44729SMilanka Ringwald  *
4ffb44729SMilanka Ringwald  * Redistribution and use in source and binary forms, with or without
5ffb44729SMilanka Ringwald  * modification, are permitted provided that the following conditions
6ffb44729SMilanka Ringwald  * are met:
7ffb44729SMilanka Ringwald  *
8ffb44729SMilanka Ringwald  * 1. Redistributions of source code must retain the above copyright
9ffb44729SMilanka Ringwald  *    notice, this list of conditions and the following disclaimer.
10ffb44729SMilanka Ringwald  * 2. Redistributions in binary form must reproduce the above copyright
11ffb44729SMilanka Ringwald  *    notice, this list of conditions and the following disclaimer in the
12ffb44729SMilanka Ringwald  *    documentation and/or other materials provided with the distribution.
13ffb44729SMilanka Ringwald  * 3. Neither the name of the copyright holders nor the names of
14ffb44729SMilanka Ringwald  *    contributors may be used to endorse or promote products derived
15ffb44729SMilanka Ringwald  *    from this software without specific prior written permission.
16ffb44729SMilanka Ringwald  * 4. Any redistribution, use, or modification is done solely for
17ffb44729SMilanka Ringwald  *    personal benefit and not for any commercial purpose or for
18ffb44729SMilanka Ringwald  *    monetary gain.
19ffb44729SMilanka Ringwald  *
20ffb44729SMilanka Ringwald  * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS
21ffb44729SMilanka Ringwald  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22ffb44729SMilanka Ringwald  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23ffb44729SMilanka Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
24ffb44729SMilanka Ringwald  * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25ffb44729SMilanka Ringwald  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
26ffb44729SMilanka Ringwald  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
27ffb44729SMilanka Ringwald  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
28ffb44729SMilanka Ringwald  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
29ffb44729SMilanka Ringwald  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
30ffb44729SMilanka Ringwald  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31ffb44729SMilanka Ringwald  * SUCH DAMAGE.
32ffb44729SMilanka Ringwald  *
33ffb44729SMilanka Ringwald  * Please inquire about commercial licensing options at
34ffb44729SMilanka Ringwald  * [email protected]
35ffb44729SMilanka Ringwald  *
36ffb44729SMilanka Ringwald  */
37ffb44729SMilanka Ringwald #ifndef SCAN_PARAMETERS_H
38ffb44729SMilanka Ringwald #define SCAN_PARAMETERS_H
39ffb44729SMilanka Ringwald 
40ffb44729SMilanka Ringwald #include <stdint.h>
41ffb44729SMilanka Ringwald #include "bluetooth.h"
42ffb44729SMilanka Ringwald #include "btstack_defines.h"
43ffb44729SMilanka Ringwald 
44ffb44729SMilanka Ringwald #if defined __cplusplus
45ffb44729SMilanka Ringwald extern "C" {
46ffb44729SMilanka Ringwald #endif
47ffb44729SMilanka Ringwald 
48ffb44729SMilanka Ringwald /* API_START */
49ffb44729SMilanka Ringwald 
50ffb44729SMilanka Ringwald /**
51*1ea30d1bSMilanka Ringwald  * @text The Scan Parameters Service enables a remote GATT Client to store the LE scan parameters it is using locally. These parameters can be utilized by the application to optimize power consumption and/or reconnection latency.
52ffb44729SMilanka Ringwald  *
53*1ea30d1bSMilanka Ringwald  * To use with your application, add `#import <scan_parameters_service.gatt` to your .gatt file
54ffb44729SMilanka Ringwald  * and call all functions below. All strings and blobs need to stay valid after calling the functions.
55ffb44729SMilanka Ringwald  */
56ffb44729SMilanka Ringwald 
57ffb44729SMilanka Ringwald /**
58ffb44729SMilanka Ringwald  * @brief Init Scan Parameters Service Server with ATT DB
59ffb44729SMilanka Ringwald  * @param packet_handler
60ffb44729SMilanka Ringwald  */
61ffb44729SMilanka Ringwald void scan_parameters_service_server_init(btstack_packet_handler_t packet_handler);
62ffb44729SMilanka Ringwald 
63ffb44729SMilanka Ringwald /**
6482879dc3SMilanka Ringwald  * @brief Request scan parameters from Scan Parameters Client.
65ffb44729SMilanka Ringwald  */
6682879dc3SMilanka Ringwald void scan_parameters_service_server_request_scan_parameters(void);
67ffb44729SMilanka Ringwald 
68ffb44729SMilanka Ringwald /* API_END */
69ffb44729SMilanka Ringwald 
70ffb44729SMilanka Ringwald #if defined __cplusplus
71ffb44729SMilanka Ringwald }
72ffb44729SMilanka Ringwald #endif
73ffb44729SMilanka Ringwald 
74ffb44729SMilanka Ringwald #endif
75ffb44729SMilanka Ringwald 
76