Mercurial > hg > thermostat-ng > web-client
view src/app/components/auth/keycloak-auth.service.ts @ 257:f13e9da11350
Port authServices to TypeScript, upgrade for Angular 4
Reviewed-by: jkang
Review-thread: http://icedtea.classpath.org/pipermail/thermostat/2017-October/025463.html
author | Andrew Azores <aazores@redhat.com> |
---|---|
date | Fri, 20 Oct 2017 16:16:16 -0400 |
parents | src/app/components/auth/keycloak-auth.service.js@8f116d9b0130 |
children |
line wrap: on
line source
/** * Copyright 2012-2017 Red Hat, Inc. * * Thermostat is distributed under the GNU General Public License, * version 2 or any later version (with a special exception described * below, commonly known as the "Classpath Exception"). * * A copy of GNU General Public License (GPL) is included in this * distribution, in the file COPYING. * * Linking Thermostat code with other modules is making a combined work * based on Thermostat. Thus, the terms and conditions of the GPL * cover the whole combination. * * As a special exception, the copyright holders of Thermostat give you * permission to link this code with independent modules to produce an * executable, regardless of the license terms of these independent * modules, and to copy and distribute the resulting executable under * terms of your choice, provided that you also meet, for each linked * independent module, the terms and conditions of the license of that * module. An independent module is a module which is not derived from * or based on Thermostat code. If you modify Thermostat, you may * extend this exception to your version of the software, but you are * not obligated to do so. If you do not wish to do so, delete this * exception statement from your version. */ import * as angular from "angular"; import * as url from "url"; import { IAuthService } from "./auth-service.interface"; export class KeycloakAuthService implements IAuthService { private scope: ng.IRootScopeService; public constructor(private keycloak: any) { } public set rootScope(rootScope: ng.IRootScopeService) { this.scope = rootScope; } public login(): void { // no-op } public goToLogin(promise: ng.IDeferred<{}>): void { this.keycloak.login(); this.scope.$broadcast("userLoginChanged"); promise.resolve(); } public logout(callback = angular.noop): void { this.scope.$broadcast("userLoginChanged"); this.keycloak.logout(); callback(); } public status(): boolean { return this.keycloak.authenticated; } public refresh(): ng.IPromise<{}> { // refresh the token if it expires within 300 seconds return this.keycloak.updateToken(300); } public get authHeader(): string { return "Bearer " + this.keycloak.token; } public get username(): string { return this.keycloak.idTokenParsed.preferred_username; } public getCommandChannelUrl(baseUrl: string): string { const parsed = url.parse(baseUrl); parsed.query = { access_token: this.keycloak.token }; return url.format(parsed); } }