2016-02-03 10:20:22 +00:00
|
|
|
<!--
|
2016-11-25 10:45:40 +00:00
|
|
|
~ Copyright 2016 Red Hat, Inc. and/or its affiliates
|
|
|
|
~ and other contributors as indicated by the @author tags.
|
|
|
|
~
|
|
|
|
~ Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
~ you may not use this file except in compliance with the License.
|
|
|
|
~ You may obtain a copy of the License at
|
|
|
|
~
|
|
|
|
~ http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
~
|
|
|
|
~ Unless required by applicable law or agreed to in writing, software
|
|
|
|
~ distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
~ See the License for the specific language governing permissions and
|
|
|
|
~ limitations under the License.
|
|
|
|
-->
|
2016-02-03 10:20:22 +00:00
|
|
|
|
2016-10-19 10:07:31 +00:00
|
|
|
<html>
|
|
|
|
<body>
|
2016-11-25 10:45:40 +00:00
|
|
|
<script>
|
|
|
|
var init;
|
|
|
|
|
|
|
|
function checkState(clientId, origin, sessionState, callback) {
|
|
|
|
var cookie = getCookie();
|
|
|
|
|
|
|
|
if (!cookie) {
|
|
|
|
callback('changed');
|
|
|
|
} else if (!init) {
|
|
|
|
var req = new XMLHttpRequest(),
|
|
|
|
url = location.href + '/init';
|
2016-10-19 10:07:31 +00:00
|
|
|
|
2016-11-25 10:45:40 +00:00
|
|
|
url += '?client_id=' + encodeURIComponent(clientId);
|
|
|
|
url += '&origin=' + encodeURIComponent(origin);
|
|
|
|
|
|
|
|
req.open('GET', url, true);
|
|
|
|
|
|
|
|
req.onreadystatechange = function () {
|
|
|
|
if (req.readyState === 4) {
|
|
|
|
if (req.status === 204) {
|
|
|
|
init = {
|
|
|
|
clientId: clientId,
|
|
|
|
origin: origin
|
|
|
|
}
|
|
|
|
callback('unchanged');
|
|
|
|
} else if (req.status === 404) {
|
2016-10-20 14:06:51 +00:00
|
|
|
callback('changed');
|
2016-11-25 10:45:40 +00:00
|
|
|
} else {
|
|
|
|
callback('error');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
req.send();
|
|
|
|
} else {
|
|
|
|
if (clientId === init.clientId && origin === init.origin) {
|
|
|
|
if (sessionState === cookie) {
|
|
|
|
callback('unchanged');
|
2016-10-19 10:07:31 +00:00
|
|
|
} else {
|
2016-11-25 10:45:40 +00:00
|
|
|
callback('changed');
|
2016-10-19 10:07:31 +00:00
|
|
|
}
|
2016-11-25 10:45:40 +00:00
|
|
|
} else {
|
|
|
|
callback('error');
|
|
|
|
}
|
2016-10-19 10:07:31 +00:00
|
|
|
}
|
2016-11-25 10:45:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function getCookie() {
|
|
|
|
var name = 'KEYCLOAK_SESSION=',
|
|
|
|
ca = document.cookie.split(';'),
|
|
|
|
i = 0,
|
|
|
|
length = ca.length,
|
|
|
|
c = null;
|
|
|
|
|
|
|
|
for (; i < length; i++) {
|
|
|
|
c = ca[i].trim();
|
|
|
|
if (c.indexOf(name) === 0) return c.substring(name.length, c.length);
|
2015-07-17 11:45:43 +00:00
|
|
|
}
|
2016-11-25 10:45:40 +00:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
function receiveMessage(event) {
|
|
|
|
var origin = event.origin,
|
|
|
|
data = event.data.split(' '),
|
|
|
|
clientId = data[0],
|
|
|
|
sessionState = data[1];
|
|
|
|
|
|
|
|
if (data.length !== 2) {
|
|
|
|
event.source.postMessage('error', origin);
|
2015-07-17 11:45:43 +00:00
|
|
|
}
|
2016-11-25 10:45:40 +00:00
|
|
|
|
|
|
|
checkState(clientId, event.origin, sessionState, function (result) {
|
|
|
|
event.source.postMessage(result, origin);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
window.addEventListener('message', receiveMessage, false);
|
|
|
|
</script>
|
2016-10-19 10:07:31 +00:00
|
|
|
</body>
|
2016-11-25 10:45:40 +00:00
|
|
|
</html>
|