Coap Client and Server
Dependencies: DebugLib EthernetInterface cantcoap mbed-rtos
Fork of yeswecancoap by
YesWeCanCoap
Is a small coap client and server library for mbed based on the cantcoap library.
Import librarycantcoap
This is CoAP library with a focus on simplicity. It offers minimal CoAP PDU construction and decoding to and from byte buffers.
yeswecancoap server enables easy implementation of coap resources, each with a dedicated function. When the function is registered by the server, it will do the rest.
Coap server example
Repository: YesWeCanCoap-example
Coap client example
under construction
Diff: server.cpp
- Revision:
- 4:34a62b7cb2f9
- Parent:
- 3:e03960f91763
- Child:
- 5:1924c60356d0
diff -r e03960f91763 -r 34a62b7cb2f9 server.cpp --- a/server.cpp Tue Oct 20 20:57:45 2015 +0000 +++ b/server.cpp Wed Oct 21 08:10:12 2015 +0000 @@ -13,7 +13,7 @@ server.bind(5683); } -void Server::add(char* uri, void (*fnc)(CoapPDU*, CoapPDU*), Method method) +void Server::add(char* uri, void (*fnc)(CoapPDU*, Response*), Method method) { Resource res = {uri, fnc, method}; resources.push_back(res); @@ -22,23 +22,21 @@ void Server::waitForRequest() { - char buffer[256]; + char buffer[UDP_BUFFER_SIZE]; printf("\r\nWaiting for UDP packet...\r\n"); int size = server.receiveFrom(client, buffer, sizeof(buffer)); buffer[size] = '\0'; - char uriBuffer[32]; - int recvURILen; - int msgId; - uint8_t token[20]; - int tokenLength; + char uriBuffer[URI_BUFFER_SIZE]; + int uriLength; + uint8_t token[TOKEN_BUFFER_SIZE]; + uint8_t tokenLength; CoapPDU *recvPDU = new CoapPDU((uint8_t*)buffer,256, size); if(recvPDU->validate()) { recvPDU->printHuman(); - recvPDU->getURI(uriBuffer,32,&recvURILen); - msgId = recvPDU->getMessageID(); + recvPDU->getURI(uriBuffer,URI_BUFFER_SIZE,&uriLength); tokenLength = recvPDU->getTokenLength(); memcpy(token, recvPDU->getTokenPointer(), tokenLength); } @@ -47,16 +45,16 @@ for(int i = 0; i < resources.size(); i++){ if(strcmp(uriBuffer, resources[i].uri) == 0){ - CoapPDU *pdu = new CoapPDU(); - pdu->setType(CoapPDU::COAP_ACKNOWLEDGEMENT); - pdu->setCode(CoapPDU::COAP_CONTENT); - pdu->setMessageID(msgId); - pdu->setToken(token,4); + Response *res = new Response(); + res->setType(Response::COAP_ACKNOWLEDGEMENT); + res->setCode(Response::COAP_CONTENT); + res->setMessageID(recvPDU->getMessageID()); + res->setToken(token,4); - resources[i].function(recvPDU, pdu); + resources[i].function(recvPDU, res); - server.sendTo(client, (char*) pdu->getPDUPointer(),pdu->getPDULength()); - delete pdu; + server.sendTo(client, (char*) res->getPDUPointer(),res->getPDULength()); + delete res; } }