xref: /btstack/src/mesh/mesh_keys.h (revision bc6a318f2177319997f3b7da7b6f161b4ec94fed)
1f4854a5eSMatthias Ringwald /*
2f4854a5eSMatthias Ringwald  * Copyright (C) 2018 BlueKitchen GmbH
3f4854a5eSMatthias Ringwald  *
4f4854a5eSMatthias Ringwald  * Redistribution and use in source and binary forms, with or without
5f4854a5eSMatthias Ringwald  * modification, are permitted provided that the following conditions
6f4854a5eSMatthias Ringwald  * are met:
7f4854a5eSMatthias Ringwald  *
8f4854a5eSMatthias Ringwald  * 1. Redistributions of source code must retain the above copyright
9f4854a5eSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer.
10f4854a5eSMatthias Ringwald  * 2. Redistributions in binary form must reproduce the above copyright
11f4854a5eSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer in the
12f4854a5eSMatthias Ringwald  *    documentation and/or other materials provided with the distribution.
13f4854a5eSMatthias Ringwald  * 3. Neither the name of the copyright holders nor the names of
14f4854a5eSMatthias Ringwald  *    contributors may be used to endorse or promote products derived
15f4854a5eSMatthias Ringwald  *    from this software without specific prior written permission.
16f4854a5eSMatthias Ringwald  * 4. Any redistribution, use, or modification is done solely for
17f4854a5eSMatthias Ringwald  *    personal benefit and not for any commercial purpose or for
18f4854a5eSMatthias Ringwald  *    monetary gain.
19f4854a5eSMatthias Ringwald  *
20f4854a5eSMatthias Ringwald  * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS
21f4854a5eSMatthias Ringwald  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22f4854a5eSMatthias Ringwald  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
232fca4dadSMilanka Ringwald  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BLUEKITCHEN
242fca4dadSMilanka Ringwald  * GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
25f4854a5eSMatthias Ringwald  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
26f4854a5eSMatthias Ringwald  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
27f4854a5eSMatthias Ringwald  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
28f4854a5eSMatthias Ringwald  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
29f4854a5eSMatthias Ringwald  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
30f4854a5eSMatthias Ringwald  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31f4854a5eSMatthias Ringwald  * SUCH DAMAGE.
32f4854a5eSMatthias Ringwald  *
33f4854a5eSMatthias Ringwald  * Please inquire about commercial licensing options at
34f4854a5eSMatthias Ringwald  * [email protected]
35f4854a5eSMatthias Ringwald  *
36f4854a5eSMatthias Ringwald  */
37f4854a5eSMatthias Ringwald 
38*bc6a318fSMatthias Ringwald #ifndef MESH_KEYS_H
39*bc6a318fSMatthias Ringwald #define MESH_KEYS_H
40f4854a5eSMatthias Ringwald 
41f4854a5eSMatthias Ringwald #include <stdint.h>
42f4854a5eSMatthias Ringwald 
43f4854a5eSMatthias Ringwald #include "btstack_linked_list.h"
44f4854a5eSMatthias Ringwald 
45f4854a5eSMatthias Ringwald #include "mesh/adv_bearer.h"
46f4854a5eSMatthias Ringwald 
47f4854a5eSMatthias Ringwald #ifdef __cplusplus
48f4854a5eSMatthias Ringwald extern "C"
49f4854a5eSMatthias Ringwald {
50f4854a5eSMatthias Ringwald #endif
51f4854a5eSMatthias Ringwald 
520500a934SMatthias Ringwald #define MESH_KEYS_INVALID_INDEX 0xffff
530500a934SMatthias Ringwald 
54f4854a5eSMatthias Ringwald typedef struct {
55f4854a5eSMatthias Ringwald     btstack_linked_item_t item;
56f4854a5eSMatthias Ringwald 
57f4854a5eSMatthias Ringwald     // internal index [0..MAX_NR_MESH_NETWORK_KEYS-1]
58f4854a5eSMatthias Ringwald     uint16_t internal_index;
59f4854a5eSMatthias Ringwald 
60f4854a5eSMatthias Ringwald     // index into shared global key list
61f4854a5eSMatthias Ringwald     uint16_t netkey_index;
62f4854a5eSMatthias Ringwald 
63f4854a5eSMatthias Ringwald     // internal version - allows for newer-than relation between keys with same netkey_index
64f4854a5eSMatthias Ringwald     uint8_t version;
65f4854a5eSMatthias Ringwald 
66f4854a5eSMatthias Ringwald     // net_key from provisioner or Config Model Client
67f4854a5eSMatthias Ringwald     uint8_t net_key[16];
68f4854a5eSMatthias Ringwald 
69f4854a5eSMatthias Ringwald     // derived data
70f4854a5eSMatthias Ringwald 
71f4854a5eSMatthias Ringwald     // k1
72f4854a5eSMatthias Ringwald     uint8_t identity_key[16];
73f4854a5eSMatthias Ringwald     uint8_t beacon_key[16];
74f4854a5eSMatthias Ringwald 
75f4854a5eSMatthias Ringwald     // k3
76f4854a5eSMatthias Ringwald     uint8_t network_id[8];
77f4854a5eSMatthias Ringwald 
78f4854a5eSMatthias Ringwald     // k2
79f4854a5eSMatthias Ringwald     uint8_t nid;
80f4854a5eSMatthias Ringwald     uint8_t encryption_key[16];
81f4854a5eSMatthias Ringwald     uint8_t privacy_key[16];
82f4854a5eSMatthias Ringwald 
83f4854a5eSMatthias Ringwald } mesh_network_key_t;
84f4854a5eSMatthias Ringwald 
85f4854a5eSMatthias Ringwald typedef struct {
86f4854a5eSMatthias Ringwald     btstack_linked_list_iterator_t it;
87f4854a5eSMatthias Ringwald     mesh_network_key_t * key;
88f4854a5eSMatthias Ringwald     uint8_t nid;
89f4854a5eSMatthias Ringwald } mesh_network_key_iterator_t;
90f4854a5eSMatthias Ringwald 
91f4854a5eSMatthias Ringwald typedef struct {
92f4854a5eSMatthias Ringwald     btstack_linked_item_t item;
93f4854a5eSMatthias Ringwald 
94f4854a5eSMatthias Ringwald     // internal index [0..MAX_NR_MESH_TRANSPORT_KEYS-1]
95f4854a5eSMatthias Ringwald     uint16_t internal_index;
96f4854a5eSMatthias Ringwald 
97f4854a5eSMatthias Ringwald     // netkey_index of subnet this app key is used with
98f4854a5eSMatthias Ringwald     uint16_t netkey_index;
99f4854a5eSMatthias Ringwald 
100f4854a5eSMatthias Ringwald     // index into shared global app key list
101f4854a5eSMatthias Ringwald     uint16_t appkey_index;
102f4854a5eSMatthias Ringwald 
103f4854a5eSMatthias Ringwald     // app_key
104f4854a5eSMatthias Ringwald     uint8_t key[16];
105f4854a5eSMatthias Ringwald 
106f4854a5eSMatthias Ringwald     // internal version - allows for newer-than relation between keys with same appkey_index
107f4854a5eSMatthias Ringwald     uint8_t version;
108f4854a5eSMatthias Ringwald 
109f4854a5eSMatthias Ringwald     // old key - mark key as 'older' in app key update or startup
110f4854a5eSMatthias Ringwald     uint8_t old_key;
111f4854a5eSMatthias Ringwald 
112f4854a5eSMatthias Ringwald     // application key flag, 0 for device key
113f4854a5eSMatthias Ringwald     uint8_t akf;
114f4854a5eSMatthias Ringwald 
115f4854a5eSMatthias Ringwald     // application key hash id
116f4854a5eSMatthias Ringwald     uint8_t aid;
117f4854a5eSMatthias Ringwald 
118f4854a5eSMatthias Ringwald     // key refresth
119f4854a5eSMatthias Ringwald     uint8_t key_refresh;
120f4854a5eSMatthias Ringwald 
121f4854a5eSMatthias Ringwald } mesh_transport_key_t;
122f4854a5eSMatthias Ringwald 
123f4854a5eSMatthias Ringwald typedef struct {
124f4854a5eSMatthias Ringwald     btstack_linked_list_iterator_t it;
125f4854a5eSMatthias Ringwald     mesh_transport_key_t * key;
126f4854a5eSMatthias Ringwald     uint16_t netkey_index;
127f4854a5eSMatthias Ringwald     uint8_t  akf;
128f4854a5eSMatthias Ringwald     uint8_t  aid;
129f4854a5eSMatthias Ringwald } mesh_transport_key_iterator_t;
130f4854a5eSMatthias Ringwald 
131f4854a5eSMatthias Ringwald /**
132f4854a5eSMatthias Ringwald  * @brief Init network key storage
133f4854a5eSMatthias Ringwald  */
134f4854a5eSMatthias Ringwald void mesh_network_key_init(void);
135f4854a5eSMatthias Ringwald 
136f4854a5eSMatthias Ringwald /**
137f4854a5eSMatthias Ringwald  * @brief Get internal index of free network key storage entry
138f4854a5eSMatthias Ringwald  * @note index 0 is reserved for primary network key
1396b65794dSMilanka Ringwald  * @return index or MESH_KEYS_INVALID_INDEX if none found
140f4854a5eSMatthias Ringwald  */
141f4854a5eSMatthias Ringwald uint16_t mesh_network_key_get_free_index(void);
142f4854a5eSMatthias Ringwald 
143f4854a5eSMatthias Ringwald /**
144f4854a5eSMatthias Ringwald  * @brief Add network key to list
145f4854a5eSMatthias Ringwald  * @param network_key
146f4854a5eSMatthias Ringwald  * @note derivative data k1-k3 need to be already calculated
147f4854a5eSMatthias Ringwald  */
148f4854a5eSMatthias Ringwald void mesh_network_key_add(mesh_network_key_t * network_key);
149f4854a5eSMatthias Ringwald 
150f4854a5eSMatthias Ringwald /**
151f4854a5eSMatthias Ringwald  * @brief Remove network key from list
152f4854a5eSMatthias Ringwald  * @param network_key
153d58a1b5fSMatthias Ringwald  * @return true if removed
154f4854a5eSMatthias Ringwald  * @note key is only removed from list, memory is not released
155f4854a5eSMatthias Ringwald  */
156d58a1b5fSMatthias Ringwald bool mesh_network_key_remove(mesh_network_key_t * network_key);
157f4854a5eSMatthias Ringwald 
158f4854a5eSMatthias Ringwald /**
159f4854a5eSMatthias Ringwald  * @brief Get network_key for netkey_index
160f4854a5eSMatthias Ringwald  * @param netkey_index
1616b65794dSMilanka Ringwald  * @return mesh_network_key_t or NULL
162f4854a5eSMatthias Ringwald  */
163f4854a5eSMatthias Ringwald mesh_network_key_t * mesh_network_key_list_get(uint16_t netkey_index);
164f4854a5eSMatthias Ringwald 
165f4854a5eSMatthias Ringwald /**
166f4854a5eSMatthias Ringwald  * @brief Get number of stored network_keys
1676b65794dSMilanka Ringwald  * @return count
168f4854a5eSMatthias Ringwald  */
169f4854a5eSMatthias Ringwald int mesh_network_key_list_count(void);
170f4854a5eSMatthias Ringwald 
171f4854a5eSMatthias Ringwald /**
172f4854a5eSMatthias Ringwald  * @brief Iterate over all network keys
173f4854a5eSMatthias Ringwald  * @param it
174f4854a5eSMatthias Ringwald  */
175f4854a5eSMatthias Ringwald void mesh_network_key_iterator_init(mesh_network_key_iterator_t *it);
176f4854a5eSMatthias Ringwald 
177f4854a5eSMatthias Ringwald /**
178f4854a5eSMatthias Ringwald  * @brief Check if another network_key is available
179f4854a5eSMatthias Ringwald  * @param it
180f4854a5eSMatthias Ringwald  * @return
181f4854a5eSMatthias Ringwald  */
182f4854a5eSMatthias Ringwald int mesh_network_key_iterator_has_more(mesh_network_key_iterator_t *it);
183f4854a5eSMatthias Ringwald 
184f4854a5eSMatthias Ringwald /**
185f4854a5eSMatthias Ringwald  * @brief Get net network_key
186f4854a5eSMatthias Ringwald  * @param it
187f4854a5eSMatthias Ringwald  * @return
188f4854a5eSMatthias Ringwald  */
189f4854a5eSMatthias Ringwald mesh_network_key_t * mesh_network_key_iterator_get_next(mesh_network_key_iterator_t *it);
190f4854a5eSMatthias Ringwald 
191f4854a5eSMatthias Ringwald /**
192f4854a5eSMatthias Ringwald  * @brief Iterate over all network keys with a given NID
193f4854a5eSMatthias Ringwald  * @param it
194f4854a5eSMatthias Ringwald  * @param nid
195f4854a5eSMatthias Ringwald  */
196f4854a5eSMatthias Ringwald void mesh_network_key_nid_iterator_init(mesh_network_key_iterator_t *it, uint8_t nid);
197f4854a5eSMatthias Ringwald 
198f4854a5eSMatthias Ringwald /**
199f4854a5eSMatthias Ringwald  * @brief Check if another network_key with given NID is available
200f4854a5eSMatthias Ringwald  * @param it
201f4854a5eSMatthias Ringwald  * @return
202f4854a5eSMatthias Ringwald  */
203f4854a5eSMatthias Ringwald int mesh_network_key_nid_iterator_has_more(mesh_network_key_iterator_t *it);
204f4854a5eSMatthias Ringwald 
205f4854a5eSMatthias Ringwald /**
206f4854a5eSMatthias Ringwald  * @brief Get next network_key with given NID
207f4854a5eSMatthias Ringwald  * @param it
208f4854a5eSMatthias Ringwald  * @return
209f4854a5eSMatthias Ringwald  */
210f4854a5eSMatthias Ringwald mesh_network_key_t * mesh_network_key_nid_iterator_get_next(mesh_network_key_iterator_t *it);
211f4854a5eSMatthias Ringwald 
212f4854a5eSMatthias Ringwald /**
213f4854a5eSMatthias Ringwald  * Transport Keys = Application Keys + Device Key
214f4854a5eSMatthias Ringwald  */
215f4854a5eSMatthias Ringwald 
216f4854a5eSMatthias Ringwald /**
217f4854a5eSMatthias Ringwald  * @brief Set device key
218f4854a5eSMatthias Ringwald  * @param device_key
219f4854a5eSMatthias Ringwald  */
220f4854a5eSMatthias Ringwald void mesh_transport_set_device_key(const uint8_t * device_key);
221f4854a5eSMatthias Ringwald 
222f4854a5eSMatthias Ringwald /**
223f4854a5eSMatthias Ringwald  * @brief Get internal index of free transport key storage entry
224f4854a5eSMatthias Ringwald  * @note index 0 is reserved for device key
2256b65794dSMilanka Ringwald  * @return index or 0u if none found
226f4854a5eSMatthias Ringwald  */
227f4854a5eSMatthias Ringwald uint16_t mesh_transport_key_get_free_index(void);
228f4854a5eSMatthias Ringwald 
229f4854a5eSMatthias Ringwald /**
230f4854a5eSMatthias Ringwald  * @brief Add application key to list
231f4854a5eSMatthias Ringwald  * @param application key
232f4854a5eSMatthias Ringwald  * @note AID needs to be set
233f4854a5eSMatthias Ringwald  */
234f4854a5eSMatthias Ringwald void mesh_transport_key_add(mesh_transport_key_t * transport_key);
235f4854a5eSMatthias Ringwald 
236f4854a5eSMatthias Ringwald /**
237f4854a5eSMatthias Ringwald  * @brief Remove application key from list
238f4854a5eSMatthias Ringwald  * @param application key
239f4854a5eSMatthias Ringwald  * @return 0 if removed
240f4854a5eSMatthias Ringwald  * @note key is only removed from list, memory is not released
241f4854a5eSMatthias Ringwald  */
242d58a1b5fSMatthias Ringwald bool mesh_transport_key_remove(mesh_transport_key_t * transport_key);
243f4854a5eSMatthias Ringwald 
244f4854a5eSMatthias Ringwald /**
245f4854a5eSMatthias Ringwald  * Get transport key for appkey_index
246f4854a5eSMatthias Ringwald  * @param appkey_index
247f4854a5eSMatthias Ringwald  * @return
248f4854a5eSMatthias Ringwald  */
249f4854a5eSMatthias Ringwald mesh_transport_key_t * mesh_transport_key_get(uint16_t appkey_index);
250f4854a5eSMatthias Ringwald 
251f4854a5eSMatthias Ringwald /**
252f4854a5eSMatthias Ringwald  * @brief Iterate over all transport keys (AppKeys) for a given netkey index
253f4854a5eSMatthias Ringwald  * @param it
254f4854a5eSMatthias Ringwald  * @param netkey_index
255f4854a5eSMatthias Ringwald  */
256f4854a5eSMatthias Ringwald void mesh_transport_key_iterator_init(mesh_transport_key_iterator_t *it, uint16_t netkey_index);
257f4854a5eSMatthias Ringwald 
258f4854a5eSMatthias Ringwald /**
259f4854a5eSMatthias Ringwald  * @brief Check if another transport key (AppKey) is available
260f4854a5eSMatthias Ringwald  * @param it
261f4854a5eSMatthias Ringwald  * @return
262f4854a5eSMatthias Ringwald  */
263f4854a5eSMatthias Ringwald int mesh_transport_key_iterator_has_more(mesh_transport_key_iterator_t *it);
264f4854a5eSMatthias Ringwald 
265f4854a5eSMatthias Ringwald /**
266f4854a5eSMatthias Ringwald  * @brief Get next transport key (AppKey)
267f4854a5eSMatthias Ringwald  * @param it
268f4854a5eSMatthias Ringwald  * @return
269f4854a5eSMatthias Ringwald  */
270f4854a5eSMatthias Ringwald mesh_transport_key_t * mesh_transport_key_iterator_get_next(mesh_transport_key_iterator_t *it);
271f4854a5eSMatthias Ringwald 
272f4854a5eSMatthias Ringwald /**
273f4854a5eSMatthias Ringwald  * @brief Transport Key Iterator by AID - init
274f4854a5eSMatthias Ringwald  * @param it
275f4854a5eSMatthias Ringwald  * @param netkey_index
276f4854a5eSMatthias Ringwald  * @param akf
277f4854a5eSMatthias Ringwald  * @param aid
278f4854a5eSMatthias Ringwald  */
279f4854a5eSMatthias Ringwald void mesh_transport_key_aid_iterator_init(mesh_transport_key_iterator_t *it, uint16_t netkey_index, uint8_t akf,
280f4854a5eSMatthias Ringwald                                           uint8_t aid);
281f4854a5eSMatthias Ringwald 
282f4854a5eSMatthias Ringwald /**
283f4854a5eSMatthias Ringwald  * @brief Transport Key Iterator by AID - has more?
284f4854a5eSMatthias Ringwald  * @param it
285f4854a5eSMatthias Ringwald  * @return
286f4854a5eSMatthias Ringwald  */
287f4854a5eSMatthias Ringwald int mesh_transport_key_aid_iterator_has_more(mesh_transport_key_iterator_t *it);
288f4854a5eSMatthias Ringwald 
289f4854a5eSMatthias Ringwald /**
290f4854a5eSMatthias Ringwald  * @brief Transport Key Iterator by AID - get next
291f4854a5eSMatthias Ringwald  * @param it
292f4854a5eSMatthias Ringwald  * @return transport key
293f4854a5eSMatthias Ringwald  */
294f4854a5eSMatthias Ringwald mesh_transport_key_t * mesh_transport_key_aid_iterator_get_next(mesh_transport_key_iterator_t *it);
295f4854a5eSMatthias Ringwald 
296f4854a5eSMatthias Ringwald #ifdef __cplusplus
297f4854a5eSMatthias Ringwald } /* end of extern "C" */
298f4854a5eSMatthias Ringwald #endif
299f4854a5eSMatthias Ringwald 
300f4854a5eSMatthias Ringwald #endif
301