in source/azure_iot_hub_client.c [1256:1298]
AzureIoTResult_t AzureIoTHubClient_UnsubscribeProperties( AzureIoTHubClient_t * pxAzureIoTHubClient )
{
AzureIoTMQTTSubscribeInfo_t xMqttSubscription[ 2 ] = { { 0 }, { 0 } };
AzureIoTMQTTResult_t xMQTTResult;
AzureIoTResult_t xResult;
uint16_t usSubscribePacketIdentifier;
AzureIoTHubClientReceiveContext_t * pxContext;
if( pxAzureIoTHubClient == NULL )
{
AZLogError( ( "AzureIoTHubClient_UnsubscribeProperties failed: invalid argument" ) );
xResult = eAzureIoTErrorInvalidArgument;
}
else
{
pxContext = &pxAzureIoTHubClient->_internal.xReceiveContext[ azureiothubRECEIVE_CONTEXT_INDEX_PROPERTIES ];
xMqttSubscription[ 0 ].xQoS = eAzureIoTMQTTQoS0;
xMqttSubscription[ 0 ].pcTopicFilter = ( const uint8_t * ) AZ_IOT_HUB_CLIENT_PROPERTIES_MESSAGE_SUBSCRIBE_TOPIC;
xMqttSubscription[ 0 ].usTopicFilterLength = ( uint16_t ) sizeof( AZ_IOT_HUB_CLIENT_PROPERTIES_MESSAGE_SUBSCRIBE_TOPIC ) - 1;
xMqttSubscription[ 1 ].xQoS = eAzureIoTMQTTQoS0;
xMqttSubscription[ 1 ].pcTopicFilter = ( const uint8_t * ) AZ_IOT_HUB_CLIENT_PROPERTIES_WRITABLE_UPDATES_SUBSCRIBE_TOPIC;
xMqttSubscription[ 1 ].usTopicFilterLength = ( uint16_t ) sizeof( AZ_IOT_HUB_CLIENT_PROPERTIES_WRITABLE_UPDATES_SUBSCRIBE_TOPIC ) - 1;
usSubscribePacketIdentifier = AzureIoTMQTT_GetPacketId( &( pxAzureIoTHubClient->_internal.xMQTTContext ) );
AZLogDebug( ( "Attempting to unsubscribe from MQTT topics: %s and %s",
AZ_IOT_HUB_CLIENT_PROPERTIES_MESSAGE_SUBSCRIBE_TOPIC, AZ_IOT_HUB_CLIENT_PROPERTIES_WRITABLE_UPDATES_SUBSCRIBE_TOPIC ) );
if( ( xMQTTResult = AzureIoTMQTT_Unsubscribe( &( pxAzureIoTHubClient->_internal.xMQTTContext ),
xMqttSubscription, 2,
usSubscribePacketIdentifier ) ) != eAzureIoTMQTTSuccess )
{
AZLogError( ( "Failed to unsubscribe: MQTT error=0x%08x", xMQTTResult ) );
xResult = eAzureIoTErrorUnsubscribeFailed;
}
else
{
memset( pxContext, 0, sizeof( AzureIoTHubClientReceiveContext_t ) );
xResult = eAzureIoTSuccess;
}
}
return xResult;
}