mbed-os/features/FEATURE_BLE/ble/pal/PalSecurityManager.h

424 lines
13 KiB
C
Raw Normal View History

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"
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;
typedef BLEProtocol::AddressBytes_t address_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];
typedef uint32_t passkey_num_t;
2017-12-22 15:53:54 +00:00
struct bonded_list_entry_t {
address_t peer_address;
2017-12-22 15:53:54 +00:00
ediv_t ediv;
rand_t rand;
ltk_t ltk;
2018-01-07 22:22:55 +00:00
csrk_t csrk;
2017-12-22 15:53:54 +00:00
};
struct resolving_list_entry_t {
address_t peer_address;
2017-12-22 15:53:54 +00:00
irk_t peer_irk;
irk_t local_irk;
};
/** Representation of a resolving list. */
struct resolving_list_t {
resolving_list_entry_t *entries; /**< pointer to array storing the entries */
uint8_t size; /**< actual number of entries */
uint8_t capacity; /**< number of entries that can be stored */
};
/** Representation of a bonded list. */
2018-01-03 18:04:22 +00:00
struct bonded_list_t {
2017-12-22 15:53:54 +00:00
bonded_list_entry_t *entries; /**< pointer to array storing the entries */
uint8_t size; /**< actual number of entries */
uint8_t capacity; /**< number of entries that can be stored */
};
2018-01-11 18:45:27 +00:00
class SecurityManagerEventHandler {
SecurityManagerEventHandler() : _app_event_handler(NULL) { };
virtual void security_setup_initiated(connection_handle_t handle, bool allowBonding,
2018-01-11 18:45:27 +00:00
bool requireMITM, SecurityManager::SecurityIOCapabilities_t iocaps) {
if (_app_event_handler) {
_app_event_handler->securitySetupInitiated(handle, allowBonding, requireMITM, iocaps);
2018-01-11 18:45:27 +00:00
}
}
virtual void security_setup_completed(connection_handle_t handle,
2018-01-11 18:45:27 +00:00
SecurityManager::SecurityCompletionStatus_t status) {
if (_app_event_handler) {
_app_event_handler->securitySetupCompleted(handle, status);
2018-01-11 18:45:27 +00:00
}
}
virtual void link_secured(connection_handle_t handle, SecurityManager::SecurityMode_t securityMode) {
if (_app_event_handler) {
_app_event_handler->linkSecured(handle, securityMode);
2018-01-11 18:45:27 +00:00
}
}
virtual void security_context_stored(connection_handle_t handle) {
if (_app_event_handler) {
_app_event_handler->securityContextStored(handle);
2018-01-11 18:45:27 +00:00
}
}
virtual void passkey_display(connection_handle_t handle, const SecurityManager::Passkey_t passkey) {
if (_app_event_handler) {
_app_event_handler->passkeyDisplay(handle, passkey);
2018-01-11 18:45:27 +00:00
}
}
virtual void valid_mic_timeout(connection_handle_t handle) {
if (_app_event_handler) {
_app_event_handler->validMicTimeout(handle);
2018-01-11 18:45:27 +00:00
}
}
virtual void link_key_failure(connection_handle_t handle) {
if (_app_event_handler) {
_app_event_handler->linkKeyFailure(handle);
2018-01-11 18:45:27 +00:00
}
}
virtual void keypress_notification(connection_handle_t handle, SecurityManager::Keypress_t keypress) {
if (_app_event_handler) {
_app_event_handler->keypressNotification(handle, keypress);
2018-01-11 18:45:27 +00:00
}
}
virtual void legacy_pariring_oob_request(connection_handle_t handle) {
if (_app_event_handler) {
_app_event_handler->legacyPairingOobRequest(handle);
2018-01-11 18:45:27 +00:00
}
}
virtual void oob_request(connection_handle_t handle) {
if (_app_event_handler) {
_app_event_handler->oobRequest(handle);
2018-01-11 18:45:27 +00:00
}
}
virtual void pin_request(connection_handle_t handle) {
2018-01-11 18:45:27 +00:00
if (_app_event_handler) {
_app_event_handler->pinRequest(handle);
2018-01-11 18:45:27 +00:00
}
}
virtual void passkey_request(connection_handle_t handle) {
2018-01-11 18:45:27 +00:00
if (_app_event_handler) {
_app_event_handler->passkeyRequest(handle);
2018-01-11 18:45:27 +00:00
}
}
virtual void confirmation_request(connection_handle_t handle) {
2018-01-11 18:45:27 +00:00
if (_app_event_handler) {
_app_event_handler->confirmationRequest(handle);
2018-01-11 18:45:27 +00:00
}
}
virtual void accept_pairing_request(connection_handle_t handle) {
if (_app_event_handler) {
_app_event_handler->acceptPairingRequest(handle);
2018-01-11 18:45:27 +00:00
}
}
virtual void keys_exchanged(connection_handle_t handle, address_t &peer_address, ediv_t &ediv,
rand_t &rand, ltk_t &ltk, csrk_t &csrk);
virtual void ltk_request(connection_handle_t handle, ediv_t &ediv, rand_t &rand);
2018-01-11 18:45:27 +00:00
virtual void set_app_event_handler(::SecurityManagerEventHandler *app_event_handler) {
_app_event_handler = app_event_handler;
2018-01-11 18:45:27 +00:00
}
private:
::SecurityManagerEventHandler *_app_event_handler;
2018-01-11 18:45:27 +00:00
};
2017-12-22 15:53:54 +00:00
2018-01-03 18:04:22 +00:00
class SecurityManager : private mbed::NonCopyable<SecurityManager> {
2017-12-22 15:53:54 +00:00
public:
SecurityManager() : _pal_event_handler(NULL) { };
virtual ~SecurityManager() { };
2017-12-22 15:53:54 +00:00
2018-01-11 13:17:47 +00:00
virtual ble_error_t initialize() {
2018-01-11 18:27:45 +00:00
return BLE_ERROR_NONE;
2018-01-11 13:17:47 +00:00
}
virtual ble_error_t terminate() {
2018-01-11 18:27:45 +00:00
return BLE_ERROR_NONE;
2018-01-11 13:17:47 +00:00
}
virtual ble_error_t reset() {
2018-01-11 18:27:45 +00:00
return BLE_ERROR_NONE;
2018-01-11 13:17:47 +00:00
}
2017-12-22 15:53:54 +00:00
2018-01-11 11:54:21 +00:00
/* persistence */
2017-12-22 15:53:54 +00:00
2018-01-11 13:17:47 +00:00
virtual ble_error_t get_bonded_list(bonded_list_t &list) {
(void)list;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t set_bonded_list(bonded_list_t &list) {
(void)list;
return BLE_ERROR_NOT_IMPLEMENTED;
}
2017-12-22 15:53:54 +00:00
2018-01-11 13:17:47 +00:00
virtual ble_error_t get_resolving_list(resolving_list_t &list) {
(void)list;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t set_resolving_list(resolving_list_t &list) {
(void)list;
return BLE_ERROR_NOT_IMPLEMENTED;
}
2018-01-03 18:04:22 +00:00
2018-01-11 13:17:47 +00:00
virtual ble_error_t get_whitelist(Gap::Whitelist_t &list) {
(void)list;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t set_whitelist(Gap::Whitelist_t &list) {
(void)list;
return BLE_ERROR_NOT_IMPLEMENTED;
}
2017-12-22 15:53:54 +00:00
2018-01-11 11:54:21 +00:00
/* feature support */
2017-12-22 15:53:54 +00:00
2018-01-11 13:17:47 +00:00
virtual ble_error_t set_secure_connections_support(bool enabled, bool secure_connections_only = false) {
(void)enabled;
(void)secure_connections_only;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t get_secure_connections_support(bool &enabled, bool &secure_connections_only) {
(void)enabled;
(void)secure_connections_only;
return BLE_ERROR_NOT_IMPLEMENTED;
}
2017-12-22 15:53:54 +00:00
2018-01-11 11:54:21 +00:00
/* security settings */
2017-12-22 15:53:54 +00:00
2018-01-11 13:17:47 +00:00
virtual ble_error_t set_io_capabilities(SecurityIOCapabilities_t iocaps = IO_CAPS_NONE) {
(void)iocaps;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t set_bondable(bool bondable = true) {
(void)bondable;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t set_keypress_notification(bool send_keypresses = true) {
(void)send_keypresses;
return BLE_ERROR_NOT_IMPLEMENTED;
}
2017-12-22 15:53:54 +00:00
2018-01-11 13:17:47 +00:00
virtual ble_error_t set_pin_code(uint8_t pin_length, uint8_t *pin_code, bool static_pin = false) {
(void)pin_length;
(void)pin_code;
(void)static_pin;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t set_passkey(passkey_num_t passkey) {
(void)passkey;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t set_oob_data_usage(connection_handle_t handle, bool useOOB, bool OOBProvidesMITM) {
(void)handle;
(void)useOOB;
(void)OOBProvidesMITM;
return BLE_ERROR_NOT_IMPLEMENTED;
}
2017-12-22 15:53:54 +00:00
2018-01-11 13:17:47 +00:00
virtual ble_error_t set_encryption_key_size(uint8_t minimum_bitsize, uint8_t maximum_bitsize = 128) {
(void)minimum_bitsize;
(void)maximum_bitsize;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t get_encryption_key_size(connection_handle_t, uint8_t &bitsize) {
(void)bitsize;
return BLE_ERROR_NOT_IMPLEMENTED;
}
2017-12-22 15:53:54 +00:00
2018-01-11 13:17:47 +00:00
virtual ble_error_t set_authentication_timeout(connection_handle_t, uint16_t timeout_in_10ms) {
(void)timeout_in_10ms;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t get_authentication_timeout(connection_handle_t, uint16_t &timeout_in_10ms) {
(void)timeout_in_10ms;
return BLE_ERROR_NOT_IMPLEMENTED;
}
2018-01-11 13:17:47 +00:00
virtual ble_error_t refresh_encryption_key(connection_handle_t handle) {
(void)handle;
return BLE_ERROR_NOT_IMPLEMENTED;
}
2017-12-22 15:53:54 +00:00
2018-01-11 11:54:21 +00:00
/* privacy */
2017-12-22 15:53:54 +00:00
2018-01-11 13:17:47 +00:00
virtual ble_error_t set_private_address_timeout(uint16_t timeout_in_seconds) {
(void)timeout_in_seconds;
return BLE_ERROR_NOT_IMPLEMENTED;
}
/* keys */
virtual ble_error_t set_key_distribution() {
(void);
2018-01-11 13:17:47 +00:00
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t set_ltk(connection_handle_t handle, ltk_t ltk) {
(void)ltk;
2018-01-11 18:27:45 +00:00
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t set_irk(irk_t irk) {
(void)irk;
2018-01-11 18:27:45 +00:00
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t set_csrk(csrk_t csrk) {
(void)csrk;
2018-01-11 13:17:47 +00:00
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t generate_irk() {
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t generate_csrk() {
return BLE_ERROR_NOT_IMPLEMENTED;
}
2018-01-11 18:27:45 +00:00
/* authentication */
2018-01-11 13:17:47 +00:00
virtual ble_error_t get_encryption_status(connection_handle_t handle, LinkSecurityStatus_t &status) {
(void)handle;
(void)status;
return BLE_ERROR_NOT_IMPLEMENTED;
}
2018-01-02 17:54:22 +00:00
virtual ble_error_t request_pairing() {
2018-01-11 13:17:47 +00:00
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t set_pairing_request_authorisation(bool authorisation_required = true) {
(void)authorisation_required;
2018-01-11 18:27:45 +00:00
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t accept_pairing() {
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t reject_pairing() {
2018-01-11 13:17:47 +00:00
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t cancel_pairing() {
2018-01-11 13:17:47 +00:00
return BLE_ERROR_NOT_IMPLEMENTED;
}
2018-01-07 22:22:55 +00:00
2018-01-11 13:17:47 +00:00
virtual ble_error_t request_authentication() {
return BLE_ERROR_NOT_IMPLEMENTED;
}
2018-01-07 22:22:55 +00:00
2018-01-02 17:54:22 +00:00
/* MITM */
2017-12-22 15:53:54 +00:00
2018-01-11 13:17:47 +00:00
virtual ble_error_t confirmation_entered(connection_handle_t handle, bool confirmation) {
(void)handle;
(void)confirmation;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t passkey_entered(connection_handle_t handle, passkey_t passkey) {
(void)handle;
(void)passkey;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t send_keypress_notification(connection_handle_t handle, Keypress_t keypress) {
(void)handle;
(void)keypress;
return BLE_ERROR_NOT_IMPLEMENTED;
}
2017-12-22 15:53:54 +00:00
2018-01-11 13:17:47 +00:00
virtual ble_error_t set_oob(connection_handle_t handle, c192_t& c192, r192_t& r192) {
(void)handle;
(void)c192;
(void)r192;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t set_extended_oob(connection_handle_t handle,
c192_t& c192, r192_t& r192, c256_t& c256, r256_t& r256) {
(void)handle;
(void)c192;
(void)r192;
(void)c256;
(void)r256;
return BLE_ERROR_NOT_IMPLEMENTED;
}
virtual ble_error_t get_local_oob_data(connection_handle_t handle, c192_t& c192, r192_t& r192) {
(void)handle;
(void)c192;
(void)r192;
return BLE_ERROR_NOT_IMPLEMENTED;
}
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) {
(void)handle;
(void)c192;
(void)r192;
(void)c256;
(void)r256;
return BLE_ERROR_NOT_IMPLEMENTED;
}
2017-12-22 15:53:54 +00:00
/* Entry points for the underlying stack to report events back to the user. */
public:
SecurityManagerEventHandler& get_event_handler() {
/* guaranteed to be a valid pointer */
return _pal_event_handler;
2018-01-11 18:45:27 +00:00
}
void set_app_event_handler(::SecurityManagerEventHandler &app_event_handler) {
_pal_event_handler->set_app_event_handler(app_event_handler);
2017-12-22 15:53:54 +00:00
}
void set_event_handler(SecurityManagerEventHandler &event_handler) {
_pal_event_handler = &event_handler;
2017-12-22 15:53:54 +00:00
}
private:
SecurityManagerEventHandler *_pal_event_handler;
2017-12-22 15:53:54 +00:00
};
} /* namespace pal */
} /* namespace ble */
2017-12-22 15:53:54 +00:00
#endif /* MBED_OS_FEATURES_FEATURE_BLE_BLE_PAL_PALSM_H_ */