KEYCLOAK-1082

Make sure session is valid if keycloak.js is initialized with tokens
This commit is contained in:
Stian Thorgersen 2015-03-05 07:42:13 +01:00
parent 8dea0d50ee
commit 4cb3d51781

View file

@ -50,14 +50,7 @@
var configPromise = loadConfig(config); var configPromise = loadConfig(config);
function processInit() { function onLoad() {
var callback = parseCallback(window.location.href);
if (callback) {
window.history.replaceState({}, null, callback.newUrl);
processCallback(callback, initPromise);
return;
} else if (initOptions) {
var doLogin = function(prompt) { var doLogin = function(prompt) {
if (!prompt) { if (!prompt) {
options.prompt = 'none'; options.prompt = 'none';
@ -69,10 +62,6 @@
}); });
} }
if (initOptions.token || initOptions.refreshToken) {
setToken(initOptions.token, initOptions.refreshToken, initOptions.idToken);
initPromise.setSuccess();
} else if (initOptions.onLoad) {
var options = {}; var options = {};
switch (initOptions.onLoad) { switch (initOptions.onLoad) {
case 'check-sso': case 'check-sso':
@ -95,6 +84,35 @@
throw 'Invalid value for onLoad'; throw 'Invalid value for onLoad';
} }
} }
function processInit() {
var callback = parseCallback(window.location.href);
if (callback) {
setupCheckLoginIframe();
window.history.replaceState({}, null, callback.newUrl);
processCallback(callback, initPromise);
return;
} else if (initOptions) {
if (initOptions.token || initOptions.refreshToken) {
setToken(initOptions.token, initOptions.refreshToken, initOptions.idToken);
if (loginIframe.enable) {
setupCheckLoginIframe().success(function() {
checkLoginIframe().success(function () {
initPromise.setSuccess();
}).error(function () {
if (initOptions.onLoad) {
onLoad();
}
});
});
} else {
initPromise.setSuccess();
}
} else if (initOptions.onLoad) {
onLoad();
}
} else { } else {
initPromise.setSuccess(); initPromise.setSuccess();
} }
@ -122,8 +140,13 @@
sessionStorage.oauthState = JSON.stringify({ state: state, redirectUri: encodeURIComponent(redirectUri) }); sessionStorage.oauthState = JSON.stringify({ state: state, redirectUri: encodeURIComponent(redirectUri) });
var action = 'login';
if (options && options.action == 'register') {
action = 'registrations';
}
var url = getRealmUrl() var url = getRealmUrl()
+ '/protocol/openid-connect/login' + '/protocol/openid-connect/' + action
+ '?client_id=' + encodeURIComponent(kc.clientId) + '?client_id=' + encodeURIComponent(kc.clientId)
+ '&redirect_uri=' + encodeURIComponent(redirectUri) + '&redirect_uri=' + encodeURIComponent(redirectUri)
+ '&state=' + encodeURIComponent(state) + '&state=' + encodeURIComponent(state)
@ -451,10 +474,6 @@
} }
function setToken(token, refreshToken, idToken) { function setToken(token, refreshToken, idToken) {
if (token || refreshToken) {
setupCheckLoginIframe();
}
if (token) { if (token) {
kc.token = token; kc.token = token;
kc.tokenParsed = decodeToken(token); kc.tokenParsed = decodeToken(token);
@ -633,15 +652,17 @@
var promise = createPromise(); var promise = createPromise();
if (!loginIframe.enable) { if (!loginIframe.enable) {
return; promise.setSuccess();
return promise.promise;
} }
if (loginIframe.iframe) { if (loginIframe.iframe) {
promise.setSuccess(); promise.setSuccess();
return; return promise.promise;
} }
var iframe = document.createElement('iframe'); var iframe = document.createElement('iframe');
loginIframe.iframe = iframe;
iframe.onload = function() { iframe.onload = function() {
var realmUrl = getRealmUrl(); var realmUrl = getRealmUrl();
@ -650,8 +671,9 @@
} else { } else {
loginIframe.iframeOrigin = realmUrl.substring(0, realmUrl.indexOf('/', 8)); loginIframe.iframeOrigin = realmUrl.substring(0, realmUrl.indexOf('/', 8));
} }
loginIframe.iframe = iframe;
promise.setSuccess(); promise.setSuccess();
setTimeout(check, loginIframe.interval * 1000);
} }
var src = getRealmUrl() + '/protocol/openid-connect/login-status-iframe.html?client_id=' + encodeURIComponent(kc.clientId) + '&origin=' + getOrigin(); var src = getRealmUrl() + '/protocol/openid-connect/login-status-iframe.html?client_id=' + encodeURIComponent(kc.clientId) + '&origin=' + getOrigin();
@ -683,8 +705,6 @@
} }
}; };
setTimeout(check, loginIframe.interval * 1000);
return promise.promise; return promise.promise;
} }