nl::Weave::WeaveServerDelegateBase

#include <src/lib/core/WeaveServerBase.h>

Una clase base común para implementar objetos delegados del servidor de Weave.

Resumen

Herencia

Subclases conocidas directas:
  nl::Weave::Profiles::DeviceControl::DeviceControlDelegate
  nl::Weave::Profiles::FabricProvisioning::FabricProvisioningDelegate
  nl::Weave::Profiles::NetworkProvisioning::NetworkProvisioningDelegate
  nl::Weave::Profiles::ServiceProvisioning::ServiceProvisioningDelegate
  nl::Weave::Profiles::TokenPairing::TokenPairingDelegate
  nl::Weave::Profiles::Vendor::Nestlabs::DropcamLegacyPairing::DropcamLegacyPairingDelegate

Tipos protegidos

@69{
  kAccessControlResult_NotDetermined = 0,
  kAccessControlResult_Accepted = 1,
  kAccessControlResult_Rejected = 2,
  kAccessControlResult_Rejected_RespSent = 3,
  kAccessControlResult_Rejected_Silent = 4
}
enum
AccessControlResult typedef
uint8_t

Funciones protegidas

EnforceAccessControl(ExchangeContext *ec, uint32_t msgProfileId, uint8_t msgType, const WeaveMessageInfo *msgInfo, AccessControlResult & result)
virtual void
Método virtual para determinar la política de control de acceso a nivel de mensaje para mensajes de solicitudes entrantes del servidor.
WeaveServerDelegateBase(void)

Tipos protegidos

@69

 @69

AccessControlResult

uint8_t AccessControlResult

Funciones protegidas

EnforceAccessControl

virtual void EnforceAccessControl(
  ExchangeContext *ec,
  uint32_t msgProfileId,
  uint8_t msgType,
  const WeaveMessageInfo *msgInfo,
  AccessControlResult & result
)

Método virtual para determinar la política de control de acceso a nivel de mensaje para mensajes de solicitudes entrantes del servidor.

La infraestructura del servidor de Weave llama a este método para determinar si un mensaje de solicitud entrante se debe aceptar y procesar con normalidad o rechazarse. Las clases de delegación asociadas con implementaciones de servidores de Weave deben anular este método para implementar políticas de control de acceso adecuadas para sus protocolos. Las aplicaciones pueden anular aún más este método para admitir políticas personalizadas más allá de las que proporcionan las implementaciones de servidor estándar.

Se espera que las implementaciones de este método devuelvan el valor de Aceptado o Rechazado según el resultado de la evaluación de la política de control de acceso. Mostrar un resultado de Rechazado hace que se envíe un StatusReport al solicitante con el estado Common/AccessDenied. Como alternativa, las implementaciones de métodos pueden optar por enviar sus propias respuestas, que pueden ser un StatusReport o cualquier otro tipo de mensaje. En este caso, el método debe devolver un resultado de Rechazar_RespSent para indicar que ya se envió una respuesta. Por último, las implementaciones pueden mostrar Deny_Silent para indicar que se debe rechazar la solicitud sin enviar una respuesta al solicitante.

Las clases que anulan el método EnforceAccessControl() son necesarias en los casos de llamada para llamar al método con nombre similar en su clase superior inmediata, ya sea la clase WeaveServerDelegateBase o una clase derivada de esa clase. Los métodos de anulación deben actualizar primero el valor del resultado con su determinación de la política de control de acceso y, luego, llamar a su clase base para tomar su determinación.

Detalles
Parámetros
[in] ec
El ExchangeContext a través del cual se recibió el mensaje.
[in] msgProfileId
El ID de perfil del mensaje recibido.
[in] msgType
El tipo de mensaje del mensaje recibido.
[in] msgInfo
Una estructura WeaveMessageInfo que contiene información sobre el mensaje recibido.
[in,out] result
Un valor enumerado que describe el resultado de la evaluación de la política de control de acceso para el mensaje recibido. Al ingresar al método, el valor representa el resultado tentativo en el punto actual del proceso de evaluación. Tras regresar, se espera que el resultado represente la evaluación final de la política de control de acceso del mensaje.

WeaveServerDelegateBase

 WeaveServerDelegateBase(
  void
)