/[projects]/smsdaemon/embedded-http/embeddedhttp.cpp
ViewVC logotype

Diff of /smsdaemon/embedded-http/embeddedhttp.cpp

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 675 by torben, Tue Apr 27 20:07:12 2010 UTC revision 695 by torben, Thu Apr 29 18:18:18 2010 UTC
# Line 4  Line 4 
4  #include <stdio.h>  #include <stdio.h>
5  #include "mongoose.h"  #include "mongoose.h"
6    
7    #include "Logger.h"
8    #include "version.h"
9    #include "Common.h"
10    #include "ConfigFile.h"
11    #include <sstream>
12    #include <iomanip>
13    #include <stdlib.h>
14    
15    void show_status(struct mg_connection *conn, const struct mg_request_info *request_info, void *user_data) {
16            Common* cmn = Common::instance();
17    
18    
19            int tot_sec = time(0) - cmn->daemonStart;
20    
21            int sec = tot_sec % 60;
22            int min = (tot_sec / 60) % 60;
23            int hour = (tot_sec / 3600) %24;
24            int days = tot_sec / (3600*24);
25    
26            std::ostringstream os;
27            os << VERSION << std::endl;
28            os << SVNVERSION << std::endl;
29            os << "Status:" << std::endl;
30            os << "Recv: " << cmn->smsCounter.incomming << std::endl;
31            os << "Send: " << cmn->smsCounter.outgoing << std::endl;
32            os << "Uptime: " << days << "d, ";
33            os << std::setw(2) << std::setfill('0') << hour << ":";
34            os << std::setw(2) << min << ":" ;
35            os << std::setw(2) << sec;
36    
37            mg_printf(conn, "%s", "HTTP/1.1 200 OK\r\n");
38            mg_printf(conn, "%s", "Content-Type: text/plain\r\n\r\n");
39    
40            mg_printf(conn, "%s", os.str().c_str() );      
41    }
42    
43    void show_index(struct mg_connection *conn, const struct mg_request_info *request_info, void *user_data) {
44            mg_printf(conn, "%s", "HTTP/1.1 200 OK\r\n");
45            mg_printf(conn, "%s", "Content-Type: text/html\r\n\r\n");
46            
47            mg_printf(conn, "%s", "<html><body><h2>smsdaemon</h2>\n");
48            mg_printf(conn, "%s", "<a href='/status'>smsdaemon status</a><br>\n");
49            mg_printf(conn, "%s", "<a href='/log'>smsdaemon log</a><br>\n");
50    
51            mg_printf(conn, "%s", "</body></html>");
52    }
53    
54    static void show_404(struct mg_connection *conn, const struct mg_request_info *request_info, void *user_data)
55    {
56            mg_printf(conn, "%s", "HTTP/1.1 200 OK\r\n");
57            mg_printf(conn, "%s", "Content-Type: text/plain\r\n\r\n");
58            mg_printf(conn, "%s", "Oops. File not found! ");
59    }
60    
61    void show_log(struct mg_connection *conn, const struct mg_request_info *request_info, void *user_data) {
62            mg_printf(conn, "%s", "HTTP/1.1 200 OK\r\n");
63            mg_printf(conn, "%s", "Content-Type: text/plain\r\n\r\n");
64    
65            mg_printf(conn, "%s", Logger::getLog().c_str() );
66    }
67    
68  void EmbeddedHttp::startServer() {  void EmbeddedHttp::startServer() {
69          mg_start();          std::string portStr = Common::instance()->GetConfigfile()->GetValue("smsdaemon", "httpport");
70            int port = atoi( portStr.c_str() );
71    
72            if (port > 0) {
73                    std::ostringstream oss;
74                    oss << "Starting mongoose embedded http engine (listenin on port " << port << ")";
75                    Logger::logMessage( oss.str() );
76    
77                    oss.str(""); //empty string stream
78                    oss << port;
79    
80                    m_context = mg_start();
81                    mg_set_option(m_context, "ports", oss.str().c_str() );
82                    mg_set_option(m_context, "root", "/nosuchpatch"); //set root to non-existant path to disable normal file serving - only callbacks are now serviced
83    
84                    mg_set_uri_callback(m_context, "/", &show_index, 0);
85                    mg_set_uri_callback(m_context, "/status", &show_status, 0);
86                    mg_set_uri_callback(m_context, "/log", &show_log, 0);
87                    mg_set_error_callback(m_context, 404, show_404, NULL);
88    
89    
90            } else {
91                    Logger::logMessage( "Mongoose http disabled" );
92                    m_context = 0;
93            }
94  }  }
95    
96    
97  void EmbeddedHttp::stopServer() {  void EmbeddedHttp::stopServer() {
98            if (m_context != 0) {
99                    mg_stop(m_context);
100            }
101  }  }

Legend:
Removed from v.675  
changed lines
  Added in v.695

  ViewVC Help
Powered by ViewVC 1.1.20