2019-09-02 12:18:09 +02:00
|
|
|
import { HttpClient, HttpHeaders } from '@angular/common/http';
|
2019-01-18 18:03:45 +01:00
|
|
|
import { Component, OnInit } from '@angular/core';
|
2019-09-02 12:18:09 +02:00
|
|
|
import { ActivatedRoute, Params } from '@angular/router';
|
2019-12-11 15:51:03 +01:00
|
|
|
import { AuthProvider } from '@app/core/common/enum/auth-provider';
|
|
|
|
import { AuthService } from '@app/core/services/auth/auth.service';
|
|
|
|
import { LoginService } from '@app/ui/auth/login/utilities/login.service';
|
|
|
|
import { BaseComponent } from '@common/base/base.component';
|
|
|
|
import { environment } from 'environments/environment';
|
2019-01-18 18:03:45 +01:00
|
|
|
import { takeUntil } from 'rxjs/operators';
|
|
|
|
|
|
|
|
@Component({
|
|
|
|
selector: 'app-b2access-login',
|
|
|
|
templateUrl: './b2access-login.component.html',
|
|
|
|
})
|
|
|
|
export class B2AccessLoginComponent extends BaseComponent implements OnInit {
|
|
|
|
|
|
|
|
private returnUrl: string;
|
|
|
|
|
|
|
|
constructor(
|
|
|
|
private route: ActivatedRoute,
|
2019-09-02 12:18:09 +02:00
|
|
|
private authService: AuthService,
|
|
|
|
private loginService: LoginService,
|
|
|
|
private httpClient: HttpClient
|
2019-01-18 18:03:45 +01:00
|
|
|
) {
|
|
|
|
super();
|
|
|
|
}
|
|
|
|
|
|
|
|
ngOnInit(): void {
|
|
|
|
this.route.queryParams
|
|
|
|
.pipe(takeUntil(this._destroyed))
|
|
|
|
.subscribe((params: Params) => {
|
|
|
|
const returnUrl = params['returnUrl'];
|
|
|
|
if (returnUrl) { this.returnUrl = returnUrl; }
|
|
|
|
if (!params['code']) { this.b2AccessGetAuthCode(); } else { this.b2AccessLogin(params['code']); }
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
public b2AccessGetAuthCode() {
|
2019-11-14 12:56:09 +01:00
|
|
|
window.location.href = environment.loginProviders.b2accessConfiguration.oauthUrl
|
2019-12-11 15:51:03 +01:00
|
|
|
+ '?response_type=code&client_id=' + environment.loginProviders.b2accessConfiguration.clientId
|
|
|
|
+ '&redirect_uri=' + environment.loginProviders.b2accessConfiguration.redirectUri
|
|
|
|
+ '&state=' + environment.loginProviders.b2accessConfiguration.state
|
|
|
|
+ '&scope=USER_PROFILE';
|
2019-01-18 18:03:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public b2AccessLogin(code: String) {
|
2019-09-02 12:18:09 +02:00
|
|
|
let headers = new HttpHeaders();
|
|
|
|
headers = headers.set('Content-Type', 'application/json');
|
|
|
|
headers = headers.set('Accept', 'application/json');
|
|
|
|
this.httpClient.post(environment.Server + 'auth/b2AccessRequestToken', { code: code }, { headers: headers })
|
|
|
|
.pipe(takeUntil(this._destroyed))
|
|
|
|
.subscribe((data: any) => {
|
|
|
|
this.authService.login({ ticket: data.payload.accessToken, provider: AuthProvider.B2Access, data: null })
|
|
|
|
.pipe(takeUntil(this._destroyed))
|
|
|
|
.subscribe(
|
|
|
|
res => this.loginService.onLogInSuccess(res, this.returnUrl),
|
|
|
|
error => this.loginService.onLogInError(error)
|
|
|
|
);
|
|
|
|
});
|
2019-01-18 18:03:45 +01:00
|
|
|
}
|
|
|
|
}
|