/* * Fun with Binary - a fun way of introducing binary * Copyright (C) 2018, Diogo Cordeiro. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . * * @category UI interaction * @package Fun with Binary * @author Diogo Cordeiro * @copyright 2018 Diogo Cordeiro. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 * @link https://www.diogo.site/projects/fun_with_binary/ */ /*********************************** * EXTEND JAVASCRIPT FUNCTIONALITY * ***********************************/ /** * Returns a random integer between min (inclusive) and max (inclusive) * Using Math.round() would give a non-uniform distribution! */ function getRandomInt (min, max) { return Math.floor(Math.random() * (max - min + 1)) + min; } /** * Replace char at given position */ String.prototype.replaceAt=function(index, replacement) { return this.substr(0, index) + replacement+ this.substr(index + replacement.length); } /** * Checks if session storage is available */ function is_session_storage_available () { return window.sessionStorage != null; } //*********************************** /*********************************** * GAME SETTINGS * ***********************************/ // Box IP let URL = "http://42.42.42.42/"; // Number of leds let NLEDS = 6; // ON and OFF leds srcs let LED_OFF = ""; let LED_ON = ""; //*********************************** /********************************** * ACTUAL GAME * **********************************/ /** * Global variables */ // Empty Answer empty_answer = ''; while (empty_answer.length < NLEDS) { empty_answer += '0'; } // current answer current_answer = empty_answer; /** * Create leds */ for (let i = 0; i < NLEDS; ++i) { // Led holder let figure = document.createElement ("figure"); figure.setAttribute ("class", "box"); // Led let img = document.createElement ("img"); img.src = LED_OFF; img.setAttribute ("value", "OFF"); img.id = "led" + i; img.setAttribute ("class", "led"); img.setAttribute ("onclick", "switch_led("+i+")"); figure.appendChild (img); document.getElementById("leds").appendChild(figure); } /** * Turn current answer bits accordingly */ function switch_led (led_id) { let image = document.getElementById("led"+led_id); if (image.getAttribute("value") == "ON") { image.setAttribute ("value", "OFF"); image.src = LED_OFF; current_answer = current_answer.replaceAt(led_id, "0"); } else { image.setAttribute ("value", "ON"); image.src = LED_ON; current_answer = current_answer.replaceAt(led_id, "1"); } } function submit_auth_form () { let xhttp = new XMLHttpRequest(); xhttp.onreadystatechange = function() { if (this.readyState == 4 && this.status == 200) { if (this.responseText == "ok") window.location.replace (URL+"game"); else alert (this.responseText); } }; xhttp.open("POST", URL+"auth", true); xhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); sessionStorage.token=getRandomInt (42, 31337) xhttp.send("password="+current_answer+"&token="+sessionStorage.token); }