HttpServer Library for "mbed-os" which added a snapshot handler.

Dependents:   GR-PEACH-webcam GR-Boards_WebCamera GR-Boards_WebCamera GR-Boards_WebCamera

Fork of HttpServer_snapshot by Renesas

Committer:
yueee_yt
Date:
Sat Feb 22 05:51:59 2014 +0000
Revision:
5:b8f6a11c70db
Parent:
4:1b6b021ee21d
Child:
8:a9fb8fe9b8a3
BugFix(RPCHandler)

Who changed what in which revision?

UserRevisionLine numberNew contents of line
yueee_yt 0:fdf9c2c5200f 1 /*
yueee_yt 0:fdf9c2c5200f 2 Permission is hereby granted, free of charge, to any person obtaining a copy
yueee_yt 0:fdf9c2c5200f 3 of this software and associated documentation files (the "Software"), to deal
yueee_yt 0:fdf9c2c5200f 4 in the Software without restriction, including without limitation the rights
yueee_yt 0:fdf9c2c5200f 5 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
yueee_yt 0:fdf9c2c5200f 6 copies of the Software, and to permit persons to whom the Software is
yueee_yt 0:fdf9c2c5200f 7 furnished to do so, subject to the following conditions:
yueee_yt 4:1b6b021ee21d 8
yueee_yt 0:fdf9c2c5200f 9 The above copyright notice and this permission notice shall be included in
yueee_yt 0:fdf9c2c5200f 10 all copies or substantial portions of the Software.
yueee_yt 4:1b6b021ee21d 11
yueee_yt 0:fdf9c2c5200f 12 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
yueee_yt 0:fdf9c2c5200f 13 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
yueee_yt 0:fdf9c2c5200f 14 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
yueee_yt 0:fdf9c2c5200f 15 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
yueee_yt 0:fdf9c2c5200f 16 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
yueee_yt 0:fdf9c2c5200f 17 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
yueee_yt 0:fdf9c2c5200f 18 THE SOFTWARE.
yueee_yt 0:fdf9c2c5200f 19 */
yueee_yt 5:b8f6a11c70db 20 //#define _DEBUG_FS_HANDLER
yueee_yt 0:fdf9c2c5200f 21
yueee_yt 0:fdf9c2c5200f 22 #include "FSHandler.h"
yueee_yt 0:fdf9c2c5200f 23
yueee_yt 0:fdf9c2c5200f 24 #define CHUNK_SIZE 128
yueee_yt 0:fdf9c2c5200f 25
yueee_yt 0:fdf9c2c5200f 26 #define DEFAULT_PAGE "/index.htm"
yueee_yt 0:fdf9c2c5200f 27
yueee_yt 0:fdf9c2c5200f 28 //*FSHandler::FSHandler(const char* rootPath, const char* path, TCPSocket* pTCPSocket) : HTTPRequestHandler(rootPath, path, pTCPSocket), m_err404(false)
yueee_yt 0:fdf9c2c5200f 29 FSHandler::FSHandler(const char* rootPath, const char* path, TCPSocketConnection* pTCPSocketConnection) : HTTPRequestHandler(rootPath, path, pTCPSocketConnection), m_err404(false)
yueee_yt 0:fdf9c2c5200f 30 {}
yueee_yt 0:fdf9c2c5200f 31
yueee_yt 0:fdf9c2c5200f 32 FSHandler::~FSHandler()
yueee_yt 0:fdf9c2c5200f 33 {
yueee_yt 5:b8f6a11c70db 34 #ifdef _DEBUG_FS_HANDLER
yueee_yt 5:b8f6a11c70db 35 printf("\r\n+++FSHandler destroy\r\n");
yueee_yt 5:b8f6a11c70db 36 #endif
yueee_yt 5:b8f6a11c70db 37 if(m_fp){
yueee_yt 5:b8f6a11c70db 38 #ifdef _DEBUG_FS_HANDLER
yueee_yt 5:b8f6a11c70db 39 printf("\r\n+++FSHandler fclose start\r\n");
yueee_yt 5:b8f6a11c70db 40 #endif
yueee_yt 4:1b6b021ee21d 41 fclose(m_fp);
yueee_yt 4:1b6b021ee21d 42 #ifdef _DEBUG_FS_HANDLER
yueee_yt 5:b8f6a11c70db 43 printf("\r\n+++FSHandler fclose end\r\n");
yueee_yt 5:b8f6a11c70db 44 #endif
yueee_yt 5:b8f6a11c70db 45
yueee_yt 5:b8f6a11c70db 46 }
yueee_yt 5:b8f6a11c70db 47 #ifdef _DEBUG_FS_HANDLER
yueee_yt 4:1b6b021ee21d 48 printf("\r\nHandler destroyed\r\n");
yueee_yt 4:1b6b021ee21d 49 #endif
yueee_yt 0:fdf9c2c5200f 50 }
yueee_yt 0:fdf9c2c5200f 51
yueee_yt 0:fdf9c2c5200f 52 //static init
yueee_yt 0:fdf9c2c5200f 53 map<string,string> FSHandler::m_lFsPath = map<string,string>();
yueee_yt 0:fdf9c2c5200f 54
yueee_yt 0:fdf9c2c5200f 55 void FSHandler::mount(const string& fsPath, const string& rootPath)
yueee_yt 0:fdf9c2c5200f 56 {
yueee_yt 4:1b6b021ee21d 57 m_lFsPath[rootPath]=fsPath;
yueee_yt 0:fdf9c2c5200f 58 }
yueee_yt 0:fdf9c2c5200f 59
yueee_yt 0:fdf9c2c5200f 60 void FSHandler::doGet()
yueee_yt 0:fdf9c2c5200f 61 {
yueee_yt 4:1b6b021ee21d 62 #ifdef _DEBUG_FS_HANDLER
yueee_yt 4:1b6b021ee21d 63 printf("\r\nIn FSHandler::doGet() - rootPath=%s, path=%s\r\n", rootPath().c_str(), path().c_str());
yueee_yt 4:1b6b021ee21d 64 #endif
yueee_yt 4:1b6b021ee21d 65 //FIXME: Translate path to local/path
yueee_yt 4:1b6b021ee21d 66 string checkedRootPath = rootPath();
yueee_yt 4:1b6b021ee21d 67 if(checkedRootPath.empty())
yueee_yt 4:1b6b021ee21d 68 checkedRootPath="/";
yueee_yt 4:1b6b021ee21d 69 string filePath = m_lFsPath[checkedRootPath];
yueee_yt 4:1b6b021ee21d 70 if (path().size() > 1) {
yueee_yt 4:1b6b021ee21d 71 filePath += path();
yueee_yt 4:1b6b021ee21d 72 } else {
yueee_yt 4:1b6b021ee21d 73 filePath += DEFAULT_PAGE;
yueee_yt 4:1b6b021ee21d 74 }
yueee_yt 4:1b6b021ee21d 75 #ifdef _DEBUG_FS_HANDLER
yueee_yt 4:1b6b021ee21d 76 printf("Trying to open %s\n", filePath.c_str());
yueee_yt 4:1b6b021ee21d 77 #endif
yueee_yt 4:1b6b021ee21d 78 m_fp = fopen(filePath.c_str(), "r"); //FIXME: if null, error 404
yueee_yt 0:fdf9c2c5200f 79
yueee_yt 4:1b6b021ee21d 80 if(!m_fp) {
yueee_yt 4:1b6b021ee21d 81 m_err404 = true;
yueee_yt 4:1b6b021ee21d 82 setErrCode(404);
yueee_yt 4:1b6b021ee21d 83 const char* msg = "File not found.";
yueee_yt 4:1b6b021ee21d 84 setContentLen(strlen(msg));
yueee_yt 4:1b6b021ee21d 85 respHeaders()["Content-Type"] = "text/html";
yueee_yt 4:1b6b021ee21d 86 respHeaders()["Connection"] = "close";
yueee_yt 4:1b6b021ee21d 87 writeData(msg,strlen(msg)); //Only send header
yueee_yt 4:1b6b021ee21d 88 printf("\r\nExit FSHandler::doGet() w Error 404\r\n");
yueee_yt 4:1b6b021ee21d 89 return;
yueee_yt 4:1b6b021ee21d 90 }
yueee_yt 4:1b6b021ee21d 91
yueee_yt 4:1b6b021ee21d 92 //Seek EOF to get length
yueee_yt 4:1b6b021ee21d 93 fseek(m_fp, 0, SEEK_END);
yueee_yt 4:1b6b021ee21d 94 setContentLen( ftell(m_fp) );
yueee_yt 4:1b6b021ee21d 95 fseek(m_fp, 0, SEEK_SET); //Goto SOF
yueee_yt 4:1b6b021ee21d 96
yueee_yt 0:fdf9c2c5200f 97 respHeaders()["Connection"] = "close";
yueee_yt 4:1b6b021ee21d 98 onWriteable();
yueee_yt 4:1b6b021ee21d 99 #ifdef _DEBUG_FS_HANDLER
yueee_yt 4:1b6b021ee21d 100 printf("\r\nExit SimpleHandler::doGet()\r\n");
yueee_yt 4:1b6b021ee21d 101 #endif
yueee_yt 0:fdf9c2c5200f 102 }
yueee_yt 0:fdf9c2c5200f 103
yueee_yt 0:fdf9c2c5200f 104 void FSHandler::doPost()
yueee_yt 0:fdf9c2c5200f 105 {
yueee_yt 0:fdf9c2c5200f 106
yueee_yt 0:fdf9c2c5200f 107 }
yueee_yt 0:fdf9c2c5200f 108
yueee_yt 0:fdf9c2c5200f 109 void FSHandler::doHead()
yueee_yt 0:fdf9c2c5200f 110 {
yueee_yt 0:fdf9c2c5200f 111
yueee_yt 0:fdf9c2c5200f 112 }
yueee_yt 0:fdf9c2c5200f 113
yueee_yt 0:fdf9c2c5200f 114 void FSHandler::onReadable() //Data has been read
yueee_yt 0:fdf9c2c5200f 115 {
yueee_yt 0:fdf9c2c5200f 116
yueee_yt 0:fdf9c2c5200f 117 }
yueee_yt 0:fdf9c2c5200f 118
yueee_yt 0:fdf9c2c5200f 119 void FSHandler::onWriteable() //Data has been written & buf is free
yueee_yt 0:fdf9c2c5200f 120 {
yueee_yt 4:1b6b021ee21d 121 #ifdef _DEBUG_FS_HANDLER
yueee_yt 4:1b6b021ee21d 122 printf("\r\nFSHandler::onWriteable() event\r\n");
yueee_yt 4:1b6b021ee21d 123 #endif
yueee_yt 4:1b6b021ee21d 124 if(m_err404) {
yueee_yt 4:1b6b021ee21d 125 //Error has been served, now exit
yueee_yt 4:1b6b021ee21d 126 close();
yueee_yt 4:1b6b021ee21d 127 return;
yueee_yt 4:1b6b021ee21d 128 }
yueee_yt 4:1b6b021ee21d 129
yueee_yt 4:1b6b021ee21d 130 static char rBuf[CHUNK_SIZE];
yueee_yt 4:1b6b021ee21d 131 while(true) {
yueee_yt 4:1b6b021ee21d 132 int len = fread(rBuf, 1, CHUNK_SIZE, m_fp);
yueee_yt 4:1b6b021ee21d 133 if(len>0) {
yueee_yt 4:1b6b021ee21d 134 int writtenLen = writeData(rBuf, len);
yueee_yt 4:1b6b021ee21d 135 if(writtenLen < 0) { //Socket error
yueee_yt 4:1b6b021ee21d 136 #ifdef _DEBUG_FS_HANDLER
yueee_yt 4:1b6b021ee21d 137 printf("FSHandler: Socket error %d\n", writtenLen);
yueee_yt 4:1b6b021ee21d 138 #endif
yueee_yt 5:b8f6a11c70db 139 /** Not Work
yueee_yt 5:b8f6a11c70db 140 if(writtenLen == TCPSOCKET_MEM) {
yueee_yt 5:b8f6a11c70db 141 fseek(m_fp, -len, SEEK_CUR);
yueee_yt 5:b8f6a11c70db 142 return; //Wait for the queued TCP segments to be transmitted
yueee_yt 5:b8f6a11c70db 143 } else {
yueee_yt 5:b8f6a11c70db 144 //This is a critical error
yueee_yt 5:b8f6a11c70db 145 **/
yueee_yt 5:b8f6a11c70db 146 close();
yueee_yt 5:b8f6a11c70db 147 return;
yueee_yt 5:b8f6a11c70db 148 /**
yueee_yt 5:b8f6a11c70db 149 }
yueee_yt 5:b8f6a11c70db 150 **/
yueee_yt 4:1b6b021ee21d 151 } else if(writtenLen < len) { //Short write, socket's buffer is full
yueee_yt 4:1b6b021ee21d 152 fseek(m_fp, writtenLen - len, SEEK_CUR);
yueee_yt 4:1b6b021ee21d 153 return;
yueee_yt 4:1b6b021ee21d 154 }
yueee_yt 4:1b6b021ee21d 155 } else {
yueee_yt 4:1b6b021ee21d 156 close(); //Data written, we can close the connection
yueee_yt 4:1b6b021ee21d 157 return;
yueee_yt 0:fdf9c2c5200f 158 }
yueee_yt 0:fdf9c2c5200f 159 }
yueee_yt 0:fdf9c2c5200f 160 }
yueee_yt 0:fdf9c2c5200f 161
yueee_yt 0:fdf9c2c5200f 162 void FSHandler::onClose() //Connection is closing
yueee_yt 0:fdf9c2c5200f 163 {
yueee_yt 5:b8f6a11c70db 164 /**
yueee_yt 5:b8f6a11c70db 165 #ifdef _DEBUG_FS_HANDLER
yueee_yt 5:b8f6a11c70db 166 printf("FSHandler: onClose start \r\n");
yueee_yt 5:b8f6a11c70db 167 #endif
yueee_yt 5:b8f6a11c70db 168 if(m_fp){
yueee_yt 5:b8f6a11c70db 169 #ifdef _DEBUG_FS_HANDLER
yueee_yt 5:b8f6a11c70db 170 printf("FSHandler: fclose start \r\n");
yueee_yt 5:b8f6a11c70db 171 #endif
yueee_yt 5:b8f6a11c70db 172 fclose(m_fp);
yueee_yt 5:b8f6a11c70db 173 #ifdef _DEBUG_FS_HANDLER
yueee_yt 5:b8f6a11c70db 174 printf("FSHandler: fclose end \r\n");
yueee_yt 5:b8f6a11c70db 175 #endif
yueee_yt 0:fdf9c2c5200f 176 }
yueee_yt 5:b8f6a11c70db 177 #ifdef _DEBUG_FS_HANDLER
yueee_yt 5:b8f6a11c70db 178 printf("FSHandler: onClose end \r\n");
yueee_yt 5:b8f6a11c70db 179 #endif
yueee_yt 5:b8f6a11c70db 180 **/
yueee_yt 5:b8f6a11c70db 181 }