2018-01-11 13:17:47 +00:00
|
|
|
/* mbed Microcontroller Library
|
|
|
|
* Copyright (c) 2017-2018 ARM Limited
|
2017-12-22 15:53:54 +00:00
|
|
|
*
|
2018-01-11 13:17:47 +00:00
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
2017-12-22 15:53:54 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef MBED_OS_FEATURES_FEATURE_BLE_BLE_PAL_PALSM_H_
|
|
|
|
#define MBED_OS_FEATURES_FEATURE_BLE_BLE_PAL_PALSM_H_
|
|
|
|
|
|
|
|
#include "platform/Callback.h"
|
|
|
|
#include "platform/NonCopyable.h"
|
|
|
|
#include "ble/BLETypes.h"
|
|
|
|
#include "ble/SafeEnum.h"
|
|
|
|
#include "ble/BLEProtocol.h"
|
|
|
|
#include "ble/SecurityManager.h"
|
2018-01-15 15:05:50 +00:00
|
|
|
#include "ble/pal/GapTypes"
|
2017-12-22 15:53:54 +00:00
|
|
|
|
|
|
|
namespace ble {
|
|
|
|
namespace pal {
|
|
|
|
|
|
|
|
using SecurityManager::SecurityIOCapabilities_t;
|
2018-01-02 17:54:22 +00:00
|
|
|
using SecurityManager::IO_CAPS_NONE;
|
2017-12-22 15:53:54 +00:00
|
|
|
using SecurityManager::SecurityCompletionStatus_t;
|
|
|
|
using SecurityManager::SecurityMode_t;
|
2018-01-02 17:54:22 +00:00
|
|
|
using SecurityManager::LinkSecurityStatus_t;
|
|
|
|
using SecurityManager::Keypress_t;
|
2017-12-22 15:53:54 +00:00
|
|
|
|
2018-01-11 13:17:47 +00:00
|
|
|
/* please use typedef for porting not the types directly */
|
2017-12-22 15:53:54 +00:00
|
|
|
|
2018-01-11 13:17:47 +00:00
|
|
|
typedef SecurityManager::Passkey_t passkey_t;
|
|
|
|
typedef SecurityManager::C192_t c192_t;
|
|
|
|
typedef SecurityManager::R192_t r192_t;
|
|
|
|
typedef SecurityManager::C256_t c256_t;
|
|
|
|
typedef SecurityManager::R256_t r256_t;
|
2017-12-22 15:53:54 +00:00
|
|
|
|
|
|
|
typedef uint8_t irk_t[16];
|
|
|
|
typedef uint8_t csrk_t[16];
|
|
|
|
typedef uint8_t ltk_t[16];
|
|
|
|
typedef uint8_t ediv_t[8];
|
|
|
|
typedef uint8_t rand_t[2];
|
2018-01-05 17:32:49 +00:00
|
|
|
typedef uint32_t passkey_num_t;
|
2017-12-22 15:53:54 +00:00
|
|
|
|
2018-01-12 12:41:43 +00:00
|
|
|
typedef uint8_t key_distribution_t;
|
|
|
|
|
2018-01-15 08:31:33 +00:00
|
|
|
enum KeyDistributionFlags_t {
|
2018-01-12 12:41:43 +00:00
|
|
|
KEY_DISTRIBUTION_NONE = 0x00,
|
|
|
|
KEY_DISTRIBUTION_ENCRYPTION = 0x01,
|
|
|
|
KEY_DISTRIBUTION_IDENTITY = 0x02,
|
|
|
|
KEY_DISTRIBUTION_SIGNING = 0x04,
|
|
|
|
KEY_DISTRIBUTION_LINK = 0x08,
|
|
|
|
KEY_DISTRIBUTION_ALL = 0x0F
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef uint8_t authentication_t;
|
|
|
|
|
2018-01-15 08:31:33 +00:00
|
|
|
enum AuthenticationFlags_t {
|
2018-01-12 12:41:43 +00:00
|
|
|
AUTHENTICATION_BONDING = 0x01,
|
|
|
|
AUTHENTICATION_MITM = 0x04, /* 0x02 missing because bonding uses two bits */
|
|
|
|
AUTHENTICATION_SECURE_CONNECTIONS = 0x08,
|
|
|
|
AUTHENTICATION_KEYPRESS_NOTIFICATION = 0x10
|
|
|
|
};
|
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
/**
|
|
|
|
* Handle events generated by ble::pal::SecurityManager
|
|
|
|
*/
|
2018-01-11 18:45:27 +00:00
|
|
|
class SecurityManagerEventHandler {
|
2018-01-15 14:25:27 +00:00
|
|
|
public:
|
|
|
|
virtual void security_setup_initiated(
|
|
|
|
connection_handle_t handle,
|
|
|
|
bool allow_bonding,
|
|
|
|
bool require_mitm,
|
|
|
|
SecurityIOCapabilities_t iocaps
|
|
|
|
) = 0;
|
2018-01-11 18:45:27 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual void security_setup_completed(
|
|
|
|
connection_handle_t handle,
|
|
|
|
SecurityManager::SecurityCompletionStatus_t status
|
|
|
|
) = 0;
|
2018-01-11 18:45:27 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual void link_secured(
|
|
|
|
connection_handle_t handle, SecurityManager::SecurityMode_t security_mode
|
|
|
|
) = 0;
|
2018-01-11 18:45:27 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual void security_context_stored(connection_handle_t handle) = 0;
|
2018-01-11 18:45:27 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual void passkey_display(connection_handle_t handle, const passkey_t passkey) = 0;
|
2018-01-11 18:45:27 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual void valid_mic_timeout(connection_handle_t handle) = 0;
|
2018-01-11 18:45:27 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual void link_key_failure(connection_handle_t handle) = 0;
|
2018-01-11 18:45:27 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual void keypress_notification(connection_handle_t handle, SecurityManager::Keypress_t keypress) = 0;
|
2018-01-11 18:45:27 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual void legacy_pariring_oob_request(connection_handle_t handle) = 0;
|
2018-01-11 18:45:27 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual void oob_request(connection_handle_t handle) = 0;
|
2018-01-11 18:45:27 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual void pin_request(connection_handle_t handle) = 0;
|
2018-01-11 18:45:27 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual void passkey_request(connection_handle_t handle) = 0;
|
|
|
|
|
|
|
|
virtual void confirmation_request(connection_handle_t handle) = 0;
|
2018-01-11 18:45:27 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual void accept_pairing_request(
|
|
|
|
connection_handle_t handle,
|
|
|
|
SecurityIOCapabilities_t iocaps,
|
|
|
|
bool use_oob,
|
|
|
|
authentication_t authentication,
|
|
|
|
uint8_t max_key_size,
|
|
|
|
key_distribution_t initiator_dist,
|
|
|
|
key_distribution_t responder_dist
|
|
|
|
) = 0;
|
2017-12-22 15:53:54 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual void keys_exchanged(
|
|
|
|
connection_handle_t handle,
|
2018-01-15 15:05:50 +00:00
|
|
|
advertising_peer_address_type_t peer_identity_address_type,
|
|
|
|
address_t &peer_identity_address,
|
2018-01-15 14:25:27 +00:00
|
|
|
ediv_t &ediv,
|
|
|
|
rand_t &rand,
|
|
|
|
ltk_t <k,
|
|
|
|
csrk_t &csrk
|
|
|
|
) = 0;
|
|
|
|
|
|
|
|
virtual void ltk_request(
|
|
|
|
connection_handle_t handle,
|
|
|
|
ediv_t &ediv,
|
|
|
|
rand_t &rand
|
|
|
|
) = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adaptation layer of the Security Manager.
|
|
|
|
*/
|
2018-01-03 18:04:22 +00:00
|
|
|
class SecurityManager : private mbed::NonCopyable<SecurityManager> {
|
2017-12-22 15:53:54 +00:00
|
|
|
public:
|
2018-01-12 11:36:03 +00:00
|
|
|
SecurityManager() : _pal_event_handler(NULL) { };
|
2018-01-15 14:25:27 +00:00
|
|
|
|
2018-01-05 17:32:49 +00:00
|
|
|
virtual ~SecurityManager() { };
|
2017-12-22 15:53:54 +00:00
|
|
|
|
2018-01-15 15:05:50 +00:00
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
// SM lifecycle management
|
|
|
|
//
|
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t initialize() = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t terminate() = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t reset() = 0;
|
2017-12-22 15:53:54 +00:00
|
|
|
|
2018-01-15 15:05:50 +00:00
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Resolving list management
|
|
|
|
//
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the number of address translation entries that can be stored by the
|
|
|
|
* subsystem.
|
|
|
|
*
|
|
|
|
* @warning: The number of entries is considered fixed.
|
|
|
|
*
|
|
|
|
* see BLUETOOTH SPECIFICATION Version 5.0 | Vol 2, Part E: 7.8.41
|
|
|
|
*/
|
|
|
|
virtual uint8_t read_resolving_list_capacity() = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a device definition into the resolving list of the LE subsystem.
|
|
|
|
*
|
|
|
|
* @see BLUETOOTH SPECIFICATION Version 5.0 | Vol 2, Part E: 7.8.38
|
|
|
|
*/
|
|
|
|
virtual ble_error_t add_device_to_resolving_list(
|
|
|
|
advertising_peer_address_type_t peer_identity_address_type,
|
|
|
|
address_t peer_identity_address,
|
|
|
|
irk_t peer_irk,
|
|
|
|
irk_t local_irk
|
|
|
|
) = 0;
|
2018-01-15 14:25:27 +00:00
|
|
|
|
|
|
|
|
2018-01-15 15:05:50 +00:00
|
|
|
/**
|
|
|
|
* Add a device definition from the resolving list of the LE subsystem.
|
|
|
|
*
|
|
|
|
* @see BLUETOOTH SPECIFICATION Version 5.0 | Vol 2, Part E: 7.8.39
|
|
|
|
*/
|
|
|
|
virtual ble_error_t remove_device_from_resolving_list(
|
|
|
|
advertising_peer_address_type_t peer_identity_address_type,
|
|
|
|
address_t peer_identity_address
|
|
|
|
) = 0;
|
2018-01-15 14:25:27 +00:00
|
|
|
|
2018-01-15 15:05:50 +00:00
|
|
|
/**
|
|
|
|
* Remove all devices from the resolving list.
|
|
|
|
*
|
|
|
|
* @see BLUETOOTH SPECIFICATION Version 5.0 | Vol 2, Part E: 7.8.40
|
|
|
|
*/
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t clear_resolving_list() = 0;
|
|
|
|
|
2018-01-15 15:05:50 +00:00
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Feature support
|
|
|
|
//
|
2017-12-22 15:53:54 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t set_secure_connections_support(
|
|
|
|
bool enabled, bool secure_connections_only = false
|
|
|
|
) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t get_secure_connections_support(
|
|
|
|
bool &enabled, bool &secure_connections_only
|
|
|
|
) = 0;
|
2017-12-22 15:53:54 +00:00
|
|
|
|
2018-01-15 15:05:50 +00:00
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Security settings
|
|
|
|
//
|
2017-12-22 15:53:54 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t set_pin_code(
|
|
|
|
uint8_t pin_length, uint8_t *pin_code, bool static_pin = false
|
|
|
|
) = 0;
|
2017-12-22 15:53:54 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t set_passkey(passkey_num_t passkey) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t set_authentication_timeout(
|
|
|
|
connection_handle_t, uint16_t timeout_in_10ms
|
|
|
|
) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t get_authentication_timeout(
|
|
|
|
connection_handle_t, uint16_t &timeout_in_10ms
|
|
|
|
) = 0;
|
2018-01-05 17:32:49 +00:00
|
|
|
|
2018-01-15 15:05:50 +00:00
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Encryption
|
|
|
|
//
|
2018-01-12 15:32:11 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t enable_encryption(connection_handle_t handle) = 0;
|
2018-01-12 15:32:11 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t disable_encryption(connection_handle_t handle) = 0;
|
2018-01-12 15:32:11 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t get_encryption_status(
|
|
|
|
connection_handle_t handle, LinkSecurityStatus_t &status
|
|
|
|
) = 0;
|
2018-01-12 15:32:11 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t get_encryption_key_size(
|
|
|
|
connection_handle_t, uint8_t &bitsize
|
|
|
|
) = 0;
|
2018-01-12 15:32:11 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t refresh_encryption_key(connection_handle_t handle) = 0;
|
2017-12-22 15:53:54 +00:00
|
|
|
|
2018-01-15 15:05:50 +00:00
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Privacy
|
|
|
|
//
|
2017-12-22 15:53:54 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t set_private_address_timeout(uint16_t timeout_in_seconds) = 0;
|
2018-01-08 10:44:32 +00:00
|
|
|
|
2018-01-15 15:05:50 +00:00
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Keys
|
|
|
|
//
|
2018-01-12 12:00:34 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t set_ltk(connection_handle_t handle, ltk_t ltk) = 0;
|
2018-01-12 12:00:34 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t set_irk(irk_t irk) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t set_csrk(csrk_t csrk) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t generate_irk() = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t generate_csrk() = 0;
|
2018-01-07 23:18:14 +00:00
|
|
|
|
2018-01-15 15:05:50 +00:00
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Authentication
|
|
|
|
//
|
2018-01-11 18:27:45 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t request_pairing(
|
|
|
|
connection_handle_t handle,
|
|
|
|
SecurityIOCapabilities_t iocaps,
|
|
|
|
bool use_oob,
|
|
|
|
authentication_t authentication,
|
|
|
|
uint8_t max_key_size,
|
|
|
|
key_distribution_t initiator_dist,
|
|
|
|
key_distribution_t responder_dist
|
|
|
|
) = 0;
|
2018-01-12 12:41:43 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t accept_pairing(
|
|
|
|
connection_handle_t handle,
|
|
|
|
SecurityIOCapabilities_t iocaps,
|
|
|
|
bool use_oob,
|
|
|
|
authentication_t authentication,
|
|
|
|
uint8_t max_key_size,
|
|
|
|
key_distribution_t initiator_dist,
|
|
|
|
key_distribution_t responder_dist
|
|
|
|
) = 0;
|
2018-01-07 22:22:55 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t reject_pairing(connection_handle_t handle) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t cancel_pairing(connection_handle_t handle) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t set_pairing_request_authorisation(
|
|
|
|
bool authorisation_required = true
|
|
|
|
) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t request_authentication(connection_handle_t handle) = 0;
|
2018-01-07 22:22:55 +00:00
|
|
|
|
2018-01-15 15:05:50 +00:00
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
|
|
// MITM
|
|
|
|
//
|
2017-12-22 15:53:54 +00:00
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
virtual ble_error_t confirmation_entered(
|
|
|
|
connection_handle_t handle, bool confirmation
|
|
|
|
) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t passkey_entered(
|
|
|
|
connection_handle_t handle, passkey_t passkey
|
|
|
|
) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t send_keypress_notification(
|
|
|
|
connection_handle_t handle, Keypress_t keypress
|
|
|
|
) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t set_oob(
|
|
|
|
connection_handle_t handle, c192_t& c192, r192_t& r192
|
|
|
|
) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t set_extended_oob(
|
|
|
|
connection_handle_t handle,
|
|
|
|
c192_t& c192,
|
|
|
|
r192_t& r192,
|
|
|
|
c256_t& c256,
|
|
|
|
r256_t& r256
|
|
|
|
) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t get_local_oob_data(
|
|
|
|
connection_handle_t handle, c192_t& c192, r192_t& r192
|
|
|
|
) = 0;
|
|
|
|
|
|
|
|
virtual ble_error_t get_local_extended_oob_data(
|
|
|
|
connection_handle_t handle,
|
|
|
|
c192_t& c192, r192_t& r192, c256_t& c256, r256_t& r256
|
|
|
|
) = 0;
|
2017-12-22 15:53:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* Entry points for the underlying stack to report events back to the user. */
|
2018-01-15 14:25:27 +00:00
|
|
|
public:
|
2018-01-12 12:41:43 +00:00
|
|
|
void set_event_handler(SecurityManagerEventHandler *event_handler) {
|
|
|
|
_pal_event_handler = event_handler;
|
2017-12-22 15:53:54 +00:00
|
|
|
}
|
|
|
|
|
2018-01-15 14:25:27 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
SecurityManagerEventHandler* get_event_handler() {
|
|
|
|
return _pal_event_handler;
|
|
|
|
}
|
|
|
|
|
2017-12-22 15:53:54 +00:00
|
|
|
private:
|
2018-01-12 11:36:03 +00:00
|
|
|
SecurityManagerEventHandler *_pal_event_handler;
|
2017-12-22 15:53:54 +00:00
|
|
|
|
|
|
|
};
|
|
|
|
|
2018-01-05 17:32:49 +00:00
|
|
|
} /* namespace pal */
|
|
|
|
} /* namespace ble */
|
2017-12-22 15:53:54 +00:00
|
|
|
|
|
|
|
#endif /* MBED_OS_FEATURES_FEATURE_BLE_BLE_PAL_PALSM_H_ */
|