@@ -95,30 +95,27 @@ void printtable(ostringstream &ret, const string &ringname, const string &title,
95
95
int entries=0 ;
96
96
vector<pair <string,unsigned int > >ring=S.getRing (ringname);
97
97
98
- for (vector<pair<string, unsigned int > >::const_iterator i=ring.begin (); i!=ring.end ();++i) {
98
+ for (vector<pair<string, unsigned int > >::const_iterator i=ring.begin (); i!=ring.end ();++i) {
99
99
tot+=i->second ;
100
100
entries++;
101
101
}
102
102
103
-
104
- ret<<" <table border=1><tr><td colspan=3 bgcolor=\" #0000ff\" >"
105
- " <a href=\" ?ring=" <<ringname<<" \" ><font color=\" #ffffff\" >Top-" <<limit<<" of " ;
106
- ret<<entries<<" : " <<title<<" </font></a></td>" <<endl;
107
-
108
- ret<<" <tr><td colspan=3><table bgcolor=\" #ff0000\" width=\" 100%\" ><tr><td align=left>"
109
- " <a href=\" ?resetring=" <<ringname<<" \" ><font color=\" #ffffff\" >Reset</font></a></td>" ;
110
- ret<<" <td align=right>Resize: " ;
111
-
103
+ ret<<" <div class=\" panel\" >" ;
104
+ ret<<" <span class=resetring><i></i><a href=\" ?resetring=" <<ringname<<" \" >Reset</a></span>" <<endl;
105
+ ret<<" <h2>" <<title<<" </h2>" <<endl;
106
+ ret<<" <div class=ringmeta>" ;
107
+ ret<<" <a class=topXofY href=\" ?ring=" <<ringname<<" \" >Showing: Top " <<limit<<" of " <<entries<<" </a>" <<endl;
108
+ ret<<" <span class=resizering>Resize: " ;
112
109
unsigned int sizes[]={10 ,100 ,500 ,1000 ,10000 ,500000 ,0 };
113
110
for (int i=0 ;sizes[i];++i) {
114
111
if (S.getRingSize (ringname)!=sizes[i])
115
112
ret<<" <a href=\" ?resizering=" <<ringname<<" &size=" <<sizes[i]<<" \" >" <<sizes[i]<<" </a> " ;
116
113
else
117
114
ret<<" (" <<sizes[i]<<" ) " ;
118
115
}
119
- ret<<" </td></table>" <<endl;
120
-
116
+ ret<<" </span></div>" ;
121
117
118
+ ret<<" <table class=\" data\" >" ;
122
119
int printed=0 ;
123
120
for (vector<pair<string,unsigned int > >::const_iterator i=ring.begin ();limit && i!=ring.end ();++i,--limit) {
124
121
ret<<" <tr><td>" <<i->first <<" </td><td>" <<i->second <<" </td><td align=right>" << StatWebServer::makePercentage (i->second *100.0 /tot)<<" </td>" <<endl;
@@ -129,20 +126,19 @@ void printtable(ostringstream &ret, const string &ringname, const string &title,
129
126
ret<<" <tr><td><b>Rest:</b></td><td><b>" <<tot-printed<<" </b></td><td align=right><b>" << StatWebServer::makePercentage ((tot-printed)*100.0 /tot)<<" </b></td>" <<endl;
130
127
131
128
ret<<" <tr><td><b>Total:</b></td><td><b>" <<tot<<" </b></td><td align=right><b>100%</b></td>" ;
132
- ret<<" </table><br >" <<endl;
129
+ ret<<" </table></div >" <<endl;
133
130
}
134
131
135
132
void StatWebServer::printvars (ostringstream &ret)
136
133
{
137
- ret<<" <table border=1><tr><td colspan=3 bgcolor=\" #0000ff\" ><font color=\" #ffffff\" >Variables</font></td>" <<endl;
138
-
134
+ ret<<" <div class=panel><h2>Variables</h2><table class=\" data\" >" <<endl;
139
135
140
136
vector<string>entries=S.getEntries ();
141
137
for (vector<string>::const_iterator i=entries.begin ();i!=entries.end ();++i) {
142
138
ret<<" <tr><td>" <<*i<<" </td><td>" <<S.read (*i)<<" </td><td>" <<S.getDescrip (*i)<<" </td>" <<endl;
143
139
}
144
140
145
- ret<<" </table>" <<endl;
141
+ ret<<" </table></div> " <<endl;
146
142
}
147
143
148
144
void StatWebServer::printargs (ostringstream &ret)
@@ -177,17 +173,21 @@ string StatWebServer::indexfunction(const string& method, const string& post, co
177
173
178
174
ostringstream ret;
179
175
180
- ret<<" <!DOCTYPE HTML PUBLIC \" -//W3C//DTD HTML 4.01 Transitional//EN\" \" http://www.w3.org/TR/html4/loose.dtd\" >" <<endl;
181
- ret<<" <html><head><title>PowerDNS Operational Monitor</title></head><body bgcolor=\" #ffffff\" >" <<endl;
182
-
183
-
184
- ret<<" <h2>" ;
185
- if (!arg ()[" config-name" ].empty ())
186
- ret<<" [" <<arg ()[" config-name" ]<<" ]" ;
187
- if (rvarmap[" ring" ].empty ())
188
- ret<<" PDNS " VERSION" Main Page</h2>" <<endl;
189
- else
190
- ret<<" Details page</h2><a href=\" /\" >Back to main page</a>" <<endl;
176
+ ret<<" <!DOCTYPE html>" <<endl;
177
+ ret<<" <html><head>" <<endl;
178
+ ret<<" <title>PowerDNS Authoritative Server Monitor</title>" <<endl;
179
+ ret<<" <link rel=\" stylesheet\" href=\" style.css\" />" <<endl;
180
+ ret<<" </head><body>" <<endl;
181
+
182
+ ret<<" <div class=\" row\" >" <<endl;
183
+ ret<<" <div class=\" headl columns\" >" ;
184
+ ret<<" <a href=\" /\" id=\" appname\" >PowerDNS " VERSION;
185
+ if (!arg ()[" config-name" ].empty ()) {
186
+ ret<<" [" <<arg ()[" config-name" ]<<" ]" ;
187
+ }
188
+ ret<<" </a></div>" <<endl;
189
+ ret<<" <div class=\" headr columns\" ></div></div>" ;
190
+ ret<<" <div class=\" row\" ><div class=\" all columns\" >" ;
191
191
192
192
time_t passed=time (0 )-s_starttime;
193
193
@@ -221,7 +221,7 @@ string StatWebServer::indexfunction(const string& method, const string& post, co
221
221
sws->d_qcachemisses .get10 ()<<" . Max queries/second: " <<sws->d_qcachemisses .getMax ()<<
222
222
" <br>" <<endl;
223
223
224
- ret<<" Total queries: " <<S.read (" udp-queries" )<<" . Question/answer latency: " <<S.read (" latency" )/1000.0 <<" ms</p>" <<endl;
224
+ ret<<" Total queries: " <<S.read (" udp-queries" )<<" . Question/answer latency: " <<S.read (" latency" )/1000.0 <<" ms</p><br> " <<endl;
225
225
if (rvarmap[" ring" ].empty ()) {
226
226
vector<string>entries=S.listRings ();
227
227
for (vector<string>::const_iterator i=entries.begin ();i!=entries.end ();++i)
@@ -234,6 +234,8 @@ string StatWebServer::indexfunction(const string& method, const string& post, co
234
234
else
235
235
printtable (ret,rvarmap[" ring" ],S.getRingTitle (rvarmap[" ring" ]),100 );
236
236
237
+ ret<<" </div></div>" <<endl;
238
+ ret<<" <footer class=\" row\" >PowerDNS Authoritative Server " VERSION" . © 2013 <a href=\" http://www.powerdns.com/\" >PowerDNS.COM BV</a>.</footer>" <<endl;
237
239
ret<<" </body></html>" <<endl;
238
240
239
241
return ret.str ();
@@ -518,11 +520,52 @@ string StatWebServer::jsonstat(const string& method, const string& post, const m
518
520
return ret;
519
521
}
520
522
523
+ string StatWebServer::cssfunction (const string& method, const string& post, const map<string,string> &varmap, void *ptr, bool *custom)
524
+ {
525
+ *custom=1 ; // indicates we build the response
526
+ ostringstream ret;
527
+ ret<<" HTTP/1.1 200 OK\r\n "
528
+ " Server: PowerDNS/" VERSION" \r\n "
529
+ " Connection: close\r\n "
530
+ " Cache-Control: max-age=86400\r\n "
531
+ " Content-Type: text/css\r\n "
532
+ " \r\n " ;
533
+
534
+ ret<<" * { box-sizing: border-box; margin: 0; padding: 0; }" <<endl;
535
+ ret<<" body { color: black; background: white; margin-top: 1em; font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; font-size: 10pt; position: relative; }" <<endl;
536
+ ret<<" a { color: #0959c2; }" <<endl;
537
+ ret<<" a:hover { color: #3B8EC8; }" <<endl;
538
+ ret<<" .row { width: 940px; max-width: 100%; min-width: 768px; margin: 0 auto; }" <<endl;
539
+ ret<<" .row:before, .row:after { display: table; content:\" \" ; }" <<endl;
540
+ ret<<" .row:after { clear: both; }" <<endl;
541
+ ret<<" .columns { position: relative; min-height: 1px; float: left; }" <<endl;
542
+ ret<<" .all { width: 100%; }" <<endl;
543
+ ret<<" .headl { width: 60%; }" <<endl;
544
+ ret<<" .headr { width: 39.5%; float: right; background-repeat: no-repeat; margin-top: 7px; " ;
545
+ ret<<"background-image: url();";
546
+ ret<<" width: 154px; height: 20px; }" <<endl;
547
+ ret<<" a#appname { margin: 0; font-size: 27px; color: #666; text-decoration: none; font-weight: bold; display: block; }" <<endl;
548
+ ret<<" footer { border-top: 1px solid #ddd; padding-top: 4px; font-size: 12px; }" <<endl;
549
+ ret<<" footer.row { margin-top: 1em; margin-bottom: 1em; }" <<endl;
550
+ ret<<" .panel { background: #f2f2f2; border: 1px solid #e6e6e6; margin: 0 0 22px 0; padding: 20px; }" <<endl;
551
+ ret<<" table.data { width: 100%; border-spacing: 0; border-top: 1px solid #333; }" <<endl;
552
+ ret<<" table.data td { border-bottom: 1px solid #333; padding: 2px; }" <<endl;
553
+ ret<<" table.data tr:nth-child(2n) { background: #e2e2e2; }" <<endl;
554
+ ret<<" table.data tr:hover { background: white; }" <<endl;
555
+ ret<<" .ringmeta { margin-bottom: 5px; }" <<endl;
556
+ ret<<" .resetring {float: right; }" <<endl;
557
+ ret<<" .resetring i { background-image: url(); width: 10px; height: 10px; margin-right: 2px; display: inline-block; background-repeat: no-repeat; }" <<endl;
558
+ ret<<" .resetring:hover i { background-image: url();}" <<endl;
559
+ ret<<" .resizering {float: right;}" <<endl;
560
+ return ret.str ();
561
+ }
562
+
521
563
void StatWebServer::launch ()
522
564
{
523
565
try {
524
566
d_ws->setCaller (this );
525
567
d_ws->registerHandler (" " ,&indexfunction);
568
+ d_ws->registerHandler (" style.css" ,&cssfunction);
526
569
if (::arg ().mustDo (" experimental-json-interface" ))
527
570
d_ws->registerHandler (" jsonstat" , &jsonstat);
528
571
d_ws->go ();
0 commit comments