153 lines
11 KiB
JavaScript
153 lines
11 KiB
JavaScript
|
/*
|
||
|
* 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 <http://www.gnu.org/licenses/>.
|
||
|
*
|
||
|
* @category UI interaction
|
||
|
* @package Fun with Binary
|
||
|
* @author Diogo Cordeiro <up201705417@fc.up.pt>
|
||
|
* @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);
|
||
|
}
|