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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 683 - (hide annotations) (download)
Wed Apr 28 08:51:24 2010 UTC (14 years, 1 month ago) by torben
File size: 2215 byte(s)
pretty print of uptime
1 torben 675
2     #include "embeddedhttp.h"
3    
4     #include <stdio.h>
5     #include "mongoose.h"
6    
7 torben 676 #include "Logger.h"
8     #include "version.h"
9     #include "Common.h"
10 torben 680 #include "ConfigFile.h"
11 torben 676 #include <sstream>
12 torben 683 #include <iomanip>
13 torben 680 #include <stdlib.h>
14 torben 676
15     void show_secret(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 torben 683 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 torben 676
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 torben 679 mg_printf(conn, "%s", os.str().c_str() );
41     }
42 torben 676
43 torben 679 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 torben 676
47 torben 679 mg_printf(conn, "%s", "<html><body><h2>smsdaemon</h2>\n");
48     mg_printf(conn, "%s", "<a href='/status'>smsdaemon status</a>\n");
49     mg_printf(conn, "%s", "</body></html>");
50 torben 676 }
51    
52 torben 675 void EmbeddedHttp::startServer() {
53 torben 680 std::string portStr = Common::instance()->GetConfigfile()->GetValue("smsdaemon", "httpport");
54     int port = atoi( portStr.c_str() );
55 torben 676
56 torben 680 if (port > 0) {
57     std::ostringstream oss;
58     oss << "Starting mongoose embedded http engine (listenin on port " << port << ")";
59     Logger::logMessage( oss.str() );
60 torben 676
61 torben 680 oss.str(""); //empty string stream
62     oss << port;
63    
64     m_context = mg_start();
65     mg_set_option(m_context, "ports", oss.str().c_str() );
66     mg_set_uri_callback(m_context, "/", &show_index, 0);
67     mg_set_uri_callback(m_context, "/status", &show_secret, 0);
68     } else {
69     Logger::logMessage( "Mongoose http disabled" );
70     m_context = 0;
71     }
72 torben 675 }
73    
74    
75     void EmbeddedHttp::stopServer() {
76 torben 680 if (m_context != 0) {
77     mg_stop(m_context);
78     }
79 torben 675 }

  ViewVC Help
Powered by ViewVC 1.1.20