From d4060cce9202c83b08cf812a9d044aa0fb99f363 Mon Sep 17 00:00:00 2001 From: Stian Thorgersen Date: Fri, 9 Oct 2015 09:44:00 +0200 Subject: [PATCH] KEYCLOAK-1876 Some admin console pages don't load properly when accessed via URL --- .../theme/base/admin/resources/js/app.js | 47 +++++++++++++++-- .../admin/resources/js/controllers/realm.js | 51 +++++-------------- .../theme/base/admin/resources/js/services.js | 4 -- 3 files changed, 57 insertions(+), 45 deletions(-) diff --git a/forms/common-themes/src/main/resources/theme/base/admin/resources/js/app.js b/forms/common-themes/src/main/resources/theme/base/admin/resources/js/app.js index 8af3ef8d0f..92a1702725 100755 --- a/forms/common-themes/src/main/resources/theme/base/admin/resources/js/app.js +++ b/forms/common-themes/src/main/resources/theme/base/admin/resources/js/app.js @@ -14,16 +14,57 @@ var loadingTimer = -1; angular.element(document).ready(function () { var keycloakAuth = new Keycloak(configUrl); + function whoAmI(success, error) { + var req = new XMLHttpRequest(); + req.open('GET', consoleBaseUrl + "/whoami", true); + req.setRequestHeader('Accept', 'application/json'); + req.setRequestHeader('Authorization', 'bearer ' + keycloakAuth.token); + + req.onreadystatechange = function () { + if (req.readyState == 4) { + if (req.status == 200) { + var data = JSON.parse(req.responseText); + success(data); + } else { + error(); + } + } + } + + req.send(); + } + + function hasAnyAccess(user) { + return user && user['realm_access']; + } + keycloakAuth.onAuthLogout = function() { location.reload(); } keycloakAuth.init({ onLoad: 'login-required' }).success(function () { auth.authz = keycloakAuth; - module.factory('Auth', function() { - return auth; + + auth.refreshPermissions = function(success, error) { + whoAmI(function(data) { + auth.user = data; + auth.loggedIn = true; + auth.hasAnyAccess = hasAnyAccess(data); + + success(); + }, function() { + error(); + }); + }; + + auth.refreshPermissions(function() { + module.factory('Auth', function() { + return auth; + }); + angular.bootstrap(document, ["keycloak"]); + }, function() { + window.location.reload(); }); - angular.bootstrap(document, ["keycloak"]); }).error(function () { window.location.reload(); }); diff --git a/forms/common-themes/src/main/resources/theme/base/admin/resources/js/controllers/realm.js b/forms/common-themes/src/main/resources/theme/base/admin/resources/js/controllers/realm.js index 15dc6793ec..d100df752a 100755 --- a/forms/common-themes/src/main/resources/theme/base/admin/resources/js/controllers/realm.js +++ b/forms/common-themes/src/main/resources/theme/base/admin/resources/js/controllers/realm.js @@ -1,31 +1,9 @@ -module.controller('GlobalCtrl', function($scope, $http, Auth, WhoAmI, Current, $location, Notifications, ServerInfo) { - $scope.addMessage = function() { - Notifications.success("test"); - }; - +module.controller('GlobalCtrl', function($scope, $http, Auth, Current, $location, Notifications, ServerInfo) { $scope.authUrl = authUrl; $scope.resourceUrl = resourceUrl; $scope.auth = Auth; $scope.serverInfo = ServerInfo.get(); - function hasAnyAccess() { - var realmAccess = Auth.user && Auth.user['realm_access']; - if (realmAccess) { - for (var p in realmAccess){ - return true; - } - return false; - } else { - return false; - } - } - - WhoAmI.get(function (data) { - Auth.user = data; - Auth.loggedIn = true; - Auth.hasAnyAccess = hasAnyAccess(); - }); - function getAccess(role) { if (!Current.realm) { return false; @@ -155,7 +133,7 @@ module.controller('RealmDropdownCtrl', function($scope, Realm, Current, Auth, $l } }); -module.controller('RealmCreateCtrl', function($scope, Current, Realm, $upload, $http, WhoAmI, $location, $route, Dialog, Notifications, Auth, $modal) { +module.controller('RealmCreateCtrl', function($scope, Current, Realm, $upload, $http, $location, $route, Dialog, Notifications, Auth, $modal) { console.log('RealmCreateCtrl'); Current.realm = null; @@ -193,22 +171,17 @@ module.controller('RealmCreateCtrl', function($scope, Current, Realm, $upload, $ }, true); $scope.$watch('realm.realm', function() { - if (create) { $scope.realm.id = $scope.realm.realm; - } }, true); $scope.save = function() { var realmCopy = angular.copy($scope.realm); Realm.create(realmCopy, function() { - Realm.query(function(data) { - Current.realms = data; - - WhoAmI.get(function(user) { - Auth.user = user; + Notifications.success("The realm has been created."); + Auth.refreshPermissions(function() { + $scope.$apply(function() { $location.url("/realms/" + realmCopy.realm); - Notifications.success("The realm has been created."); }); }); }); @@ -227,7 +200,7 @@ module.controller('ObjectModalCtrl', function($scope, object) { $scope.object = object; }); -module.controller('RealmDetailCtrl', function($scope, Current, Realm, realm, serverInfo, $http, $location, Dialog, Notifications, WhoAmI, Auth) { +module.controller('RealmDetailCtrl', function($scope, Current, Realm, realm, serverInfo, $http, $location, Dialog, Notifications, Auth) { $scope.createRealm = !realm.realm; $scope.serverInfo = serverInfo; @@ -272,11 +245,13 @@ module.controller('RealmDetailCtrl', function($scope, Current, Realm, realm, ser }); if (nameChanged) { - WhoAmI.get(function(user) { - Auth.user = user; - - $location.url("/realms/" + realmCopy.realm); - Notifications.success("Your changes have been saved to the realm."); + Auth.refreshPermissions(function() { + Auth.refreshPermissions(function() { + Notifications.success("Your changes have been saved to the realm."); + $scope.$apply(function() { + $location.url("/realms/" + realmCopy.realm); + }); + }); }); } else { $location.url("/realms/" + realmCopy.realm); diff --git a/forms/common-themes/src/main/resources/theme/base/admin/resources/js/services.js b/forms/common-themes/src/main/resources/theme/base/admin/resources/js/services.js index 03f4b994cb..b92fd83648 100755 --- a/forms/common-themes/src/main/resources/theme/base/admin/resources/js/services.js +++ b/forms/common-themes/src/main/resources/theme/base/admin/resources/js/services.js @@ -184,10 +184,6 @@ module.factory('Notifications', function($rootScope, $timeout) { return notifications; }); -module.factory('WhoAmI', function($resource) { - return $resource(consoleBaseUrl + '/whoami'); -}); - module.factory('Realm', function($resource) { return $resource(authUrl + '/admin/realms/:id', { id : '@realm'