Skip to content

Auto Connect / Auto Login + logo & version display #45

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Open
wants to merge 4 commits into
base: master
Choose a base branch
from
Open
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
webrepl.html - HTML5 saved sessions list + auto login
+ HTML5 localStorage
+ Saved session list via localStorage
+ Ability to connect via session list
+ Individually delete a saved session

[TODO]
Backup list function? Export as JSON?
  • Loading branch information
theredkoala21 authored Apr 4, 2019
commit 26681ed64bc88dab633791e87242f7c20863aef4
148 changes: 130 additions & 18 deletions webrepl.html
Original file line number Diff line number Diff line change
Expand Up @@ -8,19 +8,35 @@
Copyright (c) 2016, Paul Sokolovsky
-->
<style>
html {
html {
background: #555;
}
}

h1 {
h1 {
margin-bottom: 20px;
font: 20px/1.5 sans-serif;
}
.logo {
}
.logo {
position: absolute;
bottom: 10px;
right: 10px;
}
}
ul {
list-style-type: none;
padding: 0;
border: 1px solid #ddd;
}

ul li {
padding: 8px 4px;
border-bottom: 1px solid #ddd;
cursor: pointer;
}

ul li:last-child {
border-bottom: none;
cursor: pointer;
}
/*
.terminal {
float: left;
Expand All @@ -37,11 +53,16 @@
}
*/

.file-box {
.file-box {
margin: 4px;
padding: 4px;
background: #888;
}
}

i.x {
background: url("") no-repeat left center;
padding: 5px 0 5px 25px;
}
</style>
<script src="term.js"></script>
<script src="FileSaver.js"></script>
Expand Down Expand Up @@ -77,6 +98,10 @@

<div class="file-box" id="link-gen" style="margin-top: 20px;"><button onClick='buildLink()'>Generate auto connect / login link</button></div>

<div class="file-box" id="cont-saved-sessions" style="margin-top: 20px;">Saved Sessions: <ul><span id='saved-sessions'></span></ul><br><br>
<button style="vertical-align:bottom;" onClick="addSession()">ADD</button> <button style="vertical-align:bottom;" onClick="resetSessons()">Reset</button>
</div>

</div>

<br clear="both" />
Expand Down Expand Up @@ -104,43 +129,125 @@
var get_file_name = null;
var get_file_data = null;
var version = null;
var jurl = null;
var sessionList = null;

function calculate_size(win) {
var cols = Math.max(80, Math.min(150, (win.innerWidth - 280) / 7)) | 0;
var rows = Math.max(24, Math.min(80, (win.innerHeight - 180) / 12)) | 0;
return [cols, rows];
}

var jurl = null;

function buildLink()
{
var j = {"url":"","pass":"","autoconnect":"True"};
var j = {"url":"","pass":"","autoconnect":true};
j.url = prompt("Enter URL:", document.getElementById('url').value);
j.pass = prompt("Enter Password:");
j.autoconnect = confirm("Enable AutoConnect?");

window.location.hash = JSON.stringify(j);
}

// localStorage.setItem("lastname", "Smith");
function addSession() {
if (typeof(Storage) === "undefined") {
console.error("[ERROR] No localStorage");
return;
}

var j = {"url":"","pass":"","autoconnect":true};
j.url = prompt("Enter URL:", document.getElementById('url').value);
j.pass = prompt("Enter Password:");
j.autoconnect = confirm("Enable AutoConnect?");

if(j.url == null){
alert('[ERROR] URL is empty!');
return;
}

loadSessions();

for (i in sessionList) {
var u = sessionList[i].url;
if(u == j.url) {
alert('Already exists!');
return;
}
}
sessionList.push(j);
localStorage.setItem('sessionList', JSON.stringify(sessionList));

loadSessionList();
}

function resetSessons() {
localStorage.setItem('sessionList', '');
sessionList = null;
document.getElementById('saved-sessions').innerHTML = '';
}

function loadSessions() {
if (typeof(Storage) === "undefined") {
console.error("[ERROR] No localStorage");
return;
}
try {
sessionList = JSON.parse(localStorage.getItem('sessionList'));
} catch(error) {
console.error(error);
if(typeof sessionList === 'undefined' || sessionList === null) {
sessionList = [];
localStorage.setItem('sessionList', JSON.stringify(sessionList));
return;
}
return;
}
return;
}

function loadSessionList() {
var s = document.getElementById('saved-sessions');
s.innerHTML = "";

for (var i in sessionList) {
var tu = sessionList[i].url.replace('ws://','');
s.innerHTML = s.innerHTML + "<li onClick='connectSession(this);' lang='"+i+"'>" + tu + "<span lang='"+i+"' onClick='deleteSession(this);' style='float: right;cursor: pointer;'><i class='x'/></span></li>";
}
}

function connectSession(e) {
console.log('Connecting to: ' + sessionList[e.lang].url);
var s = sessionList[e.lang];


jurl = {"url":s.url,"pass":s.pass,"autoconnect":s.autoconnect};
document.getElementById('url').disabled = true;
document.getElementById('button').value = "Disconnect";
connected = true;
document.getElementById('url').value = jurl.url;
connect(jurl.url);
}

function deleteSession(e) {
sessionList.splice(e.lang, 1);
localStorage.setItem('sessionList', JSON.stringify(sessionList));
loadSessionList();
}

(function() {
window.onload = function() {
try {
jurl = JSON.parse(decodeURI(window.location.hash.substring(1)));
console.log(jurl);

if(jurl.url) {
document.getElementById('url').value = jurl.url;
if(jurl.autoconnect) {
setTimeout(function() { button_click(); }, 100);
}
}

}
catch(error) {
console.log(error);
console.error(error);
console.log("Attempting Alt Method of URL parsing.");
var url = window.location.hash.substring(1);
if (url) {
Expand All @@ -149,8 +256,9 @@
}


loadSessions();
loadSessionList();


var size = calculate_size(self);
term = new Terminal({
cols: size[0],
Expand Down Expand Up @@ -327,22 +435,26 @@
}

function managePasswordReq(data) {
if(typeof data == 'string' && data.indexOf('Password:') > -1 && jsonExists(jurl, 'pass')) {
if(typeof data == 'string' && data.indexOf('Password:') > -1 && jsonKeyExists(jurl, 'pass')) {
term.write('\x1b[36mAttempting AutoLogin\x1b[m\r\n');
term.send(jurl.pass + "\r");
}
}

function jsonExists(pri, key) {
function jsonKeyExists(pri, key) {
if(typeof pri === 'undefined' || pri === null) {
return false;
}else{
}else {
if(jurl.hasOwnProperty(key)) {
return true;
}
}
}

function jsonExists(pri) {
if(typeof pri === 'undefined' || pri === null) { return false; }else { return true; }
}

function decode_resp(data) {
if (data[0] == 'W'.charCodeAt(0) && data[1] == 'B'.charCodeAt(0)) {
var code = data[2] | (data[3] << 8);
Expand Down