diff options
| author | Tom Smeding <tom@tomsmeding.com> | 2022-02-03 10:13:46 +0100 | 
|---|---|---|
| committer | Tom Smeding <tom@tomsmeding.com> | 2022-02-03 10:13:46 +0100 | 
| commit | d601d0431d6a35ce55680af9987c2ecfee719870 (patch) | |
| tree | 8698dc4cbf764f89bf3cdab6eaa71f03df8e5b5a /modules/timetrack/unknownuser.html | |
| parent | 38b2f19f563d560be208b0c8f53bc7b6630c0436 (diff) | |
timetrack: Initial
Diffstat (limited to 'modules/timetrack/unknownuser.html')
| -rw-r--r-- | modules/timetrack/unknownuser.html | 87 | 
1 files changed, 87 insertions, 0 deletions
| diff --git a/modules/timetrack/unknownuser.html b/modules/timetrack/unknownuser.html new file mode 100644 index 0000000..8911520 --- /dev/null +++ b/modules/timetrack/unknownuser.html @@ -0,0 +1,87 @@ +<!DOCTYPE html> +<html> +<head> +<meta charset="utf-8"> +<title>TimeTrack: Unknown user</title> +<script> +"use strict"; + +function fetch(method,url,data/*?*/,creds/*?*/,cb){ +	if(!creds){ +		cb=data; +		data=undefined; +		creds=undefined; +	} else if(!cb){ +		cb=creds; +		creds=undefined; +	} +	if(!cb)throw new Error("No callback passed to fetch"); +	var xhr=new XMLHttpRequest(); +	xhr.onreadystatechange=function(ev){ +		if(xhr.readyState<4)return; +		cb(xhr.status,xhr.responseText); +	}; +	if(creds){ +		xhr.open(method,url,true,creds[0],creds[1]); +	} else { +		xhr.open(method,url); +	} +	xhr.send(data); +} + +function asciiValid(str){ +	var i,c; +	for(i=0;i<str.length;i++){ +		c=str.charCodeAt(i); +		if(c<32||c>=127)return false; +	} +	return true; +} + +function logoutReload(){ +	fetch("GET","/timetrack/authfail",undefined,["baduser","badpass"],function(status,body){ +		location.href=location.href; +	}); +} + +function doCreateUser(){ +	var username=document.getElementById("username").value; +	var password=document.getElementById("password").value; +	var fail; +	[["Username",username],["Password",password]].forEach(function(name,value){ +		fail=true; +		if(value.length<3)alert(name+" too short!"); +		else if(value.length>32)alert(name+" too long!"); +		else if(!asciiValid(value))alert("Invalid "+name.toLowerCase()+"! Please use only ASCII characters."); +		else fail=false; +	}); +	if(fail)return; + +	fetch("POST","/timetrack/createuser",undefined,[username,password],function(status,body){ +		if(status==200){ +			alert("User \""+username+"\" created successfully. Please login."); +			logoutReload(); +		} else { +			alert("Error: "+body); +		} +	}); +} +</script> +<style> +body{ +	font-family:Georgia,Times,serif; +	font-size:14px; +} +</style> +</head> +<body> +<h1>TimeTrack: Unknown user</h1> +<p>The user you entered is not known in the system. You can use the form below to create a new user. +Be aware: this system is not secure.</p> +Username: <input type="text" id="username" placeholder="username"><br> +Password: <input type="password" id="password" placeholder="password"><br> +<input type="button" value="Create user" onclick="doCreateUser();"> +<br><br> +<p>You can also <input type="button" onclick="logoutReload();" value="log out and try again"> if you just can't type.</p> +</body> +</html> | 
