2016-05-04 14:24:30 +01:00

139 lines
4.0 KiB
TypeScript

/**
* @license
* Copyright 2016 Alfresco Software, Ltd.
*
* 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.
*/
import {Injectable} from 'angular2/core';
import {Observable} from 'rxjs/Rx';
import {Http, Headers, URLSearchParams, Response} from 'angular2/http';
declare let xml2json:any;
/**
* The AlfrescoAuthenticationService provide the login service and store the token in the localStorage
*/
@Injectable()
export class AlfrescoAuthenticationService {
token:string;
private _host:string = 'http://192.168.99.100:8080';
private _baseUrl:string = this._host + '/alfresco/service/api/';
/**
* Constructor
* @param http
*/
constructor(public http:Http) {
this.token = localStorage.getItem('token');
}
/**
* The method return tru if the user is logged in
* @returns {boolean}
*/
isLoggedIn() {
return !!localStorage.getItem('token');
}
/**
* Method to delegate GET or POST login
* @param method
* @param username
* @param password
* @returns {Observable<R>|Observable<T>}
*/
login(method:string, username:string, password:string) {
if (method === 'GET') {
return this.loginGet(username, password);
} else if (method === 'POST') {
return this.loginPost(username, password);
} else {
return Observable.throw('Invalid method name the value should be GET or POST');
}
}
/**
* The method provide the login with GET Request
* @param username
* @param password
* @returns {Observable<R>|Observable<T>}
*/
loginGet(username:string, password:string) {
const searchParams = new URLSearchParams();
searchParams.set('u', username);
searchParams.set('pw', password);
return this.http.get(this._baseUrl + 'login', {search: searchParams})
.map((res:any) => {
let data = JSON.parse(xml2json(res.text(), ' '));
this.token = data.ticket;
this.saveJwt(this.token);
})
.catch(this.handleError);
}
/**
* The method provide the login with POST Request
* @param username
* @param password
* @returns {Observable<R>|Observable<T>}
*/
loginPost(username:string, password:string) {
let credentials = '{ username: ' + username + ', password: ' + password + ' }';
let headers = new Headers();
headers.append('Content-Type', 'application/json');
return this.http.post(this._baseUrl + 'login', credentials, {
headers: headers
})
.map((res:any) => {
let response = res.json();
this.token = response.data.ticket;
this.saveJwt(this.token);
})
.catch(this.handleError);
}
/**
* The method save the toke in the localStorage
* @param jwt
*/
saveJwt(jwt) {
if (jwt) {
localStorage.setItem('token', jwt);
}
}
/**
* The method remove the token from the local storage
* @returns {Observable<T>}
*/
logout() {
this.token = undefined;
localStorage.removeItem('token');
return Observable.of(true);
}
/**
* The method write the error in the console browser
* @param error
* @returns {ErrorObservable}
*/
private handleError(error:Response) {
console.error(error.json().message);
return Observable.throw(error.json().message || 'Server error');
}
}