1(function () { 2function check_file() 3{ 4 var f = document.getElementById("file").files[0]; 5 var max_len = 100000; 6 var dis = 0; 7 8 if (f) { 9 if (f.size >= max_len) { 10 dis = 1; 11 document.getElementById("file_info").innerHTML = 12 "<span style=\"color:red;font-weight:bold\">File larger than " + 13 max_len+"</span>"; 14 } else 15 document.getElementById("file_info").innerHTML = 16 "File length "+f.size; 17 } else 18 dis = 1; 19 20 document.getElementById("upload").disabled = dis; 21} 22 23/* 24 * We display untrusted stuff in html context... reject anything 25 * that has HTML stuff in it 26 */ 27 28function san(s) 29{ 30 if (s.search("<") !== -1) 31 return "invalid string"; 32 33 return s; 34} 35 36/* BrowserDetect came from http://www.quirksmode.org/js/detect.html */ 37 38var BrowserDetect = { 39 init: function () { 40 this.browser = this.searchString(this.dataBrowser) || 41 "An unknown browser"; 42 this.version = this.searchVersion(navigator.userAgent) 43 || this.searchVersion(navigator.appVersion) 44 || "an unknown version"; 45 this.OS = this.searchString(this.dataOS) || "an unknown OS"; 46 }, 47 searchString: function (data) { 48 for (var i=0;i<data.length;i++) { 49 var dataString = data[i].string; 50 var dataProp = data[i].prop; 51 this.versionSearchString = data[i].versionSearch || data[i].identity; 52 if (dataString) { 53 if (dataString.indexOf(data[i].subString) !== -1) 54 return data[i].identity; 55 } 56 else if (dataProp) 57 return data[i].identity; 58 } 59 }, 60 searchVersion: function (dataString) { 61 var index = dataString.indexOf(this.versionSearchString); 62 if (index === -1) return 0; 63 return parseFloat(dataString.substring(index + 64 this.versionSearchString.length + 1)); 65 }, 66 dataBrowser: [ 67 { 68 string: navigator.userAgent, 69 subString: "Chrome", 70 identity: "Chrome" 71 }, 72 { string: navigator.userAgent, 73 subString: "OmniWeb", 74 versionSearch: "OmniWeb/", 75 identity: "OmniWeb" 76 }, 77 { 78 string: navigator.vendor, 79 subString: "Apple", 80 identity: "Safari", 81 versionSearch: "Version" 82 }, 83 { 84 prop: window.opera, 85 identity: "Opera", 86 versionSearch: "Version" 87 }, 88 { 89 string: navigator.vendor, 90 subString: "iCab", 91 identity: "iCab" 92 }, 93 { 94 string: navigator.vendor, 95 subString: "KDE", 96 identity: "Konqueror" 97 }, 98 { 99 string: navigator.userAgent, 100 subString: "Firefox", 101 identity: "Firefox" 102 }, 103 { 104 string: navigator.vendor, 105 subString: "Camino", 106 identity: "Camino" 107 }, 108 { // for newer Netscapes (6+) 109 string: navigator.userAgent, 110 subString: "Netscape", 111 identity: "Netscape" 112 }, 113 { 114 string: navigator.userAgent, 115 subString: "MSIE", 116 identity: "Explorer", 117 versionSearch: "MSIE" 118 }, 119 { 120 string: navigator.userAgent, 121 subString: "Gecko", 122 identity: "Mozilla", 123 versionSearch: "rv" 124 }, 125 { // for older Netscapes (4-) 126 string: navigator.userAgent, 127 subString: "Mozilla", 128 identity: "Netscape", 129 versionSearch: "Mozilla" 130 } 131 ], 132 dataOS : [ 133 { 134 string: navigator.platform, 135 subString: "Win", 136 identity: "Windows" 137 }, 138 { 139 string: navigator.platform, 140 subString: "Mac", 141 identity: "Mac" 142 }, 143 { 144 string: navigator.userAgent, 145 subString: "iPhone", 146 identity: "iPhone/iPod" 147 }, 148 { 149 string: navigator.platform, 150 subString: "Linux", 151 identity: "Linux" 152 } 153 ] 154 155}; 156 157var pos = 0; 158 159function get_appropriate_ws_url(extra_url) 160{ 161 var pcol; 162 var u = document.URL; 163 164 /* 165 * We open the websocket encrypted if this page came on an 166 * https:// url itself, otherwise unencrypted 167 */ 168 169 if (u.substring(0, 5) === "https") { 170 pcol = "wss://"; 171 u = u.substr(8); 172 } else { 173 pcol = "ws://"; 174 if (u.substring(0, 4) === "http") 175 u = u.substr(7); 176 } 177 178 u = u.split("/"); 179 180 /* + "/xxx" bit is for IE10 workaround */ 181 182 return pcol + u[0] + "/" + extra_url; 183} 184 185var params = {}; 186 187if (location.search) { 188 var parts = location.search.substring(1).split("&"); 189 190 for (var i = 0; i < parts.length; i++) { 191 var nv = parts[i].split("="); 192 if (!nv[0]) continue; 193 params[nv[0]] = nv[1] || true; 194 } 195} 196 197var socket_di; 198 199var mirror_name = ""; 200if (params.mirror) 201 mirror_name = params.mirror; 202 203 console.log(mirror_name); 204 205function ws_open_dumb_increment() 206{ 207 socket_di = new_ws(get_appropriate_ws_url(""), "dumb-increment-protocol"); 208 209 try { 210 socket_di.onopen = function() { 211 document.getElementById("wsdi_statustd").style.backgroundColor = 212 "#40ff40"; 213 document.getElementById("wsdi_status").innerHTML = 214 " <b>websocket connection opened</b><br>" + 215 san(socket_di.extensions); 216 }; 217 218 socket_di.onmessage =function got_packet(msg) { 219 document.getElementById("number").textContent = msg.data + "\n"; 220 }; 221 222 socket_di.onclose = function(){ 223 document.getElementById("wsdi_statustd").style.backgroundColor = 224 "#ff4040"; 225 document.getElementById("wsdi_status").textContent = 226 " websocket connection CLOSED "; 227 }; 228 } catch(exception) { 229 alert("<p>Error" + exception); 230 } 231} 232 233 var socket_status, jso, s; 234 235function ws_open_status() 236{ 237 238 socket_status = new_ws(get_appropriate_ws_url(""), "lws-status"); 239 240 try { 241 socket_status.onopen = function() { 242 document.getElementById("s_statustd").style.backgroundColor = 243 "#40ff40"; 244 document.getElementById("s_status").innerHTML = 245 " <b>websocket connection opened</b><br>" + 246 san(socket_status.extensions); 247 }; 248 249 socket_status.onmessage =function got_packet(msg) { 250 var s; 251 252 console.log(msg.data); 253 254 jso = JSON.parse(msg.data); 255 256 if (jso.wss_over_h2 === "1") 257 document.getElementById("wstransport").innerHTML = 258 "<img src=\"./wss-over-h2.png\">"; 259 260 document.getElementById("servinfo").innerHTML = 261 "<table><tr><td class=l>Build info</td><td>"+ 262 san(jso.version) + "</td></tr>" + 263 "<tr><td class=l>Server info</td><td>" + 264 san(jso.hostname) + "</td></tr>" + 265 "</table>"; 266 s="<table>"; 267 var n; 268 for (n = 0; n < jso.conns.length; n++) { 269 var d = new Date(parseInt(jso.conns[n].time, 10) * 1000); 270 271 s = s + "<tr><td class=l>client " + (n + 1) + 272 "</td><td><b>" + san(jso.conns[n].peer) + 273 "</b><br>" + san(d.toString()) + 274 "<br>" + san(jso.conns[n].ua) + 275 "</td></tr>"; 276 } 277 s = s + "</table>"; 278 279 document.getElementById("conninfo").innerHTML = s; 280 }; 281 282 socket_status.onclose = function(){ 283 document.getElementById("s_statustd").style.backgroundColor = 284 "#ff4040"; 285 document.getElementById("s_status").textContent = 286 " websocket connection CLOSED "; 287 }; 288 } catch(exception) { 289 alert("<p>Error" + exception); 290 } 291} 292 293function reset() { 294 socket_di.send("reset\n"); 295} 296 297 298function junk() { 299 for(var word = ""; word.length < 9000; word += "a"){} 300 socket_di.send(word); 301} 302 303function on_pmd() { 304 socket_status.send("{ \"RequestType\":\"DDoS\", \"blob\":\"\" }"); 305 socket_status.send("{ \"RequestType\":\"SendImage\", \"RequestID\":\"283463389\", \"toType\":\"toUser\", \"toID\":\"1036\", \"fileType\":\"image/jpeg\", \"blob\":\"\"}"); 306 socket_status.send("{ \"RequestType\":\"SendImage\", \"RequestID\":\"788346414\", \"toType\":\"toUser\", \"toID\":\"1036\", \"fileType\":\"image/jpeg\", \"blob\":\"\"}"); 307} 308 309var socket_ot; 310 311function ot_open() { 312 socket_ot = new_ws(get_appropriate_ws_url(""), "dumb-increment-protocol"); 313 314 console.log("ot_open"); 315 316 try { 317 socket_ot.onopen = function() { 318 document.getElementById("ot_statustd").style.backgroundColor = 319 "#40ff40"; 320 document.getElementById("ot_status").innerHTML = 321 " <b>websocket connection opened</b><br>" + 322 san(socket_di.extensions); 323 document.getElementById("ot_open_btn").disabled = true; 324 document.getElementById("ot_close_btn").disabled = false; 325 document.getElementById("ot_req_close_btn").disabled = false; 326 console.log("ot_open.onopen"); 327 }; 328 329 socket_ot.onclose = function(e){ 330 document.getElementById("ot_statustd").style.backgroundColor = 331 "#ff4040"; 332 document.getElementById("ot_status").textContent = 333 " websocket connection CLOSED, code: " + e.code + 334 ", reason: " + e.reason; 335 document.getElementById("ot_open_btn").disabled = false; 336 document.getElementById("ot_close_btn").disabled = true; 337 document.getElementById("ot_req_close_btn").disabled = true; 338 }; 339 } catch(exception) { 340 alert("<p>Error" + exception); 341 } 342} 343 344/* browser will close the ws in a controlled way */ 345function ot_close() { 346 socket_ot.close(3000, "Bye!"); 347} 348 349/* we ask the server to close the ws in a controlled way */ 350function ot_req_close() { 351 socket_ot.send("closeme\n"); 352} 353 354var socket_lm; 355var pending = ""; 356 357function lm_timer_handler(ev) { 358 socket_lm.send(pending); 359 pending=""; 360} 361 362/* lws-mirror protocol */ 363 364var down = 0; 365var no_last = 1; 366var last_x = 0, last_y = 0; 367var ctx; 368var color = "#000000"; 369var lm_timer; 370 371function ev_mousemove (ev) { 372 var x, y; 373 374 if (ev.offsetX) { 375 x = ev.offsetX; 376 y = ev.offsetY; 377 } else { 378 x = ev.layerX - offsetX; 379 y = ev.layerY - offsetY; 380 381 } 382 383 if (!down) 384 return; 385 if (no_last) { 386 no_last = 0; 387 last_x = x; 388 last_y = y; 389 return; 390 } 391 pending = pending + "d " + color + " " + last_x + " " + last_y + 392 " " + x + " " + y + ";"; 393 394 if (pending.length > 400) { 395 socket_lm.send(pending); 396 clearTimeout(lm_timer); 397 pending = ""; 398 } else 399 lm_timer = setTimeout(lm_timer_handler, 1); 400 401 last_x = x; 402 last_y = y; 403} 404 405function ev_mousedown (ev) { 406 down = 1; 407} 408 409function ev_mouseup(ev) { 410 down = 0; 411 no_last = 1; 412} 413 414 415function ws_open_mirror() 416{ 417 socket_lm = new_ws(get_appropriate_ws_url("?mirror=" + mirror_name), 418 "lws-mirror-protocol"); 419 try { 420 socket_lm.onopen = function() { 421 document.getElementById("wslm_statustd").style.backgroundColor = 422 "#40ff40"; 423 document.getElementById("wslm_status").innerHTML = 424 " <b>websocket connection opened</b><br>" + 425 san(socket_lm.extensions); 426 lws_gray_out(false); 427 }; 428 429 socket_lm.onmessage =function got_packet(msg) { 430 j = msg.data.split(";"); 431 var f = 0; 432 while (f < j.length - 1) { 433 i = j[f].split(" "); 434 if (i[0] === "d") { 435 ctx.strokeStyle = i[1]; 436 ctx.beginPath(); 437 ctx.moveTo(+(i[2]), +(i[3])); 438 ctx.lineTo(+(i[4]), +(i[5])); 439 ctx.stroke(); 440 } 441 if (i[0] === "c") { 442 ctx.strokeStyle = i[1]; 443 ctx.beginPath(); 444 ctx.arc(+(i[2]), +(i[3]), +(i[4]), 0, Math.PI*2, true); 445 ctx.stroke(); 446 } 447 448 f++; 449 } 450 }; 451 452 socket_lm.onclose = function(){ 453 document.getElementById("wslm_statustd").style.backgroundColor = 454 "#ff4040"; 455 document.getElementById("wslm_status").textContent = 456 " websocket connection CLOSED "; 457 lws_gray_out(true,{"zindex":"499"}); 458 }; 459 } catch(exception) { 460 alert("<p>Error" + exception); 461 } 462 463 var canvas = document.createElement("canvas"); 464 canvas.height = 300; 465 canvas.width = 480; 466 ctx = canvas.getContext("2d"); 467 468 document.getElementById("wslm_drawing").appendChild(canvas); 469 470 canvas.addEventListener("mousemove", ev_mousemove, false); 471 canvas.addEventListener("mousedown", ev_mousedown, false); 472 canvas.addEventListener("mouseup", ev_mouseup, false); 473 474 offsetX = offsetY = 0; 475 element = canvas; 476 if (element.offsetParent) { 477 do { 478 offsetX += element.offsetLeft; 479 offsetY += element.offsetTop; 480 element = element.offsetParent; 481 } while (element); 482 } 483} 484 485function update_color() { 486 color = document.getElementById("color").value; 487} 488 489/* stuff that has to be delayed until all the page assets are loaded */ 490 491window.addEventListener("load", function() { 492 493 lws_gray_out(true,{"zindex":"499"}); 494 495 document.getElementById("file").onchange = check_file; 496 document.getElementById("offset").onclick = reset; 497 document.getElementById("junk").onclick = junk; 498 document.getElementById("color").onclick = update_color; 499 document.getElementById("ot_open_btn").onclick = ot_open; 500 document.getElementById("ot_close_btn").onclick = ot_close; 501 document.getElementById("ot_req_close_btn").onclick = ot_req_close; 502 document.getElementById("pmd").onclick = on_pmd; 503 504 var transport_protocol = ""; 505 506 if ( performance && performance.timing.nextHopProtocol ) { 507 transport_protocol = performance.timing.nextHopProtocol; 508 } else if ( window.chrome && window.chrome.loadTimes ) { 509 transport_protocol = window.chrome.loadTimes().connectionInfo; 510 } else { 511 512 var p = performance.getEntriesByType("resource"); 513 for (var i=0; i < p.length; i++) { 514 var value = "nextHopProtocol" in p[i]; 515 if (value) 516 transport_protocol = p[i].nextHopProtocol; 517 } 518 } 519 520 console.log("transport protocol " + transport_protocol); 521 522 if (transport_protocol === "h2") 523 document.getElementById("transport").innerHTML = 524 "<img src=\"./http2.png\">"; 525 526 BrowserDetect.init(); 527 528 document.getElementById("brow").textContent = " " + 529 BrowserDetect.browser + " " + BrowserDetect.version + " " + 530 BrowserDetect.OS +" "; 531 532 document.getElementById("number").textContent = 533 get_appropriate_ws_url(mirror_name); 534 535 /* create the ws connections back to the server */ 536 537 ws_open_dumb_increment(); 538 ws_open_status(); 539 ws_open_mirror(); 540 541}, false); 542 543}()); 544