nl:: Weave:: Profiles:: Security:: CertProvisioning:: WeaveCertProvEngine
#include <src/lib/profiles/security/WeaveCertProvisioning.h>
Implémente la logique de base de l'objet du protocole de provisionnement de certificat Weave.
Résumé
Constructeurs et destructeurs |
|
---|---|
WeaveCertProvEngine(void)
|
Types publics |
|
---|---|
@246{
|
énum |
EventCallback)(void *appState, EventType eventType, const InEventParam &inParam, OutEventParam &outParam)
|
typedefvoid(*
Cette fonction est le rappel d'application appelé sur les événements de l'API Certificate Provisioning Engine. |
EventType{
|
énum |
State{
|
énum |
Attributs publics |
|
---|---|
AppState
|
void *
Pointeur vers des données spécifiques à l'application.
|
Fonctions publiques |
|
---|---|
AbortCertificateProvisioning(void)
|
void
Arrête tout échange GetCertificate en cours.
|
GenerateGetCertificateRequest(PacketBuffer *msgBuf, uint8_t reqType, bool doMfrAttest)
|
Générez le message GetCertificateRequest.
|
GetBinding(void) const
|
Binding *
Renvoie un pointeur vers l'objet Binding associé à WeaveCertProvEngine.
|
GetEventCallback(void) const
|
Renvoie un pointeur vers la fonction de rappel d'événement d'API actuellement configurée sur l'objet WeaveCertProvEngine.
|
GetMfrAttestDelegate(void) const
|
Renvoie un pointeur vers l'objet délégué d'attestation du fabricant actuellement configuré sur l'objet WeaveCertProvEngine.
|
GetOpAuthDelegate(void) const
|
Renvoie un pointeur vers l'objet de délégation d'authentification opérationnelle actuellement configuré sur l'objet WeaveCertProvEngine.
|
GetReqType(void) const
|
uint8_t
Récupérez le type de requête actuel.
|
GetState(void) const
|
Récupérer l'état actuel de l'objet WeaveCertProvEngine.
|
Init(Binding *binding, WeaveNodeOpAuthDelegate *opAuthDelegate, WeaveNodeMfrAttestDelegate *mfrAttestDelegate, EventCallback eventCallback, void *appState)
|
Initialisez un objet WeaveCertProvEngine en vue de l'envoi du message de requête de certificat.
|
ProcessGetCertificateResponse(PacketBuffer *msgBuf)
|
Traiter le message GetCertificateResponse.
|
SetBinding(Binding *binding)
|
void
Définit l'objet de liaison sur l'objet WeaveCertProvEngine.
|
SetEventCallback(EventCallback eventCallback)
|
void
Définit la fonction de rappel d'événement de l'API sur l'objet WeaveCertProvEngine.
|
SetMfrAttestDelegate(WeaveNodeMfrAttestDelegate *mfrAttestDelegate)
|
void
Définit l'objet délégué d'attestation du fabricant sur l'objet WeaveCertProvEngine.
|
SetOpAuthDelegate(WeaveNodeOpAuthDelegate *opAuthDelegate)
|
void
Définit l'objet délégué d'authentification opérationnelle sur l'objet WeaveCertProvEngine.
|
Shutdown(void)
|
void
Arrêtez un objet WeaveCertProvEngine précédemment initialisé.
|
StartCertificateProvisioning(uint8_t reqType, bool doMfrAttest)
|
Démarrez le protocole de provisionnement des certificats.
|
Structs |
|
---|---|
nl:: |
Paramètres d'entrée de l'événement de l'API Weave Certificate Provisioning. |
nl:: |
Paramètres de sortie de l'événement de l'API Weave Certificate Provisioning. |
Types publics
@246
@246
Propriétés | |
---|---|
kReqType_GetInitialOpDeviceCert
|
Le type de requête "Obtenir un certificat" permet d'obtenir un certificat opérationnel initial. |
kReqType_RotateOpDeviceCert
|
Le type de demande "Get Certificate" (Obtenir un certificat) permet de faire pivoter le certificat opérationnel actuel. |
EventCallback
void(* EventCallback)(void *appState, EventType eventType, const InEventParam &inParam, OutEventParam &outParam)
Cette fonction est le rappel d'application appelé sur les événements de l'API Certificate Provisioning Engine.
Détails | |||||||||
---|---|---|---|---|---|---|---|---|---|
Paramètres |
|
EventType
EventType
Propriétés | |
---|---|
kEvent_CommunicationError
|
Une erreur de communication s'est produite lors de l'envoi d'une requête GetCertificate ou lors de l'attente d'une réponse. |
kEvent_PrepareAuthorizeInfo
|
L'application est invitée à préparer la charge utile pour la requête GetCertificateRequest. |
kEvent_ResponseReceived
|
Un message GetCertificateResponse a été reçu du pair. |
État
State
Propriétés | |
---|---|
kState_Idle
|
L'objet du moteur est inactif. |
kState_NotInitialized
|
L'objet du moteur n'est pas initialisé. |
kState_PreparingBinding
|
L'objet du moteur attend que la liaison soit prête. |
kState_RequestInProgress
|
Un message GetCertificateRequest a été envoyé et l'objet du moteur attend une réponse. |
Attributs publics
AppState
void * AppState
Pointeur vers des données spécifiques à l'application.
Fonctions publiques
AbortCertificateProvisioning
void AbortCertificateProvisioning( void )
Arrête tout échange GetCertificate en cours.
GenerateGetCertificateRequest
WEAVE_ERROR GenerateGetCertificateRequest( PacketBuffer *msgBuf, uint8_t reqType, bool doMfrAttest )
Générez le message GetCertificateRequest.
Cette méthode génère la structure Weave GetCertificateRequest encodée au format TLV Weave.
Lors de la création du message GetCertificateRequest, la méthode envoie une requête à l'application, via les fonctions WeaveNodeOpAuthDelegate et WeaveNodeMfrAttestDelegate et l'événement API PrepareAuthorizeInfo, pour préparer la charge utile du message.
Détails | |||||||
---|---|---|---|---|---|---|---|
Paramètres |
|
||||||
Valeurs renvoyées |
|
GetBinding
Binding * GetBinding( void ) const
Renvoie un pointeur vers l'objet Binding associé à WeaveCertProvEngine.
GetEventCallback
EventCallback GetEventCallback( void ) const
Renvoie un pointeur vers la fonction de rappel d'événement de l'API actuellement configurée sur l'objet WeaveCertProvEngine.
GetMfrAttestDelegate
WeaveNodeMfrAttestDelegate * GetMfrAttestDelegate( void ) const
Renvoie un pointeur vers l'objet délégué d'attestation du fabricant actuellement configuré sur l'objet WeaveCertProvEngine.
GetOpAuthDelegate
WeaveNodeOpAuthDelegate * GetOpAuthDelegate( void ) const
Renvoie un pointeur vers l'objet délégué d'authentification opérationnelle actuellement configuré sur l'objet WeaveCertProvEngine.
GetReqType
uint8_t GetReqType( void ) const
Récupérez le type de requête actuel.
Init
WEAVE_ERROR Init( Binding *binding, WeaveNodeOpAuthDelegate *opAuthDelegate, WeaveNodeMfrAttestDelegate *mfrAttestDelegate, EventCallback eventCallback, void *appState )
Initialisez un objet WeaveCertProvEngine en vue de l'envoi du message de requête de certificat.
Détails | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Paramètres |
|
ProcessGetCertificateResponse
WEAVE_ERROR ProcessGetCertificateResponse( PacketBuffer *msgBuf )
Traiter le message GetCertificateResponse.
Cette méthode traite la structure Weave GetCertificateResponse encodée au format TLV Weave.
Une fois le traitement du message GetCertificateResponse terminé, la méthode appelle l'application via l'événement API ResponseReceived pour fournir le résultat.
Si le traitement du message GetCertificateResponse échoue, la méthode appelle l'application via l'événement de l'API CommunicationError pour signaler l'erreur.
Détails | |||
---|---|---|---|
Paramètres |
|
||
Valeurs renvoyées |
|
SetBinding
void SetBinding( Binding *binding )
Définit l'objet de liaison sur l'objet WeaveCertProvEngine.
SetEventCallback
void SetEventCallback( EventCallback eventCallback )
Définit la fonction de rappel d'événement d'API sur l'objet WeaveCertProvEngine.
SetMfrAttestDelegate
void SetMfrAttestDelegate( WeaveNodeMfrAttestDelegate *mfrAttestDelegate )
Définit l'objet délégué d'attestation du fabricant sur l'objet WeaveCertProvEngine.
SetOpAuthDelegate
void SetOpAuthDelegate( WeaveNodeOpAuthDelegate *opAuthDelegate )
Définit l'objet délégué d'authentification opérationnelle sur l'objet WeaveCertProvEngine.
Arrêt
void Shutdown( void )
Arrêtez un objet WeaveCertProvEngine précédemment initialisé.
Notez que cette méthode ne peut être appelée que si la méthode Init() a déjà été appelée.
StartCertificateProvisioning
WEAVE_ERROR StartCertificateProvisioning( uint8_t reqType, bool doMfrAttest )
Démarrez le protocole de provisionnement de certificat.
Cette méthode lance le processus d'envoi d'un message GetCertificateRequest au service CA. Si le message GetCertificateResponse correspondant est reçu, il est transmis à l'application via l'événement d'API ResponseReceived.
Si l'objet Binding n'est pas dans l'état "Prêt" lorsque cette méthode est appelée, une requête est envoyée à la méthode Binding::RequestPrepare() pour lancer la préparation à la demande. L'opération de requête attend alors la fin de ce processus. Tout appel à StartCertificateProvisioning() lors d'une requête précédente en cours est ignoré.
Détails | |||||
---|---|---|---|---|---|
Paramètres |
|
||||
Valeurs renvoyées |
|
WeaveCertProvEngine
WeaveCertProvEngine( void )