verben-authentication-ui 0.3.8 → 0.3.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/auth-callback/auth-callback.component.mjs +48 -0
- package/esm2022/lib/components/auth-callback/auth-callback.module.mjs +18 -0
- package/esm2022/lib/components/o-auth/o-auth.component.mjs +53 -81
- package/esm2022/lib/components/sign-in/sign-in.component.mjs +103 -35
- package/esm2022/lib/components/sign-up/sign-up.component.mjs +1 -1
- package/esm2022/lib/components/user-management/user-management.component.mjs +2 -2
- package/esm2022/lib/components/user-request/user-request.component.mjs +58 -61
- package/esm2022/lib/components/user-request-approval/user-request-approval.component.mjs +2 -2
- package/esm2022/lib/models/UserRequest.mjs +1 -1
- package/esm2022/lib/models/log-in.mjs +1 -1
- package/esm2022/lib/models/oauth-response.mjs +2 -0
- package/esm2022/lib/services/http-web-request.service.mjs +1 -2
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/verben-authentication-ui.mjs +271 -174
- package/fesm2022/verben-authentication-ui.mjs.map +1 -1
- package/lib/components/auth-callback/auth-callback.component.d.ts +17 -0
- package/lib/components/auth-callback/auth-callback.module.d.ts +8 -0
- package/lib/components/o-auth/o-auth.component.d.ts +10 -18
- package/lib/components/sign-in/sign-in.component.d.ts +17 -5
- package/lib/components/user-request/user-request.component.d.ts +6 -5
- package/lib/models/UserRequest.d.ts +2 -0
- package/lib/models/log-in.d.ts +1 -0
- package/lib/models/oauth-response.d.ts +6 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/router";
|
|
4
|
+
export class AuthCallbackComponent {
|
|
5
|
+
router;
|
|
6
|
+
code = '';
|
|
7
|
+
previousUrl = '';
|
|
8
|
+
redirectText;
|
|
9
|
+
width = 40;
|
|
10
|
+
height = 40;
|
|
11
|
+
color = 'black';
|
|
12
|
+
constructor(router) {
|
|
13
|
+
this.router = router;
|
|
14
|
+
}
|
|
15
|
+
ngOnInit() {
|
|
16
|
+
this.handleRedirect();
|
|
17
|
+
}
|
|
18
|
+
handleRedirect() {
|
|
19
|
+
const params = new URLSearchParams(window.location.search);
|
|
20
|
+
const code = params.get('code');
|
|
21
|
+
const stateParam = params.get('state');
|
|
22
|
+
if (code && stateParam) {
|
|
23
|
+
try {
|
|
24
|
+
const state = JSON.parse(decodeURIComponent(stateParam));
|
|
25
|
+
const returnTo = state.returnTo || '/';
|
|
26
|
+
this.router.navigate([returnTo], { queryParams: { code } });
|
|
27
|
+
}
|
|
28
|
+
catch (e) {
|
|
29
|
+
const msg = e;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AuthCallbackComponent, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Component });
|
|
34
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: AuthCallbackComponent, selector: "verben-auth-callback", inputs: { redirectText: "redirectText", width: "width", height: "height", color: "color" }, ngImport: i0, template: "<section class=\"wrapper\"> \n <div class=\"flexWrapper\"> \n <p class=\"{{redirectText}}\">Redirecting ...</p>\n <div class=\"loader\"></div>\n </div>\n</section>", styles: [".wrapper{width:100%;min-height:100%;display:flex;align-items:center;justify-content:center}.flexWrapper{display:flex;align-items:center;justify-content:center}.loader{border:2px solid white;border-radius:50%;border-top:2px solid black;width:40px;height:40px;-webkit-animation:spin 2s linear infinite;animation:spin 2s linear infinite}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg)}to{-webkit-transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"] });
|
|
35
|
+
}
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AuthCallbackComponent, decorators: [{
|
|
37
|
+
type: Component,
|
|
38
|
+
args: [{ selector: 'verben-auth-callback', template: "<section class=\"wrapper\"> \n <div class=\"flexWrapper\"> \n <p class=\"{{redirectText}}\">Redirecting ...</p>\n <div class=\"loader\"></div>\n </div>\n</section>", styles: [".wrapper{width:100%;min-height:100%;display:flex;align-items:center;justify-content:center}.flexWrapper{display:flex;align-items:center;justify-content:center}.loader{border:2px solid white;border-radius:50%;border-top:2px solid black;width:40px;height:40px;-webkit-animation:spin 2s linear infinite;animation:spin 2s linear infinite}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg)}to{-webkit-transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"] }]
|
|
39
|
+
}], ctorParameters: () => [{ type: i1.Router }], propDecorators: { redirectText: [{
|
|
40
|
+
type: Input
|
|
41
|
+
}], width: [{
|
|
42
|
+
type: Input
|
|
43
|
+
}], height: [{
|
|
44
|
+
type: Input
|
|
45
|
+
}], color: [{
|
|
46
|
+
type: Input
|
|
47
|
+
}] } });
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC1jYWxsYmFjay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4tYXV0aGVudGljYXRpb24tdWkvc3JjL2xpYi9jb21wb25lbnRzL2F1dGgtY2FsbGJhY2svYXV0aC1jYWxsYmFjay5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4tYXV0aGVudGljYXRpb24tdWkvc3JjL2xpYi9jb21wb25lbnRzL2F1dGgtY2FsbGJhY2svYXV0aC1jYWxsYmFjay5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQzs7O0FBUXpELE1BQU0sT0FBTyxxQkFBcUI7SUFTWjtJQVJwQixJQUFJLEdBQVcsRUFBRSxDQUFDO0lBQ2xCLFdBQVcsR0FBVyxFQUFFLENBQUM7SUFDaEIsWUFBWSxDQUFTO0lBQ3JCLEtBQUssR0FBVSxFQUFFLENBQUM7SUFDbEIsTUFBTSxHQUFVLEVBQUUsQ0FBQztJQUNuQixLQUFLLEdBQVUsT0FBTyxDQUFDO0lBR2hDLFlBQW9CLE1BQWM7UUFBZCxXQUFNLEdBQU4sTUFBTSxDQUFRO0lBQUcsQ0FBQztJQUV0QyxRQUFRO1FBQ04sSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFRCxjQUFjO1FBQ1osTUFBTSxNQUFNLEdBQUcsSUFBSSxlQUFlLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMzRCxNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ2hDLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFdkMsSUFBSSxJQUFJLElBQUksVUFBVSxFQUFFLENBQUM7WUFDdkIsSUFBSSxDQUFDO2dCQUNILE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsa0JBQWtCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztnQkFDekQsTUFBTSxRQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsSUFBSSxHQUFHLENBQUM7Z0JBQ3ZDLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsRUFBRSxXQUFXLEVBQUUsRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDOUQsQ0FBQztZQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7Z0JBQ1osTUFBTSxHQUFHLEdBQUcsQ0FBQyxDQUFBO1lBQ2QsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO3dHQTdCVSxxQkFBcUI7NEZBQXJCLHFCQUFxQix3SkNSbEMseUxBS1U7OzRGREdHLHFCQUFxQjtrQkFMakMsU0FBUzsrQkFDRSxzQkFBc0I7MkVBT3ZCLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFjdGl2YXRlZFJvdXRlLCBSb3V0ZXIgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2ZXJiZW4tYXV0aC1jYWxsYmFjaycsXG4gIHRlbXBsYXRlVXJsOiAnLi9hdXRoLWNhbGxiYWNrLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL2F1dGgtY2FsbGJhY2suY29tcG9uZW50LmNzcydcbn0pXG5leHBvcnQgY2xhc3MgQXV0aENhbGxiYWNrQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgY29kZTogc3RyaW5nID0gJyc7XG4gIHByZXZpb3VzVXJsOiBzdHJpbmcgPSAnJztcbiAgQElucHV0KCkgcmVkaXJlY3RUZXh0PzpzdHJpbmc7XG4gIEBJbnB1dCgpIHdpZHRoOm51bWJlciA9IDQwO1xuICBASW5wdXQoKSBoZWlnaHQ6bnVtYmVyID0gNDA7XG4gIEBJbnB1dCgpIGNvbG9yOnN0cmluZyA9ICdibGFjayc7XG4gIFxuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcm91dGVyOiBSb3V0ZXIpIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5oYW5kbGVSZWRpcmVjdCgpO1xuICB9XG5cbiAgaGFuZGxlUmVkaXJlY3QoKSB7XG4gICAgY29uc3QgcGFyYW1zID0gbmV3IFVSTFNlYXJjaFBhcmFtcyh3aW5kb3cubG9jYXRpb24uc2VhcmNoKTtcbiAgICBjb25zdCBjb2RlID0gcGFyYW1zLmdldCgnY29kZScpO1xuICAgIGNvbnN0IHN0YXRlUGFyYW0gPSBwYXJhbXMuZ2V0KCdzdGF0ZScpO1xuXG4gICAgaWYgKGNvZGUgJiYgc3RhdGVQYXJhbSkge1xuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc3Qgc3RhdGUgPSBKU09OLnBhcnNlKGRlY29kZVVSSUNvbXBvbmVudChzdGF0ZVBhcmFtKSk7XG4gICAgICAgIGNvbnN0IHJldHVyblRvID0gc3RhdGUucmV0dXJuVG8gfHwgJy8nO1xuICAgICAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZShbcmV0dXJuVG9dLCB7IHF1ZXJ5UGFyYW1zOiB7IGNvZGUgfSB9KTtcbiAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICBjb25zdCBtc2cgPSBlXG4gICAgICB9XG4gICAgfVxuICB9XG59XG4iLCI8c2VjdGlvbiBjbGFzcz1cIndyYXBwZXJcIj4gXG4gICAgPGRpdiBjbGFzcz1cImZsZXhXcmFwcGVyXCI+IFxuICAgICAgICA8cCBjbGFzcz1cInt7cmVkaXJlY3RUZXh0fX1cIj5SZWRpcmVjdGluZyAuLi48L3A+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJsb2FkZXJcIj48L2Rpdj5cbiAgICA8L2Rpdj5cbjwvc2VjdGlvbj4iXX0=
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { AuthCallbackComponent } from './auth-callback.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class AuthCallbackModule {
|
|
6
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AuthCallbackModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
7
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: AuthCallbackModule, declarations: [AuthCallbackComponent], imports: [CommonModule], exports: [AuthCallbackComponent] });
|
|
8
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AuthCallbackModule, imports: [CommonModule] });
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AuthCallbackModule, decorators: [{
|
|
11
|
+
type: NgModule,
|
|
12
|
+
args: [{
|
|
13
|
+
declarations: [AuthCallbackComponent],
|
|
14
|
+
imports: [CommonModule],
|
|
15
|
+
exports: [AuthCallbackComponent]
|
|
16
|
+
}]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC1jYWxsYmFjay5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4tYXV0aGVudGljYXRpb24tdWkvc3JjL2xpYi9jb21wb25lbnRzL2F1dGgtY2FsbGJhY2svYXV0aC1jYWxsYmFjay5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7O0FBT2xFLE1BQU0sT0FBTyxrQkFBa0I7d0dBQWxCLGtCQUFrQjt5R0FBbEIsa0JBQWtCLGlCQUpkLHFCQUFxQixhQUMxQixZQUFZLGFBQ1oscUJBQXFCO3lHQUVwQixrQkFBa0IsWUFIbkIsWUFBWTs7NEZBR1gsa0JBQWtCO2tCQUw5QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHFCQUFxQixDQUFDO29CQUNyQyxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQ3ZCLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO2lCQUNqQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQXV0aENhbGxiYWNrQ29tcG9uZW50IH0gZnJvbSAnLi9hdXRoLWNhbGxiYWNrLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW0F1dGhDYWxsYmFja0NvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICBleHBvcnRzOiBbQXV0aENhbGxiYWNrQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBBdXRoQ2FsbGJhY2tNb2R1bGUge30iXX0=
|
|
@@ -1,79 +1,41 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
2
|
import { MechanismType } from '../../models/auth-mechanism';
|
|
3
|
-
import { ErrorResponse } from '../../models/ErrorResponse';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
4
|
import * as i1 from "@angular/router";
|
|
6
5
|
import * as i2 from "../../services/http-web-request.service";
|
|
7
6
|
import * as i3 from "../../services/util.service";
|
|
8
|
-
import * as i4 from "
|
|
9
|
-
import * as i5 from "
|
|
10
|
-
import * as i6 from "verben-ng-ui";
|
|
7
|
+
import * as i4 from "@angular/common";
|
|
8
|
+
import * as i5 from "verben-ng-ui";
|
|
11
9
|
export class OAuthComponent {
|
|
12
10
|
route;
|
|
13
11
|
server;
|
|
14
12
|
utilService;
|
|
15
|
-
|
|
16
|
-
clientId = 'YOUR_CLIENT_ID_FROM_BACKEND';
|
|
13
|
+
router;
|
|
17
14
|
showGoogle = false;
|
|
18
15
|
showMicrosoft = false;
|
|
19
16
|
showApple = false;
|
|
20
17
|
authMechanisms = null;
|
|
21
|
-
redirectUri = 'http://localhost:4200/documentation/login';
|
|
22
|
-
apiKey;
|
|
23
18
|
microsoftClick = new EventEmitter();
|
|
24
|
-
onSubmitGoogleAuth = new EventEmitter();
|
|
25
19
|
googleClick = new EventEmitter();
|
|
26
20
|
appleClick = new EventEmitter();
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
constructor(route, server, utilService, envSvc) {
|
|
21
|
+
page = '';
|
|
22
|
+
constructor(route, server, utilService, router) {
|
|
30
23
|
this.route = route;
|
|
31
24
|
this.server = server;
|
|
32
25
|
this.utilService = utilService;
|
|
33
|
-
this.
|
|
26
|
+
this.router = router;
|
|
34
27
|
}
|
|
35
28
|
ngOnInit() {
|
|
29
|
+
this.loadPage();
|
|
36
30
|
this.loadGoogleScript();
|
|
37
|
-
this.route.queryParams.subscribe(params => {
|
|
38
|
-
this.code = params['code'];
|
|
39
|
-
});
|
|
40
|
-
if (this.code) {
|
|
41
|
-
console.log('Code from URL:', this.code);
|
|
42
|
-
this.verifyUserDetails();
|
|
43
|
-
}
|
|
44
31
|
if (this.authMechanisms !== null) {
|
|
45
|
-
this.
|
|
46
|
-
this.showGoogle = this.authMechanisms.some(item => item.AuthMechanism.includes(MechanismType.Google));
|
|
47
|
-
if (this.showGoogle) {
|
|
48
|
-
const data = this.authMechanisms.find(item => item.AuthMechanism.includes(MechanismType.Google));
|
|
49
|
-
this.clientId = data?.ClientId;
|
|
50
|
-
this.googleRedirectUrl = data?.RedirectUri;
|
|
51
|
-
}
|
|
52
|
-
this.showApple = this.authMechanisms.some(item => item.AuthMechanism.includes(MechanismType.Apple));
|
|
32
|
+
this.authMechanisms = this.authMechanisms.filter((item) => item.AuthMechanism !== MechanismType.InApp);
|
|
53
33
|
}
|
|
54
34
|
}
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
const data = this.authMechanisms.find(item => item.AuthMechanism.includes(MechanismType.Google));
|
|
58
|
-
const payload = {
|
|
59
|
-
AuthCode: this.code,
|
|
60
|
-
APIKey: this.apiKey,
|
|
61
|
-
AuthMechanism: data.AuthMechanism
|
|
62
|
-
};
|
|
63
|
-
this.utilService.sendBI(true);
|
|
64
|
-
const res = await this.server.post(`Authentication/GetUserDetails`, payload);
|
|
65
|
-
this.utilService.sendBI(false);
|
|
66
|
-
if (res instanceof ErrorResponse) {
|
|
67
|
-
this.onSubmitGoogleAuth.emit(res);
|
|
68
|
-
}
|
|
69
|
-
else {
|
|
70
|
-
var result = res;
|
|
71
|
-
this.onSubmitGoogleAuth.emit(result);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
35
|
+
loadPage() {
|
|
36
|
+
this.page = this.router.url;
|
|
74
37
|
}
|
|
75
38
|
loadGoogleScript() {
|
|
76
|
-
console.log('checking here');
|
|
77
39
|
if (!document.getElementById('google-jssdk')) {
|
|
78
40
|
const script = document.createElement('script');
|
|
79
41
|
script.src = 'https://accounts.google.com/gsi/client';
|
|
@@ -85,53 +47,63 @@ export class OAuthComponent {
|
|
|
85
47
|
document.head.appendChild(script);
|
|
86
48
|
}
|
|
87
49
|
}
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
}
|
|
91
|
-
oAuthWithGoogle() {
|
|
92
|
-
const redirectUri = encodeURIComponent(this.redirectUri);
|
|
50
|
+
oAuthWithGoogle(data) {
|
|
51
|
+
const redirectUri = encodeURIComponent(data.RedirectUri);
|
|
93
52
|
const scope = encodeURIComponent('openid email profile');
|
|
94
53
|
const responseType = 'code';
|
|
95
|
-
const
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
exchangeCodeForToken(authCode) {
|
|
99
|
-
console.log('Exchanging code for token:', authCode);
|
|
100
|
-
// this.http.post('/api/auth/google/token', { code: authCode }).subscribe({
|
|
101
|
-
// next: (response) => {
|
|
102
|
-
// console.log('Token received:', response);
|
|
103
|
-
// // Handle successful login (store token, etc.)
|
|
104
|
-
// },
|
|
105
|
-
// error: (err) => {
|
|
106
|
-
// console.error('Error exchanging code for token:', err);
|
|
107
|
-
// }
|
|
108
|
-
// });
|
|
109
|
-
}
|
|
110
|
-
handleCredentialResponse(response) {
|
|
111
|
-
console.log('Encoded JWT ID token:', response.credential);
|
|
54
|
+
const state = encodeURIComponent(JSON.stringify({ returnTo: this.page }));
|
|
55
|
+
const authUrl = `https://accounts.google.com/o/oauth2/v2/auth?client_id=${data.ClientId}&redirect_uri=${redirectUri}&response_type=${responseType}&scope=${scope}&state=${state}`;
|
|
56
|
+
window.location.href = authUrl;
|
|
112
57
|
}
|
|
113
58
|
oAuthWithApple() {
|
|
114
59
|
this.appleClick.emit();
|
|
115
60
|
}
|
|
116
|
-
|
|
117
|
-
|
|
61
|
+
oAuthWithMicrosoft() {
|
|
62
|
+
this.microsoftClick.emit();
|
|
63
|
+
}
|
|
64
|
+
checkForValue(value) {
|
|
65
|
+
switch (value) {
|
|
66
|
+
case MechanismType.Google:
|
|
67
|
+
return 'google-logo';
|
|
68
|
+
break;
|
|
69
|
+
case MechanismType.Apple:
|
|
70
|
+
return 'apple-logo';
|
|
71
|
+
break;
|
|
72
|
+
case MechanismType.MicrosoftAD:
|
|
73
|
+
return 'microsoft-logo';
|
|
74
|
+
break;
|
|
75
|
+
default:
|
|
76
|
+
return '';
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
handleOauthClick(value) {
|
|
80
|
+
switch (value.AuthMechanism) {
|
|
81
|
+
case MechanismType.Google:
|
|
82
|
+
return this.oAuthWithGoogle(value);
|
|
83
|
+
break;
|
|
84
|
+
case MechanismType.Apple:
|
|
85
|
+
return this.oAuthWithApple();
|
|
86
|
+
break;
|
|
87
|
+
case MechanismType.MicrosoftAD:
|
|
88
|
+
return this.oAuthWithMicrosoft();
|
|
89
|
+
break;
|
|
90
|
+
default:
|
|
91
|
+
return '';
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OAuthComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.HttpWebRequestService }, { token: i3.UtilService }, { token: i1.Router }], target: i0.ɵɵFactoryTarget.Component });
|
|
95
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: OAuthComponent, selector: "verben-o-auth", inputs: { authMechanisms: "authMechanisms" }, outputs: { microsoftClick: "microsoftClick", googleClick: "googleClick", appleClick: "appleClick" }, ngImport: i0, template: "<section class=\"oauthWrapper\"> \n <div class=\"OrFlexWrapper\">\n <hr/>\n <span>OR</span>\n <hr/>\n </div>\n <div class=\"btnWrapper\">\n <div *ngFor=\"let btn of authMechanisms, let i = index\"> \n <verbena-button\n [svg]=\"checkForValue(btn.AuthMechanism)\"\n [svgHeight]=\"24\"\n [svgWidth]=\"24\"\n [text]=\"'Continue with ' + btn.AuthMechanism\"\n bgColor=\"white\"\n textColor=\"black\"\n border=\"1px solid #333\"\n borderRadius=\"40px\"\n pd=\"10px 20px\"\n width=\"100%\"\n svgPosition=\"left\"\n buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n (click)=\"handleOauthClick(btn)\"\n ></verbena-button>\n </div> \n </div> \n</section>\n", styles: ["hr{height:1px;margin:0;border:1px solid #66666640;flex:1}.OR{margin:0 2px;color:#666}.oauthWrapper{display:flex;flex-direction:column;gap:12px}.btnWrapper{display:flex;flex-direction:column;gap:10px}.OrFlexWrapper{display:flex;align-items:center;gap:8px}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i5.VerbenaButtonComponent, selector: "verbena-button", inputs: ["text", "icon", "svgPosition", "bgColor", "textColor", "border", "borderRadius", "pd", "width", "height", "fontSize", "fontWeight", "disable", "styleType", "svg", "svgWidth", "svgHeight", "svgColor", "buttonClass", "buttonTextClass", "isLoading", "spinnerSize", "spinnerColor"] }] });
|
|
118
96
|
}
|
|
119
97
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: OAuthComponent, decorators: [{
|
|
120
98
|
type: Component,
|
|
121
|
-
args: [{ selector: 'verben-o-auth', template: "<section class=\"oauthWrapper\"> \n <div class=\"OrFlexWrapper\">\n <hr/>\n <span>OR</span>\n <hr/>\n </div>\n <
|
|
122
|
-
}], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.HttpWebRequestService }, { type: i3.UtilService }, { type:
|
|
123
|
-
type: Input
|
|
124
|
-
}], redirectUri: [{
|
|
125
|
-
type: Input
|
|
126
|
-
}], apiKey: [{
|
|
99
|
+
args: [{ selector: 'verben-o-auth', template: "<section class=\"oauthWrapper\"> \n <div class=\"OrFlexWrapper\">\n <hr/>\n <span>OR</span>\n <hr/>\n </div>\n <div class=\"btnWrapper\">\n <div *ngFor=\"let btn of authMechanisms, let i = index\"> \n <verbena-button\n [svg]=\"checkForValue(btn.AuthMechanism)\"\n [svgHeight]=\"24\"\n [svgWidth]=\"24\"\n [text]=\"'Continue with ' + btn.AuthMechanism\"\n bgColor=\"white\"\n textColor=\"black\"\n border=\"1px solid #333\"\n borderRadius=\"40px\"\n pd=\"10px 20px\"\n width=\"100%\"\n svgPosition=\"left\"\n buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n (click)=\"handleOauthClick(btn)\"\n ></verbena-button>\n </div> \n </div> \n</section>\n", styles: ["hr{height:1px;margin:0;border:1px solid #66666640;flex:1}.OR{margin:0 2px;color:#666}.oauthWrapper{display:flex;flex-direction:column;gap:12px}.btnWrapper{display:flex;flex-direction:column;gap:10px}.OrFlexWrapper{display:flex;align-items:center;gap:8px}\n"] }]
|
|
100
|
+
}], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.HttpWebRequestService }, { type: i3.UtilService }, { type: i1.Router }], propDecorators: { authMechanisms: [{
|
|
127
101
|
type: Input
|
|
128
102
|
}], microsoftClick: [{
|
|
129
103
|
type: Output
|
|
130
|
-
}], onSubmitGoogleAuth: [{
|
|
131
|
-
type: Output
|
|
132
104
|
}], googleClick: [{
|
|
133
105
|
type: Output
|
|
134
106
|
}], appleClick: [{
|
|
135
107
|
type: Output
|
|
136
108
|
}] } });
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-auth.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-authentication-ui/src/lib/components/o-auth/o-auth.component.ts","../../../../../../projects/verben-authentication-ui/src/lib/components/o-auth/o-auth.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { AuthMechanism, MechanismType } from '../../models/auth-mechanism';\nimport { ActivatedRoute } from '@angular/router';\nimport { HttpWebRequestService } from '../../services/http-web-request.service';\nimport { UtilService } from '../../services/util.service';\nimport { EnvironmentService } from '../../services/environment.service';\nimport { ErrorResponse } from '../../models/ErrorResponse';\nimport { ResponseKeyValue } from '../../models/ResponseKeyValue';\n\ndeclare global {\n    interface Window {\n    google: any;\n  }\n}\n\n@Component({\n  selector: 'verben-o-auth',\n  templateUrl: './o-auth.component.html',\n  styleUrl: './o-auth.component.css'\n})\nexport class OAuthComponent implements OnInit {\n  clientId: string = 'YOUR_CLIENT_ID_FROM_BACKEND';\n  showGoogle:boolean = false;\n  showMicrosoft:boolean = false;\n  showApple:boolean = false;\n  @Input() authMechanisms:AuthMechanism[] | null = null\n  @Input() redirectUri:string = 'http://localhost:4200/documentation/login'\n  @Input() apiKey?:string\n  @Output() microsoftClick = new EventEmitter<void>();\n  @Output() onSubmitGoogleAuth: EventEmitter<ResponseKeyValue | ErrorResponse> = new EventEmitter();\n  @Output() googleClick = new EventEmitter<void>();\n  @Output() appleClick = new EventEmitter<void>();\n  code:string = '';\n  googleRedirectUrl : string = ''\n  constructor(\n    private route: ActivatedRoute,\n    private server: HttpWebRequestService,\n    private utilService: UtilService,\n    private envSvc: EnvironmentService,\n  ){ \n  }\n\n  ngOnInit(): void {\n    this.loadGoogleScript(); \n    this.route.queryParams.subscribe(params => {\n      this.code = params['code'];\n    });\n     if(this.code){ \n      console.log('Code from URL:', this.code);\n      this.verifyUserDetails()\n     }\n       if(this.authMechanisms !== null ){ \n        this.showMicrosoft = this.authMechanisms.some(item =>\n           item.AuthMechanism.includes(MechanismType.MicrosoftAD)\n         );\n        this.showGoogle = this.authMechanisms.some(item =>\n           item.AuthMechanism.includes(MechanismType.Google)\n         );\n         if(this.showGoogle){ \n            const data:any = this.authMechanisms.find(item =>\n             item.AuthMechanism.includes(MechanismType.Google)\n           )\n           this.clientId = data?.ClientId;\n           this.googleRedirectUrl = data?.RedirectUri\n         }\n        this.showApple = this.authMechanisms.some(item =>\n           item.AuthMechanism.includes(MechanismType.Apple)\n         );\n     }\n  }\n  \n  async verifyUserDetails(){ \n    if(this.authMechanisms !== null && this.apiKey){ \n      const data:any = this.authMechanisms.find(item =>\n        item.AuthMechanism.includes(MechanismType.Google)\n      )\n      const payload = { \n        AuthCode:this.code,\n        APIKey:this.apiKey,\n        AuthMechanism:data.AuthMechanism\n      }\n\n      this.utilService.sendBI(true);\n      const res = await this.server.post(\n        `Authentication/GetUserDetails`,payload\n      );\n      this.utilService.sendBI(false);\n      if (res instanceof ErrorResponse) {\n        this.onSubmitGoogleAuth.emit(res);\n      } else {\n        var result = res as ResponseKeyValue;\n        this.onSubmitGoogleAuth.emit(result);\n      }\n    }\n\n   \n  }\n\n  loadGoogleScript(): void {\n    console.log('checking here');  \n    if (!document.getElementById('google-jssdk')) {\n      const script = document.createElement('script');\n      script.src = 'https://accounts.google.com/gsi/client';\n      script.id = 'google-jssdk';\n      script.async = true;\n      script.defer = true;\n      script.onload = () => console.log('Google SDK loaded');\n      script.onerror = () => console.log('Error loading Google SDK');\n      document.head.appendChild(script);\n    }\n  }\n\n  oAuthWithMicrosoft(){\n    this.microsoftClick.emit(); \n  }\n\noAuthWithGoogle() {\n  const redirectUri = encodeURIComponent(this.redirectUri);\n  const scope = encodeURIComponent('openid email profile');\n  const responseType = 'code';\n\n  const authUrl = `https://accounts.google.com/o/oauth2/v2/auth?client_id=${this.clientId}&redirect_uri=${redirectUri}&response_type=${responseType}&scope=${scope}`;\n\n  window.location.href = authUrl; // Redirects the current window\n}\n\nexchangeCodeForToken(authCode: string): void {\n  console.log('Exchanging code for token:', authCode);\n\n  // this.http.post('/api/auth/google/token', { code: authCode }).subscribe({\n  //     next: (response) => {\n  //         console.log('Token received:', response);\n  //         // Handle successful login (store token, etc.)\n  //     },\n  //     error: (err) => {\n  //         console.error('Error exchanging code for token:', err);\n  //     }\n  // });\n}\n\n\n  handleCredentialResponse(response: any): void {\n    console.log('Encoded JWT ID token:', response.credential)\n  }\n  oAuthWithApple(){\n    this.appleClick.emit(); \n  }\n\n}\n","<section class=\"oauthWrapper\"> \n    <div class=\"OrFlexWrapper\">\n        <hr/>\n        <span>OR</span>\n        <hr/>\n    </div>\n     <span *ngIf=\"showMicrosoft\"> \n       <verbena-button\n       svg=\"microsoft-logo\"\n       [svgHeight]=\"24\"\n       [svgWidth]=\"24\"\n       text=\"Continue with Microsoft\"\n       bgColor=\"white\"\n       textColor=\"black\"\n       border=\"1px solid #333\"\n       borderRadius=\"40px\"\n       pd=\"10px 20px\"\n       width=\"100%\"\n       svgPosition=\"left\"\n       buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n       (click)=\"oAuthWithMicrosoft()\"\n       ></verbena-button>\n     </span> \n\n    <span *ngIf=\"showGoogle\"> \n      <verbena-button\n      svg=\"google-logo\"\n      [svgHeight]=\"24\"\n      [svgWidth]=\"24\"\n      text=\"Continue with Google\"\n      bgColor=\"white\"\n      textColor=\"black\"\n      border=\"1px solid #333\"\n      borderRadius=\"40px\"\n      pd=\"10px 20px\"\n      width=\"100%\"\n      svgPosition=\"left\"\n      buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n      (click)=\"oAuthWithGoogle()\"\n      ></verbena-button>\n\n      <!-- <div id=\"g_id_onload\"\n     data-client_id=\"834995866282-l8gkp0r3v3a1bdvfmaumurki7ndar3m4.apps.googleusercontent.com\"\n     data-context=\"signin\"\n     data-ux_mode=\"popup\"\n     data-login_uri=\"http://localhost:5124/Authentication/ExternalCallback\"\n     data-itp_support=\"true\">\n</div>\n\n<div class=\"g_id_signin\"\n     data-type=\"standard\"\n     data-shape=\"rectangular\"\n     data-theme=\"outline\"\n     data-text=\"signin_with\"\n     data-size=\"large\"\n     data-logo_alignment=\"center\">\n</div> -->\n    </span>\n   \n    <span *ngIf=\"showApple\"> \n      <verbena-button\n      svg=\"apple-logo\"\n      [svgHeight]=\"24\"\n      [svgWidth]=\"24\"\n      text=\"Continue with Apple\"\n      bgColor=\"white\"\n      textColor=\"black\"\n      border=\"1px solid #333\"\n      borderRadius=\"40px\"\n      pd=\"10px 20px\"\n      width=\"100%\"\n      svgPosition=\"left\"\n      buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n      (click)=\"oAuthWithApple()\"\n      ></verbena-button>\n    </span>\n</section>\n"]}
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-auth.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-authentication-ui/src/lib/components/o-auth/o-auth.component.ts","../../../../../../projects/verben-authentication-ui/src/lib/components/o-auth/o-auth.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { AuthMechanism, MechanismType } from '../../models/auth-mechanism';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { HttpWebRequestService } from '../../services/http-web-request.service';\nimport { UtilService } from '../../services/util.service';\n\ndeclare global {\n  interface Window {\n    google: any;\n  }\n}\n\n@Component({\n  selector: 'verben-o-auth',\n  templateUrl: './o-auth.component.html',\n  styleUrl: './o-auth.component.css',\n})\nexport class OAuthComponent implements OnInit {\n  showGoogle: boolean = false;\n  showMicrosoft: boolean = false;\n  showApple: boolean = false;\n  @Input() authMechanisms: AuthMechanism[] | null = null;\n  @Output() microsoftClick = new EventEmitter<void>();\n  @Output() googleClick = new EventEmitter<void>();\n  @Output() appleClick = new EventEmitter<void>();\n  page: string = '';\n\n  constructor(\n    private route: ActivatedRoute,\n    private server: HttpWebRequestService,\n    private utilService: UtilService,\n    private router: Router\n  ) {}\n\n  ngOnInit(): void {\n    this.loadPage();\n    this.loadGoogleScript();\n    if (this.authMechanisms !== null) {\n      this.authMechanisms = this.authMechanisms.filter(\n        (item) => item.AuthMechanism !== MechanismType.InApp\n      );\n    }\n  }\n\n  loadPage() {\n    this.page = this.router.url;\n  }\n\n  loadGoogleScript(): void {\n    if (!document.getElementById('google-jssdk')) {\n      const script = document.createElement('script');\n      script.src = 'https://accounts.google.com/gsi/client';\n      script.id = 'google-jssdk';\n      script.async = true;\n      script.defer = true;\n      script.onload = () => console.log('Google SDK loaded');\n      script.onerror = () => console.log('Error loading Google SDK');\n      document.head.appendChild(script);\n    }\n  }\n\n  oAuthWithGoogle(data: AuthMechanism) {\n    const redirectUri = encodeURIComponent(data.RedirectUri);\n    const scope = encodeURIComponent('openid email profile');\n    const responseType = 'code';\n    const state = encodeURIComponent(JSON.stringify({ returnTo: this.page }));\n    const authUrl = `https://accounts.google.com/o/oauth2/v2/auth?client_id=${data.ClientId}&redirect_uri=${redirectUri}&response_type=${responseType}&scope=${scope}&state=${state}`;\n    window.location.href = authUrl;\n  }\n\n  oAuthWithApple() {\n    this.appleClick.emit();\n  }\n\n  oAuthWithMicrosoft() {\n    this.microsoftClick.emit();\n  }\n\n  checkForValue(value: string) {\n    switch (value) {\n      case MechanismType.Google:\n        return 'google-logo';\n        break;\n      case MechanismType.Apple:\n        return 'apple-logo';\n        break;\n      case MechanismType.MicrosoftAD:\n        return 'microsoft-logo';\n        break;\n      default:\n        return '';\n    }\n  }\n\n  handleOauthClick(value: AuthMechanism) {\n    switch (value.AuthMechanism) {\n      case MechanismType.Google:\n        return this.oAuthWithGoogle(value);\n        break;\n      case MechanismType.Apple:\n        return this.oAuthWithApple();\n        break;\n      case MechanismType.MicrosoftAD:\n        return this.oAuthWithMicrosoft();\n        break;\n      default:\n        return '';\n    }\n  }\n}\n","<section class=\"oauthWrapper\"> \n    <div class=\"OrFlexWrapper\">\n        <hr/>\n        <span>OR</span>\n        <hr/>\n    </div>\n     <div class=\"btnWrapper\">\n      <div *ngFor=\"let btn of authMechanisms, let i = index\"> \n        <verbena-button\n        [svg]=\"checkForValue(btn.AuthMechanism)\"\n        [svgHeight]=\"24\"\n        [svgWidth]=\"24\"\n        [text]=\"'Continue with ' + btn.AuthMechanism\"\n        bgColor=\"white\"\n        textColor=\"black\"\n        border=\"1px solid #333\"\n        borderRadius=\"40px\"\n        pd=\"10px 20px\"\n        width=\"100%\"\n        svgPosition=\"left\"\n        buttonClass=\"font-normal text-[24px] leading-[29.05px] text-[#333] mt-2\"\n        (click)=\"handleOauthClick(btn)\"\n        ></verbena-button>\n      </div> \n     </div> \n</section>\n"]}
|