Skip to content

Commit

Permalink
Merge pull request #7 from Koushik4082/develop
Browse files Browse the repository at this point in the history
Adding API to add token to empty message
  • Loading branch information
dthaler authored Jun 4, 2018
2 parents f4d20bc + bd60461 commit fa8b2b9
Show file tree
Hide file tree
Showing 2 changed files with 67 additions and 0 deletions.
10 changes: 10 additions & 0 deletions include/coap/pdu.h
Original file line number Diff line number Diff line change
Expand Up @@ -612,6 +612,16 @@ int coap_add_token(coap_pdu_t *pdu,
int coap_add_token2(coap_pdu_t *pdu, size_t len, const unsigned char *data,
coap_transport_t transport);

/**
* @param pdu The pdu pointer.
* @param len The length of the new token.
* @param data The token to add.
* @param transport The transport type.
* @return A value greater than zero on success, or @c 0 on error.
*/
int coap_add_token_to_empty_message(coap_pdu_t *pdu, size_t len, const unsigned char *data,
coap_transport_t transport);

/**
* Get token from coap header
*
Expand Down
57 changes: 57 additions & 0 deletions src/pdu.c
Original file line number Diff line number Diff line change
Expand Up @@ -598,6 +598,63 @@ coap_add_token2(coap_pdu_t *pdu, size_t len, const unsigned char *data,
return 1;
}

int coap_add_token_to_empty_message(coap_pdu_t *pdu, size_t len, const unsigned char *data,
coap_transport_t transport)
{
const size_t HEADERLENGTH = len;
/* must allow for pdu == NULL as callers may rely on this */
if (!pdu || len > 8)
return 0;

unsigned char* token = NULL;
switch(transport)
{
case COAP_UDP:
pdu->transport_hdr->udp.token_length = len;
token = pdu->transport_hdr->udp.token;
pdu->length = HEADERLENGTH;
break;
#ifdef WITH_TCP
case COAP_TCP:
pdu->transport_hdr->tcp.header_data[0] =
pdu->transport_hdr->tcp.header_data[0] | len;
token = pdu->transport_hdr->tcp.token;
pdu->length = len + COAP_TCP_HEADER_NO_FIELD;
break;
case COAP_TCP_8BIT:
pdu->transport_hdr->tcp_8bit.header_data[0] =
pdu->transport_hdr->tcp_8bit.header_data[0] | len;
token = pdu->transport_hdr->tcp_8bit.token;
pdu->length = len + COAP_TCP_HEADER_8_BIT;
break;
case COAP_TCP_16BIT:
pdu->transport_hdr->tcp_16bit.header_data[0] =
pdu->transport_hdr->tcp_16bit.header_data[0] | len;
token = pdu->transport_hdr->tcp_16bit.token;
pdu->length = len + COAP_TCP_HEADER_16_BIT;
break;
case COAP_TCP_32BIT:
pdu->transport_hdr->tcp_32bit.header_data[0] =
pdu->transport_hdr->tcp_32bit.header_data[0] | len;
token = pdu->transport_hdr->tcp_32bit.token;
pdu->length = len + COAP_TCP_HEADER_32_BIT;
break;
#endif
default:
debug("it has wrong type\n");
}

if (len)
{
memcpy(token, data, len);
}

pdu->max_delta = 0;
pdu->data = NULL;

return 1;
}

void
coap_get_token(const coap_hdr_t *pdu_hdr,
unsigned char **token, unsigned int *token_length) {
Expand Down

0 comments on commit fa8b2b9

Please sign in to comment.