-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathfbHttpResponse.h
More file actions
72 lines (62 loc) · 3.25 KB
/
fbHttpResponse.h
File metadata and controls
72 lines (62 loc) · 3.25 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
/* $Id: fbHttpResponse.h,v 1.19 2011/06/21 12:45:03 laffer1 Exp $ */
/*-
* Copyright (C) 2008 Lucas Holt. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
#ifndef FBHTTPRESPONSE_H
#define FBHTTPRESPONSE_H
#include "fbClient.h"
#include "fbThread.h"
#include "urldecode.h"
#define SERVERID "FlashBack/1.2"
using namespace std;
/**
* fbHttpResponse
* Generate and transmit the webserver response to the client.
* @author Lucas Holt
* @date March 20, 2008
*/
class fbHttpResponse: public fbThread
{
public:
fbHttpResponse(fbData* _data, fbClient * _client); /// default constructor
~fbHttpResponse(); /// default destructor
void startup(); /// Start HTTP server
void shutdown(); /// Stop HTTP server
protected:
fbData *data; /// The logging wrapper
fbClient *client; /// The client connected via socket
bool running; /// is the response thread running?
void run(); /// heavy lifting
void dynamicfoot(); /// print HTML footer for dynamic pages
void dynamichead( const char * title ); /// Print HTTP header for dynamic pages.
void internal(); /// 500 internal server error
void notfound(); /// 404 Not Found handler
void header( string name, string value );/// Create and write header for client
void status( string code, string msg ); /// write status code like 404 or 200 OK
void headdate(); /// print HTTP date header.
void sendfile( const char *filename ); /// send a file via webserver using path
const char * matchmimetype( const char *filename ); /// Determine mime type
void sanitizestr( char *str ); /// clean up encoding of GET requestion
};
#endif