6d04247947
stable
67 lines
2.3 KiB
HTML
Executable file
67 lines
2.3 KiB
HTML
Executable file
<!doctype html>
|
|
<html lang="en">
|
|
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<title>Photoz HTML5 Client</title>
|
|
|
|
<script src="lib/jwt-decode.min.js"></script>
|
|
|
|
<script src="http://localhost:8180/auth/js/keycloak.js"></script>
|
|
<script src="http://localhost:8180/auth/js/keycloak-authz.js"></script>
|
|
</head>
|
|
|
|
<h2>Result</h2>
|
|
<pre style="background-color: #ddd; border: 1px solid #ccc; padding: 10px;" id="output"></pre>
|
|
|
|
<h2>Events</h2>
|
|
<pre style="background-color: #ddd; border: 1px solid #ccc; padding: 10px;" id="events"></pre>
|
|
|
|
|
|
<script>
|
|
function showExpires() {
|
|
if (!keycloak.tokenParsed) {
|
|
output("Not authenticated");
|
|
return;
|
|
}
|
|
|
|
var o = 'Token Expires:\t\t' + new Date((keycloak.tokenParsed.exp + keycloak.timeSkew) * 1000).toLocaleString() + '\n';
|
|
o += 'Token Expires in:\t' + Math.round(keycloak.tokenParsed.exp + keycloak.timeSkew - new Date().getTime() / 1000) + ' seconds\n';
|
|
|
|
if (keycloak.refreshTokenParsed) {
|
|
o += 'Refresh Token Expires:\t' + new Date((keycloak.refreshTokenParsed.exp + keycloak.timeSkew) * 1000).toLocaleString() + '\n';
|
|
o += 'Refresh Expires in:\t' + Math.round(keycloak.refreshTokenParsed.exp + keycloak.timeSkew - new Date().getTime() / 1000) + ' seconds';
|
|
}
|
|
|
|
output(o);
|
|
}
|
|
|
|
function showError() {
|
|
output("Error: " + getParameterByName("error") + "\n" + "Error description: " + getParameterByName("error_description"));
|
|
}
|
|
|
|
function getParameterByName(name, url) {
|
|
if (!url) url = window.location.href;
|
|
name = name.replace(/[\[\]]/g, "\\$&");
|
|
var regex = new RegExp("[?&#]" + name + "(=([^&#]*)|&|#|$)"),
|
|
results = regex.exec(url);
|
|
if (!results) return null;
|
|
if (!results[2]) return '';
|
|
return decodeURIComponent(results[2].replace(/\+/g, " "));
|
|
}
|
|
|
|
function output(data) {
|
|
if (typeof data === 'object') {
|
|
data = JSON.stringify(data, null, ' ');
|
|
}
|
|
document.getElementById('output').innerHTML = data;
|
|
}
|
|
|
|
function event(event) {
|
|
var e = document.getElementById('events').innerHTML;
|
|
document.getElementById('events').innerHTML = new Date().toLocaleString() + "\t" + event + "\n" + e;
|
|
}
|
|
</script>
|
|
|
|
</body>
|
|
</html>
|