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