En Google, luchamos por la equidad racial de la comunidad negra. Más información

nl :: Tejido:: Perfiles: Seguridad:: KeyExport :: WeaveKeyExport

#include <src/lib/profiles/security/WeaveKeyExport.h>

Implementa la lógica central del protocolo de exportación de claves Weave.

Resumen

Tipos públicos

@260 {
kState_Reset = 0,
kState_InitiatorGeneratingRequest = 10,
kState_InitiatorRequestGenerated = 11,
kState_InitiatorReconfigureProcessed = 12,
kState_InitiatorDone = 13,
kState_ResponderProcessingRequest = 20,
kState_ResponderRequestProcessed = 21,
kState_ResponderDone = 22
}
enumeración
El estado actual de la WeaveKeyExport objeto.

Atributos públicos

ECDHPrivateKey [kMaxECDHPrivateKeySize]
uint8_t
ECDHPrivateKeyLen
uint16_t
ECDHPublicKey [kMaxECDHPublicKeySize]
uint8_t
EncryptionAndAuthenticationKey [kEncryptionAndAuthenticationKeySize]
uint8_t
GroupKeyStore
Puntero a un objeto de almacén de claves de grupo de plataforma.
KeyExportDelegate
Puntero a un objeto delegado de exportación clave.
SharedSecret [kMaxECDHSharedSecretSize]
uint8_t
SharedSecretLen
uint16_t

Funciones publicas

AllowedConfigs () const
uint8_t
GenerateKeyExportReconfigure (uint8_t *buf, uint16_t bufSize, uint16_t & msgLen)
GenerateKeyExportRequest (uint8_t *buf, uint16_t bufSize, uint16_t & msgLen, uint8_t proposedConfig, uint32_t keyId, bool signMessages)
GenerateKeyExportResponse (uint8_t *buf, uint16_t bufSize, uint16_t & msgLen, const WeaveMessageInfo *msgInfo)
Init ( WeaveKeyExportDelegate *keyExportDelegate, GroupKeyStoreBase *groupKeyStore)
void
IsAllowedConfig (uint8_t config) const
bool
IsInitiator () const
bool
KeyId () const
uint32_t
MessageInfo () const
ProcessKeyExportReconfigure (const uint8_t *buf, uint16_t msgSize, uint8_t & config)
ProcessKeyExportRequest (const uint8_t *buf, uint16_t msgSize, const WeaveMessageInfo *msgInfo)
ProcessKeyExportResponse (const uint8_t *buf, uint16_t msgSize, const WeaveMessageInfo *msgInfo, uint8_t *exportedKeyBuf, uint16_t exportedKeyBufSize, uint16_t & exportedKeyLen, uint32_t & exportedKeyId)
ProtocolConfig () const
uint8_t
Reset (void)
void
SetAllowedConfigs (uint8_t allowedConfigs)
void
Shutdown (void)
void
SignMessages () const
bool
State () const
uint8_t

Tipos públicos

@ 260

 @260

El estado actual de la WeaveKeyExport objeto.

Propiedades
kState_InitiatorDone

Estado del iniciador que indica que se procesó la respuesta de exportación de claves.

kState_InitiatorGeneratingRequest

Estado del iniciador que indica que se está generando el mensaje de solicitud de exportación de claves.

kState_InitiatorReconfigureProcessed

Estado del iniciador que indica que se procesó el mensaje de reconfiguración de exportación de claves.

kState_InitiatorRequestGenerated

Estado del iniciador que indica que se ha generado el mensaje de solicitud de exportación de claves.

kState_Reset

El estado inicial (y final) de un WeaveKeyExport objeto.

kState_ResponderDone

Estado de respuesta que indica que se generó el mensaje de respuesta de exportación de claves.

kState_ResponderProcessingRequest

Estado de respuesta que indica que se está procesando el mensaje de solicitud de exportación de claves.

kState_ResponderRequestProcessed

Estado de respuesta que indica que se ha procesado el mensaje de solicitud de exportación de claves.

Atributos públicos

ECDHPrivateKey

uint8_t ECDHPrivateKey[kMaxECDHPrivateKeySize]

ECDHPrivateKeyLen

uint16_t ECDHPrivateKeyLen

ECDHPublicKey

uint8_t ECDHPublicKey[kMaxECDHPublicKeySize]

EncryptionAndAuthenticationKey

uint8_t EncryptionAndAuthenticationKey[kEncryptionAndAuthenticationKeySize]

GroupKeyStore

GroupKeyStoreBase * GroupKeyStore

Puntero a un objeto de almacén de claves de grupo de plataforma.

KeyExportDelegate

WeaveKeyExportDelegate * KeyExportDelegate

Puntero a un objeto delegado de exportación clave.

Secreto compartido

uint8_t SharedSecret[kMaxECDHSharedSecretSize]

SharedSecretLen

uint16_t SharedSecretLen

Funciones publicas

Configuraciones permitidas

uint8_t AllowedConfigs() const 

GenerateKeyExportReconfigure

WEAVE_ERROR GenerateKeyExportReconfigure(
  uint8_t *buf,
  uint16_t bufSize,
  uint16_t & msgLen
)

GenerateKeyExportRequest

WEAVE_ERROR GenerateKeyExportRequest(
  uint8_t *buf,
  uint16_t bufSize,
  uint16_t & msgLen,
  uint8_t proposedConfig,
  uint32_t keyId,
  bool signMessages
)

GenerateKeyExportResponse

WEAVE_ERROR GenerateKeyExportResponse(
  uint8_t *buf,
  uint16_t bufSize,
  uint16_t & msgLen,
  const WeaveMessageInfo *msgInfo
)

En eso

void Init(
  WeaveKeyExportDelegate *keyExportDelegate,
  GroupKeyStoreBase *groupKeyStore
)

IsAllowedConfig

bool IsAllowedConfig(
  uint8_t config
) const 

IsInitiator

bool IsInitiator() const 

KeyId

uint32_t KeyId() const 

MessageInfo

const WeaveMessageInfo * MessageInfo() const 

ProcessKeyExportReconfigure

WEAVE_ERROR ProcessKeyExportReconfigure(
  const uint8_t *buf,
  uint16_t msgSize,
  uint8_t & config
)

ProcessKeyExportRequest

WEAVE_ERROR ProcessKeyExportRequest(
  const uint8_t *buf,
  uint16_t msgSize,
  const WeaveMessageInfo *msgInfo
)

ProcessKeyExportResponse

WEAVE_ERROR ProcessKeyExportResponse(
  const uint8_t *buf,
  uint16_t msgSize,
  const WeaveMessageInfo *msgInfo,
  uint8_t *exportedKeyBuf,
  uint16_t exportedKeyBufSize,
  uint16_t & exportedKeyLen,
  uint32_t & exportedKeyId
)

ProtocolConfig

uint8_t ProtocolConfig() const 

Reiniciar

void Reset(
  void
)

SetAllowedConfigs

void SetAllowedConfigs(
  uint8_t allowedConfigs
)

Cerrar

void Shutdown(
  void
)

SignMensajes

bool SignMessages() const 

Expresar

uint8_t State() const