server-status.js 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. (function() {
  2. /*
  3. * We display untrusted stuff in html context... reject anything
  4. * that has HTML stuff in it
  5. */
  6. function san(s)
  7. {
  8. if (s.search("<") !== -1)
  9. return "invalid string";
  10. return s;
  11. }
  12. function humanize(s)
  13. {
  14. var i = parseInt(s, 10);
  15. if (i >= (1024 * 1024 * 1024))
  16. return (i / (1024 * 1024 * 1024)).toFixed(3) + "Gi";
  17. if (i >= (1024 * 1024))
  18. return (i / (1024 * 1024)).toFixed(3) + "Mi";
  19. if (i > 1024)
  20. return (i / 1024).toFixed(3) + "Ki";
  21. return s;
  22. }
  23. function get_appropriate_ws_url()
  24. {
  25. var pcol;
  26. var u = document.URL;
  27. /*
  28. * We open the websocket encrypted if this page came on an
  29. * https:// url itself, otherwise unencrypted
  30. */
  31. if (u.substring(0, 5) === "https") {
  32. pcol = "wss://";
  33. u = u.substr(8);
  34. } else {
  35. pcol = "ws://";
  36. if (u.substring(0, 4) === "http")
  37. u = u.substr(7);
  38. }
  39. u = u.split("/");
  40. /* + "/xxx" bit is for IE10 workaround */
  41. return pcol + u[0] + "/xxx";
  42. }
  43. var socket_status, jso, s;
  44. function ws_open_server_status()
  45. {
  46. socket_status = new WebSocket(get_appropriate_ws_url(),
  47. "lws-server-status");
  48. try {
  49. socket_status.onopen = function() {
  50. document.getElementById("title").innerHTML = "Server Status (Active)";
  51. lws_gray_out(false);
  52. };
  53. socket_status.onmessage =function got_packet(msg) {
  54. var u, ci, n;
  55. //document.getElementById("json").innerHTML = "<pre>"+msg.data+"</pre>";
  56. if (msg.data.length < 100)
  57. return;
  58. jso = JSON.parse(msg.data);
  59. u = parseInt(san(jso.i.uptime), 10);
  60. if (parseInt(jso.i.contexts[0].deprecated, 10) === 0)
  61. s = "<table><tr><td></td><td class=\"c0\">";
  62. else
  63. s = "<table><tr><td></td><td class=\"dc0\">";
  64. s +=
  65. "Server</td><td>" +
  66. "<span class=\"sn\">Server Version:</span> <span class=\"v\">" +
  67. san(jso.i.version) + "</span><br>" +
  68. "<span class=\"sn\">Host Uptime:</span> <span class=\"v\">" +
  69. ((u / (24 * 3600)) | 0) + "d " +
  70. (((u % (24 * 3600)) / 3600) | 0) + "h " +
  71. (((u % 3600) / 60) | 0) + "m</span>";
  72. if (jso.i.l1)
  73. s = s + ", <span class=\"sn\">Host Load:</span> <span class=\"v\">" + san(jso.i.l1) + " ";
  74. if (jso.i.l2)
  75. s = s + san(jso.i.l2) + " ";
  76. if (jso.i.l3)
  77. s = s + san(jso.i.l3);
  78. if (jso.i.l1)
  79. s =s + "</span>";
  80. if (jso.i.statm) {
  81. var sm = jso.i.statm.split(" ");
  82. s += ", <span class=\"sn\">Virt stack + heap Usage:</span> <span class=\"v\">" +
  83. humanize(parseInt(sm[5], 10) * 4096) + "B</span>";
  84. }
  85. s += ", <span class=\"sn\">lws heap usage:</span> <span class=\"v\">" +
  86. humanize(jso.i.heap) + "B</span>";
  87. for (n = 0; n < jso.files.length; n++) {
  88. s += "<br><span class=n>" + san(jso.files[n].path) + ":</span><br> " + san(jso.files[n].val);
  89. }
  90. s += "</td></tr>";
  91. for (ci = 0; ci < jso.i.contexts.length; ci++) {
  92. if (parseInt(jso.i.contexts[ci].deprecated, 10) === 0)
  93. s += "<tr><td></td><td class=\"c\">" +
  94. "Active Context</td><td>";
  95. else
  96. s += "<tr><td></td><td class=\"c1\">" +
  97. "Deprecated Context " + ci + "</td><td>";
  98. u = parseInt(san(jso.i.contexts[ci].context_uptime), 10);
  99. s += "<span class=n>Server Uptime:</span> <span class=v>" +
  100. ((u / (24 * 3600)) | 0) + "d " +
  101. (((u % (24 * 3600)) / 3600) | 0) + "h " +
  102. (((u % 3600) / 60) | 0) + "m</span>";
  103. s = s +
  104. "<br>" +
  105. "<span class=n>Listening wsi:</span> <span class=v>" + san(jso.i.contexts[ci].listen_wsi) + "</span>, " +
  106. "<span class=n>Current wsi alive:</span> <span class=v>" + (parseInt(san(jso.i.contexts[ci].wsi_alive), 10) -
  107. parseInt(san(jso.i.contexts[ci].listen_wsi), 10)) + "</span><br>" +
  108. "<span class=n>Total Rx:</span> <span class=v>" + humanize(san(jso.i.contexts[ci].rx)) +"B</span>, " +
  109. "<span class=n>Total Tx:</span> <span class=v>" + humanize(san(jso.i.contexts[ci].tx)) +"B</span><br>" +
  110. "<span class=n>CONNECTIONS: HTTP/1.x:</span> <span class=v>" + san(jso.i.contexts[ci].h1_conn) +"</span>, " +
  111. "<span class=n>Websocket:</span> <span class=v>" + san(jso.i.contexts[ci].ws_upg) +"</span>, " +
  112. "<span class=n>H2 upgrade:</span> <span class=v>" + san(jso.i.contexts[ci].h2_upg) +"</span>, " +
  113. "<span class=n>H2 ALPN:</span> <span class=v>" + san(jso.i.contexts[ci].h2_alpn) +"</span>, " +
  114. "<span class=n>Rejected:</span> <span class=v>" + san(jso.i.contexts[ci].rejected) +"</span><br>" +
  115. "<span class=n>TRANSACTIONS: HTTP/1.x:</span> <span class=v>" + san(jso.i.contexts[ci].h1_trans) + "</span>, " +
  116. "<span class=n>H2:</span> <span class=v>" + san(jso.i.contexts[ci].h2_trans) +"</span>, " +
  117. "<span class=n>Total H2 substreams:</span> <span class=v>" + san(jso.i.contexts[ci].h2_subs) +"</span><br>" +
  118. "<span class=n>CGI: alive:</span> <span class=v>" + san(jso.i.contexts[ci].cgi_alive) + "</span>, " +
  119. "<span class=n>spawned:</span> <span class=v>" + san(jso.i.contexts[ci].cgi_spawned) +
  120. "</span><table>";
  121. for (n = 0; n < jso.i.contexts[ci].pt.length; n++) {
  122. if (parseInt(jso.i.contexts[ci].deprecated, 10) === 0)
  123. s += "<tr><td>&nbsp;&nbsp;</td><td class=\"l\">service thread " + (n + 1);
  124. else
  125. s += "<tr><td>&nbsp;&nbsp;</td><td class=\"dl\">service thread " + (n + 1);
  126. s += "</td><td>" +
  127. "<span class=n>fds:</span> <span class=v>" + san(jso.i.contexts[ci].pt[n].fds_count) + " / " +
  128. san(jso.i.contexts[ci].pt_fd_max) + "</span>, ";
  129. s = s + "<span class=n>ah pool:</span> <span class=v>" + san(jso.i.contexts[ci].pt[n].ah_pool_inuse) + " / " +
  130. san(jso.i.contexts[ci].ah_pool_max) + "</span>, " +
  131. "<span class=n>ah waiting list:</span> <span class=v>" + san(jso.i.contexts[ci].pt[n].ah_wait_list);
  132. s = s + "</span></td></tr>";
  133. }
  134. for (n = 0; n < jso.i.contexts[ci].vhosts.length; n++) {
  135. if (parseInt(jso.i.contexts[ci].deprecated, 10) === 0)
  136. s += "<tr><td>&nbsp;&nbsp;</td><td class=\"l\">vhost " + (n + 1);
  137. else
  138. s += "<tr><td>&nbsp;&nbsp;</td><td class=\"dl\">vhost " + (n + 1);
  139. s += "</td><td><span class=\"mountname\">";
  140. if (jso.i.contexts[ci].vhosts[n].use_ssl === "1")
  141. s = s + "https://";
  142. else
  143. s = s + "http://";
  144. s = s + san(jso.i.contexts[ci].vhosts[n].name) + ":" +
  145. san(jso.i.contexts[ci].vhosts[n].port) + "</span>";
  146. if (jso.i.contexts[ci].vhosts[n].sts === "1")
  147. s = s + " (STS)";
  148. s = s +"<br>" +
  149. "<span class=n>Total Rx:</span> <span class=v>" + humanize(san(jso.i.contexts[ci].vhosts[n].rx)) +"B</span>, " +
  150. "<span class=n>Total Tx:</span> <span class=v>" + humanize(san(jso.i.contexts[ci].vhosts[n].tx)) +"B</span><br>" +
  151. "<span class=n>CONNECTIONS: HTTP/1.x:</span> <span class=v>" + san(jso.i.contexts[ci].vhosts[n].h1_conn) +"</span>, " +
  152. "<span class=n>Websocket:</span> <span class=v>" + san(jso.i.contexts[ci].vhosts[n].ws_upg) +"</span>, " +
  153. "<span class=n>H2 upgrade:</span> <span class=v>" + san(jso.i.contexts[ci].vhosts[n].h2_upg) +"</span>, " +
  154. "<span class=n>H2 ALPN:</span> <span class=v>" + san(jso.i.contexts[ci].vhosts[n].h2_alpn) +"</span>, " +
  155. "<span class=n>Rejected:</span> <span class=v>" + san(jso.i.contexts[ci].vhosts[n].rejected) +"</span><br>" +
  156. "<span class=n>TRANSACTIONS: HTTP/1.x:</span> <span class=v>" + san(jso.i.contexts[ci].vhosts[n].h1_trans) + "</span>, " +
  157. "<span class=n>H2:</span> <span class=v>" + san(jso.i.contexts[ci].vhosts[n].h2_trans) +"</span>, " +
  158. "<span class=n>Total H2 substreams:</span> <span class=v>" + san(jso.i.contexts[ci].vhosts[n].h2_subs) +"</span><br>";
  159. if (jso.i.contexts[ci].vhosts[n].mounts) {
  160. s = s + "<table><tr><td class=t>Mountpoint</td><td class=t>Origin</td><td class=t>Cache Policy</td></tr>";
  161. var m;
  162. for (m = 0; m < jso.i.contexts[ci].vhosts[n].mounts.length; m++) {
  163. s = s + "<tr><td>";
  164. s = s + "<span class=\"m1\">" + san(jso.i.contexts[ci].vhosts[n].mounts[m].mountpoint) +
  165. "</span></td><td><span class=\"m2\">" +
  166. san(jso.i.contexts[ci].vhosts[n].mounts[m].origin) +
  167. "</span></td><td>";
  168. if (parseInt(san(jso.i.contexts[ci].vhosts[n].mounts[m].cache_max_age), 10))
  169. s = s + "<span class=n>max-age:</span> <span class=v>" +
  170. san(jso.i.contexts[ci].vhosts[n].mounts[m].cache_max_age) +
  171. "</span>, <span class=n>reuse:</span> <span class=v>" +
  172. san(jso.i.contexts[ci].vhosts[n].mounts[m].cache_reuse) +
  173. "</span>, <span class=n>reval:</span> <span class=v>" +
  174. san(jso.i.contexts[ci].vhosts[n].mounts[m].cache_revalidate) +
  175. "</span>, <span class=n>inter:</span> <span class=v>" +
  176. san(jso.i.contexts[ci].vhosts[n].mounts[m].cache_intermediaries);
  177. s = s + "</span></td></tr>";
  178. }
  179. s = s + "</table>";
  180. }
  181. s = s + "</td></tr>";
  182. }
  183. s += "</table></td></tr>";
  184. } // context
  185. s = s + "</table>";
  186. document.getElementById("conninfo").innerHTML = s;
  187. };
  188. socket_status.onclose = function(){
  189. document.getElementById("title").innerHTML = "Server Status (Disconnected)";
  190. lws_gray_out(true,{"zindex":"499"});
  191. };
  192. } catch(exception) {
  193. alert("<p>Error" + exception);
  194. }
  195. }
  196. /* stuff that has to be delayed until all the page assets are loaded */
  197. window.addEventListener("load", function() {
  198. lws_gray_out(true,{"zindex":"499"});
  199. ws_open_server_status();
  200. }, false);
  201. }());