This repository has been archived on 2023-08-20. You can view files and clone it, but cannot push or open issues or pull requests.
fun-with-binary/auth/script.js
Diogo Cordeiro 1c59afa216 Special MostraUP release: Add Authentication
Translated interface to portuguese as this is a portuguese event
2019-03-22 16:35:03 +00:00

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);
}