This is the Initial Security Bitmask that controls the use of various security features.

Enumeration Members

DISTRIBUTED_TRUST_CENTER_MODE: 2

Enables Distributed Trust Center Mode for the device forming the network. (Previously known as ::EMBER_NO_TRUST_CENTER_MODE)

EM_SAVED_IN_TOKEN: 16384
GET_LINK_KEY_WHEN_JOINING: 1024

This denotes to a joining node that it should attempt to acquire a Trust Center Link Key during joining. This is necessary if the device does not have a pre-configured key, or wants to obtain a new one (since it may be using a well-known key during joining).

GET_PRECONFIGURED_KEY_FROM_INSTALL_CODE: 8192

This denotes that the device should obtain its pre-configured key from an installation code stored in the manufacturing token. The token contains a value that will be hashed to obtain the actual pre-configured key. If that token is not valid, the call to ::emberSetInitialSecurityState() will fail.

HAVE_NETWORK_KEY: 512

This denotes that the ::EmberInitialSecurityState::networkKey element has valid data that should be used to configure the initial security state.

HAVE_PRECONFIGURED_KEY: 256

This denotes that the ::EmberInitialSecurityState::preconfiguredKey element has valid data that should be used to configure the initial security state.

HAVE_TRUST_CENTER_EUI64: 64

This denotes that the ::EmberInitialSecurityState::preconfiguredTrustCenterEui64 has a value in it containing the trust center EUI64. The device will only join a network and accept commands from a trust center with that EUI64. Normally this bit is NOT set and the EUI64 of the trust center is learned during the join process. When commissioning a device to join onto an existing network that is using a trust center and without sending any messages, this bit must be set and the field ::EmberInitialSecurityState::preconfiguredTrustCenterEui64 must be populated with the appropriate EUI64.

HAVE_TRUST_CENTER_LINK_KEY_TOKEN: 32
HAVE_TRUST_CENTER_UNKNOWN_KEY_TOKEN: 16
NO_FRAME_COUNTER_RESET: 4096

This denotes whether the device should NOT reset its outgoing frame counters (both NWK and APS) when ::emberSetInitialSecurityState() is called. Normally it is advised to reset the frame counter before joining a new network. However, when a device is joining to the same network again (but not using ::emberRejoinNetwork()), it should keep the NWK and APS frame counters stored in its tokens.

NOTE: The application is allowed to dynamically change the behavior via EMBER_EXT_NO_FRAME_COUNTER_RESET field.

PRECONFIGURED_NETWORK_KEY_MODE: 8

Enables devices that perform MAC Association with a pre-configured Network Key to join the network. It is only set on the Trust Center.

REQUIRE_ENCRYPTED_KEY: 2048

This denotes that a joining device should only accept an encrypted network key from the Trust Center (using its pre-configured key). A key sent in-the-clear by the Trust Center will be rejected and the join will fail. This option is only valid when using a pre-configured key.

TRUST_CENTER_GLOBAL_LINK_KEY: 4

Enables a Global Link Key for the Trust Center. All nodes will share the same Trust Center Link Key.

TRUST_CENTER_USES_HASHED_LINK_KEY: 132

This denotes that the ::EmberInitialSecurityState::preconfiguredKey is not the actual Link Key but a Root Key known only to the Trust Center. It is hashed with the IEEE Address of the destination device to create the actual Link Key used in encryption. This is bit is only used by the Trust Center. The joining device need not set this.