
An example HTTP Server using new Ethernet Interface and localfilesystem.
Dependencies: EthernetInterface HttpServer mbed-rpc mbed-rtos mbed
Fork of giken9_HTMLServer_Sample by
Diff: HttpServer/Handler/RPCHandler.cpp
- Revision:
- 4:28e8af6595f7
- Parent:
- 3:f0c16cc3a4ef
- Child:
- 5:d98cf6df5187
--- a/HttpServer/Handler/RPCHandler.cpp Tue Dec 23 18:40:55 2014 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,140 +0,0 @@ -/* -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -THE SOFTWARE. -*/ - -//#define _DEBUG_RPC_HANDLER - -#include "RPCHandler.h" -#include "mbed_rpc.h" - -#define RPC_DATA_LEN 64 - -RPCHandler::RPCHandler(const char* rootPath, const char* path, TCPSocketConnection* pTCPSocketConnection) : HTTPRequestHandler(rootPath, path, pTCPSocketConnection) -{} - -RPCHandler::~RPCHandler() -{ -#ifdef _DEBUG_RPC_HANDLER - printf("++++(RPC Handler)Handler destroyed\r\n"); -#endif -} - -void RPCHandler::doGet() -{ -#ifdef _DEBUG_RPC_HANDLER - printf("++++(RPC Handler)doGet\r\n"); -#endif - char resp[RPC_DATA_LEN] = {0}; - char req[RPC_DATA_LEN] = {0}; - -#ifdef _DEBUG_RPC_HANDLER - printf("++++(RPC Handler)Path : %s\r\n", path().c_str()); - printf("++++(RPC Handler)Root Path : %s\r\n", rootPath().c_str()); -#endif - //Remove path - strncpy(req, path().c_str(), RPC_DATA_LEN-1); -#ifdef _DEBUG_RPC_HANDLER - printf("++++(RPC Handler)RPC req(before) : %s\r\n", req); -#endif - //Remove "%20", "+", "," from req - cleanReq(req); -#ifdef _DEBUG_RPC_HANDLER - printf("++++(RPC Handler)RPC req(after) : %s\r\n", req); -#endif - //Do RPC Call - RPC::call(req, resp); //FIXME: Use bool result -#ifdef _DEBUG_RPC_HANDLER - printf("++++(RPC Handler)Response %s \r\n",resp); -#endif - //Response - setContentLen( strlen(resp) ); - - //Make sure that the browser won't cache this request -// respHeaders()["Cache-control"]="no-cache;no-store"; -// respHeaders()["Pragma"]="no-cache"; -// respHeaders()["Expires"]="0"; - addRespHeaders("Cache-control","no-cache;no-store"); - addRespHeaders("Pragma","no-cache"); - addRespHeaders("Expires","0"); - - //Write data -// respHeaders()["Connection"] = "close"; - addRespHeaders("Connection", "close"); - writeData(resp, strlen(resp)); -#ifdef _DEBUG_RPC_HANDLER - printf("++++(RPC Handler)Exit RPCHandler::doGet()\r\n"); -#endif -} - -void RPCHandler::doPost() -{ - -} - -void RPCHandler::doHead() -{ - -} - - -void RPCHandler::onReadable() //Data has been read -{ - -} - -void RPCHandler::onWriteable() //Data has been written & buf is free -{ -#ifdef _DEBUG_RPC_HANDLER - printf("++++(RPC Handler)onWriteable event\r\n"); -#endif - // close(); //Data written, we can close the connection -} - -void RPCHandler::onClose() //Connection is closing -{ - //Nothing to do -} - -void RPCHandler::cleanReq(char* data) -{ - char* p; - if((p = strstr(data, "+"))!=NULL)memset((void*) p, ' ', 1); - else if((p = strstr(data, ","))!=NULL)memset((void*) p, ' ', 1); - else if((p = strstr(data, "%20"))!=NULL) { - memset((void*) p, ' ', 1); - while(*(p+2)!=NULL) { - p++; - memset((void*) p,*(p+2),1); - } - } - - if((p = strstr(data, "+"))!=NULL)memset((void*) p, ' ', 1); - else if((p = strstr(data, ","))!=NULL)memset((void*) p, ' ', 1); - else if((p = strstr(data, "%20"))!=NULL) { - memset((void*) p, ' ', 1); - while(*(p+2)!=NULL) { - p++; - memset((void*) p,*(p+2),1); - } - } -} - - - -