aboutsummaryrefslogtreecommitdiff
path: root/src/daemon/session.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/daemon/session.c')
-rw-r--r--src/daemon/session.c200
1 files changed, 118 insertions, 82 deletions
diff --git a/src/daemon/session.c b/src/daemon/session.c
index fa3864ca..a719c51a 100644
--- a/src/daemon/session.c
+++ b/src/daemon/session.c
@@ -142,37 +142,65 @@ MHD_session_get_fdset(struct MHD_Session * session,
142 return MHD_YES; 142 return MHD_YES;
143} 143}
144 144
145
146
147/* FIXME: implement/fix code below this line! */
148
149
150/** 145/**
151 * This function needs to do a lot more (i.e. break up get arguments) 146 * Parse a single line of the HTTP header. Remove it
152 * but for now just seperates the prefix of the url from the document 147 * from the read buffer. If the current line does not
153 * portion. 148 * fit, consider growing the buffer. If the line is
149 * far too long, close the connection. If no line is
150 * found (incomplete, buffer too small, line too long),
151 * return NULL. Otherwise return a copy of the line.
154 */ 152 */
155static void 153static char *
156MHD_parse_URL(struct MHD_Session * session) { 154MHD_get_next_header_line(struct MHD_Session * session) {
157#if 0 155 char * rbuf;
158 char * working; 156 size_t pos;
159 int pos,i; 157 size_t start;
160 158
161 working = session->headers[0]->value; 159 start = 0;
162 160 pos = 0;
163 pos = 0; 161 rbuf = session->read_buffer;
164 for(i = 0; i < strlen(working); i++) { 162 while ( (pos < session->readLoc - 1) &&
165 if(working[i] == '/') 163 (rbuf[pos] != '\r') &&
166 pos = i+1; 164 (rbuf[pos] != '\n') )
167 } 165 pos++;
168 if(pos >= strlen(working)) 166 if (pos == session->readLoc) {
169 pos = 0; 167 /* not found, consider growing... */
170 168 if (session->readLoc == session->read_buffer_size) {
171 session->documentName = session->headers[0]->value+pos; 169 /* grow buffer to read larger header or die... */
172#endif 170 if (session->read_buffer_size < 4 * MHD_MAX_BUF_SIZE) {
171 rbuf = malloc(session->read_buffer_size * 2);
172 memcpy(rbuf,
173 session->read_buffer,
174 session->readLoc);
175 free(session->read_buffer);
176 session->read_buffer = rbuf;
177 session->read_buffer_size *= 2;
178 } else {
179 /* die, header far too long to be reasonable */
180 /* FIXME: log */
181 close(session->socket_fd);
182 session->socket_fd = -1;
183 }
184 }
185 return NULL;
186 }
187 /* found, check if we have proper CRLF */
188 rbuf = malloc(pos);
189 memcpy(rbuf,
190 session->read_buffer,
191 pos-1);
192 rbuf[pos-1] = '\0';
193 if ( (rbuf[pos] == '\r') &&
194 (rbuf[pos+1] == '\n') )
195 pos++; /* skip both r and n */
196 pos++;
197 memmove(session->read_buffer,
198 &session->read_buffer[pos],
199 session->readLoc - pos);
200 session->readLoc -= pos;
201 return rbuf;
173} 202}
174 203
175
176/** 204/**
177 * This function is designed to parse the input buffer of a given session. 205 * This function is designed to parse the input buffer of a given session.
178 * 206 *
@@ -185,62 +213,66 @@ MHD_parse_URL(struct MHD_Session * session) {
185 */ 213 */
186static void 214static void
187MHD_parse_session_headers(struct MHD_Session * session) { 215MHD_parse_session_headers(struct MHD_Session * session) {
188#if 0 216 char * line;
189 const char * crlfcrlf = "\r\n\r\n"; 217 char * colon;
190 const char * crlf = "\r\n"; 218 char * uri;
191 219 char * httpType;
192 char * saveptr; 220 struct MHD_HTTP_Header * hdr;
193 char * saveptr1;
194
195 struct MHD_HTTP_Header * newHeader;
196 char * curTok;
197 char * curTok1;
198 221
199 int numBytes; 222 if (session->bodyReceived == 1)
200 223 abort();
201 curTok = strstr(session->inbuf, crlfcrlf); 224 while (NULL != (line = MHD_get_next_header_line(session))) {
202 225 if (session->url == NULL) {
203 if(curTok == NULL) { 226 /* line must be request line */
204 return -1; 227 uri = strstr(line, " ");
205 } 228 if (uri == NULL)
206 229 goto DIE;
207 memset(curTok+2, 0, 2); 230 uri[0] = '\0';
208 231 session->method = strdup(line);
209 numBytes = strlen(session->inbuf) + 2; 232 uri++;
210 233 httpType = strstr(uri, " ");
211 curTok = strtok_r(session->inbuf, crlf, &saveptr); 234 if (httpType != NULL)
212 235 httpType[0] = '\0';
213 session->requestType = strtok_r(curTok, " ", &saveptr1); 236 session->url = strdup(uri);
214 237 /* do we want to do anything with httpType? */
215 newHeader = (struct MHD_HTTP_Header *)malloc(sizeof(struct MHD_HTTP_Header)); 238 free(line);
216 if(newHeader == NULL) { 239 continue;
217 if(session->daemon->options & MHD_USE_DEBUG) 240 }
218 fprintf(stderr, "Error allocating memory!\n"); 241 /* check if this is the end of the header */
219 return -1; 242 if (strlen(line) == 0) {
220 } 243 /* end of header */
221 newHeader->kind = MHD_GET_ARGUMENT_KIND; 244 session->headersReceived = 1;
222 newHeader->header = session->requestType; 245 /* FIXME: check with methods may have a body,
223 newHeader->value = strtok_r(NULL, " ", &saveptr1); 246 check headers to find out upload size */
224 247 session->uploadSize = 0;
225 session->headers[session->firstFreeHeader++] = newHeader; 248 session->bodyReceived = 1;
226 249 free(line);
227 curTok = strtok_r(NULL, crlf, &saveptr); 250 break;
228 while(curTok != NULL && session->firstFreeHeader < MHD_MAX_HEADERS) { 251 }
229 curTok1 = strtok_r(curTok, ":", &saveptr1); 252 /* ok, line should be normal header line, find colon */
230 newHeader = (struct MHD_HTTP_Header *)malloc(sizeof(struct MHD_HTTP_Header)); 253 colon = strstr(line, ": ");
231 if(newHeader == NULL) { 254 if (colon == NULL) {
232 if(session->daemon->options & MHD_USE_DEBUG) 255 /* error in header line, die hard */
233 fprintf(stderr, "Error allocating memory!\n"); 256 /* FIXME: log */
234 return -1; 257 goto DIE;
235 } 258 }
236 newHeader->header = curTok1; 259 /* zero-terminate header */
237 newHeader->value = curTok + strlen(curTok1) + 2; 260 colon[0] = '\0';
238 //For now, everything is a get! 261 colon += 2; /* advance to value */
239 newHeader->kind = MHD_GET_ARGUMENT_KIND; 262 hdr = malloc(sizeof(struct MHD_HTTP_Header));
240 session->headers[session->firstFreeHeader++] = newHeader; 263 hdr->next = session->headers_received;
241 curTok = strtok_r(NULL, crlf, &saveptr); 264 hdr->header = line;
242 } 265 hdr->value = strdup(colon);
243#endif 266 hdr->kind = MHD_HEADER_KIND;
267 session->headers_received = hdr;
268 }
269 if (session->bodyReceived == 0)
270 return;
271 /* FIXME: here: find cookie header and parse that! */
272 return;
273 DIE:
274 close(session->socket_fd);
275 session->socket_fd = -1;
244} 276}
245 277
246 278
@@ -463,6 +495,10 @@ MHD_session_handle_write(struct MHD_Session * session) {
463 session->headersSent = 0; 495 session->headersSent = 0;
464 session->bodyReceived = 0; 496 session->bodyReceived = 0;
465 session->messagePos = 0; 497 session->messagePos = 0;
498 free(session->method);
499 session->method = NULL;
500 free(session->url);
501 session->url = NULL;
466 free(session->write_buffer); 502 free(session->write_buffer);
467 session->write_buffer = NULL; 503 session->write_buffer = NULL;
468 session->write_buffer_size = 0; 504 session->write_buffer_size = 0;