1 | import { __decorate, __metadata } from 'tslib';
|
2 | import { forwardRef, Injectable, InjectionToken, Component, NgModule } from '@angular/core';
|
3 | import { Type, plainToClass } from 'class-transformer';
|
4 | import { Router, ActivatedRoute, RouterModule } from '@angular/router';
|
5 | import { Storage, UbudStorageModule } from '@ubud/storage';
|
6 | import { of } from 'rxjs';
|
7 | import { fromPromise } from 'rxjs/internal/observable/fromPromise';
|
8 | import { map, switchMap, first, catchError } from 'rxjs/internal/operators';
|
9 | import { HttpClient } from '@angular/common/http';
|
10 | import { ErrorObservable } from 'rxjs-compat/observable/ErrorObservable';
|
11 |
|
12 | /**
|
13 | * @fileoverview added by tsickle
|
14 | * @suppress {checkTypes} checked by tsc
|
15 | */
|
16 | class Config {
|
17 | /**
|
18 | * @param {?=} data
|
19 | */
|
20 | constructor(data) {
|
21 | this.endpoint = 'https://account.kemnaker.go.id';
|
22 | Object.assign(this, data);
|
23 | }
|
24 | }
|
25 |
|
26 | /**
|
27 | * @fileoverview added by tsickle
|
28 | * @suppress {checkTypes} checked by tsc
|
29 | */
|
30 | class User {
|
31 | }
|
32 | __decorate([
|
33 | Type(/** @type {?} */ (forwardRef(() => Date))),
|
34 | __metadata("design:type", Date)
|
35 | ], User.prototype, "updatedAt", void 0);
|
36 |
|
37 | /**
|
38 | * @fileoverview added by tsickle
|
39 | * @suppress {checkTypes} checked by tsc
|
40 | */
|
41 | class NacoService {
|
42 | /**
|
43 | * @param {?} config
|
44 | * @param {?} router
|
45 | * @param {?} storage
|
46 | * @param {?} http
|
47 | */
|
48 | constructor(config, router, storage, http) {
|
49 | this.config = config;
|
50 | this.router = router;
|
51 | this.storage = storage;
|
52 | this.http = http;
|
53 | this.VERSION = 'v1';
|
54 | this.signature = null;
|
55 | this.user = null;
|
56 | }
|
57 | /**
|
58 | * @return {?}
|
59 | */
|
60 | getUser() {
|
61 | if (null !== this.user) {
|
62 | return of(this.user);
|
63 | }
|
64 | return fromPromise(this.storage.get('user')).pipe(switchMap((user) => {
|
65 | if (null !== user) {
|
66 | return of(user);
|
67 | }
|
68 | const /** @type {?} */ uri = this.config.endpoint + '/api/' + this.VERSION + '/users/me';
|
69 | return fromPromise(this.getSignature()).pipe(switchMap((signature) => {
|
70 | if (null === signature) {
|
71 | return of(null);
|
72 | }
|
73 | const /** @type {?} */ options = {
|
74 | headers: {
|
75 | Authorization: `${signature.type} ${signature.token}`,
|
76 | },
|
77 | };
|
78 | return this.http.get(uri, options).pipe(map((res) => {
|
79 | if (res.data) {
|
80 | return res.data;
|
81 | }
|
82 | throw new Error('There are no body to be transformed');
|
83 | }), map((data) => {
|
84 | const /** @type {?} */ authUser = plainToClass(User, data);
|
85 | this.storage.set('user', authUser);
|
86 | return authUser;
|
87 | }));
|
88 | }));
|
89 | }));
|
90 | }
|
91 | /**
|
92 | * @return {?}
|
93 | */
|
94 | getSignature() {
|
95 | if (null !== this.signature) {
|
96 | return Promise.resolve(this.signature);
|
97 | }
|
98 | return this.storage.get('signature');
|
99 | }
|
100 | /**
|
101 | * @param {?} signature
|
102 | * @return {?}
|
103 | */
|
104 | setSignature(signature) {
|
105 | this.signature = signature;
|
106 | this.storage.set('signature', signature);
|
107 | }
|
108 | /**
|
109 | * @param {?} scopes
|
110 | * @param {?=} redirectUri
|
111 | * @return {?}
|
112 | */
|
113 | login(scopes, redirectUri) {
|
114 | if (!redirectUri) {
|
115 | redirectUri = this.router.url;
|
116 | }
|
117 | const /** @type {?} */ state = this.generateState();
|
118 | this.storage.set('state', state);
|
119 | const /** @type {?} */ query = this.buildQueryString({
|
120 | 'response_type': 'token',
|
121 | 'scopes': scopes,
|
122 | 'client': this.config.clientId,
|
123 | 'state': state,
|
124 | 'continue': redirectUri,
|
125 | });
|
126 | return this.config.endpoint + '/auth?' + query;
|
127 | }
|
128 | /**
|
129 | * @param {?=} redirectUri
|
130 | * @return {?}
|
131 | */
|
132 | logout(redirectUri) {
|
133 | this.signature = null;
|
134 | this.user = null;
|
135 | return new Promise(resolve => {
|
136 | Promise.all([
|
137 | this.storage.remove('signature'),
|
138 | this.storage.remove('user'),
|
139 | ]).then(() => {
|
140 | let /** @type {?} */ endpoint = this.config.endpoint + '/auth/logout';
|
141 | if (redirectUri) {
|
142 | endpoint += '?continue=' + redirectUri;
|
143 | }
|
144 | resolve(endpoint);
|
145 | });
|
146 | });
|
147 | }
|
148 | /**
|
149 | * @return {?}
|
150 | */
|
151 | getState() {
|
152 | return this.storage.get('state');
|
153 | }
|
154 | /**
|
155 | * @return {?}
|
156 | */
|
157 | generateState() {
|
158 | const /** @type {?} */ possible = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
|
159 | let /** @type {?} */ text = '';
|
160 | for (let /** @type {?} */ i = 0; i < 5; i++) {
|
161 | text += possible.charAt(Math.floor(Math.random() * possible.length));
|
162 | }
|
163 | return text;
|
164 | }
|
165 | /**
|
166 | * @param {?} params
|
167 | * @return {?}
|
168 | */
|
169 | buildQueryString(params) {
|
170 | const /** @type {?} */ queryParams = Object.keys(params).map((key) => {
|
171 | return encodeURIComponent(key) + '=' + encodeURIComponent(params[key]);
|
172 | });
|
173 | return queryParams.join('&');
|
174 | }
|
175 | }
|
176 | NacoService.decorators = [
|
177 | { type: Injectable },
|
178 | ];
|
179 | /** @nocollapse */
|
180 | NacoService.ctorParameters = () => [
|
181 | { type: Config },
|
182 | { type: Router },
|
183 | { type: Storage },
|
184 | { type: HttpClient }
|
185 | ];
|
186 |
|
187 | /**
|
188 | * @fileoverview added by tsickle
|
189 | * @suppress {checkTypes} checked by tsc
|
190 | */
|
191 | class Signature {
|
192 | }
|
193 |
|
194 | /**
|
195 | * @fileoverview added by tsickle
|
196 | * @suppress {checkTypes} checked by tsc
|
197 | */
|
198 | class AuthenticatedGuard {
|
199 | /**
|
200 | * @param {?} service
|
201 | * @param {?} storage
|
202 | */
|
203 | constructor(service, storage) {
|
204 | this.service = service;
|
205 | this.storage = storage;
|
206 | }
|
207 | /**
|
208 | * @return {?}
|
209 | */
|
210 | canActivate() {
|
211 | return this.service.getUser().pipe(first(), map((user) => {
|
212 | if (null === user) {
|
213 | let /** @type {?} */ redirectUri = document.location.protocol + '//' + document.location.hostname;
|
214 | if (document.location.port) {
|
215 | redirectUri += ':' + document.location.port;
|
216 | }
|
217 | this.storage.set('naco_intended_url', window.location.href).then(() => {
|
218 | window.location.href = this.service.login('basic email', redirectUri + '/auth');
|
219 | });
|
220 | }
|
221 | return !!user;
|
222 | }));
|
223 | }
|
224 | /**
|
225 | * @return {?}
|
226 | */
|
227 | canActivateChild() {
|
228 | return this.canActivate();
|
229 | }
|
230 | }
|
231 | AuthenticatedGuard.decorators = [
|
232 | { type: Injectable },
|
233 | ];
|
234 | /** @nocollapse */
|
235 | AuthenticatedGuard.ctorParameters = () => [
|
236 | { type: NacoService },
|
237 | { type: Storage }
|
238 | ];
|
239 |
|
240 | /**
|
241 | * @fileoverview added by tsickle
|
242 | * @suppress {checkTypes} checked by tsc
|
243 | */
|
244 | class AuthInterceptor {
|
245 | /**
|
246 | * @param {?} naco
|
247 | */
|
248 | constructor(naco) {
|
249 | this.naco = naco;
|
250 | }
|
251 | /**
|
252 | * @param {?} req
|
253 | * @param {?} next
|
254 | * @return {?}
|
255 | */
|
256 | intercept(req, next) {
|
257 | return fromPromise(this.naco.getSignature()).pipe(switchMap((signature) => {
|
258 | if (!signature) {
|
259 | return next.handle(req);
|
260 | }
|
261 | return next
|
262 | .handle(req.clone({
|
263 | setHeaders: {
|
264 | Authorization: `${signature.type} ${signature.token}`,
|
265 | },
|
266 | }))
|
267 | .pipe(catchError((error) => {
|
268 | if (error.status === 401) ;
|
269 | return ErrorObservable.create(error);
|
270 | }));
|
271 | }));
|
272 | }
|
273 | }
|
274 | AuthInterceptor.decorators = [
|
275 | { type: Injectable },
|
276 | ];
|
277 | /** @nocollapse */
|
278 | AuthInterceptor.ctorParameters = () => [
|
279 | { type: NacoService }
|
280 | ];
|
281 |
|
282 | /**
|
283 | * @fileoverview added by tsickle
|
284 | * @suppress {checkTypes} checked by tsc
|
285 | */
|
286 | /**
|
287 | * @param {?} config
|
288 | * @param {?} router
|
289 | * @param {?} storage
|
290 | * @param {?} http
|
291 | * @return {?}
|
292 | */
|
293 | function nacoFactory(config, router, storage, http) {
|
294 | return new NacoService(new Config(Object.assign({}, config)), router, storage, http);
|
295 | }
|
296 | const /** @type {?} */ NACO_CONFIG = new InjectionToken('NACO_CONFIG');
|
297 |
|
298 | /**
|
299 | * @fileoverview added by tsickle
|
300 | * @suppress {checkTypes} checked by tsc
|
301 | */
|
302 | class AuthPage {
|
303 | /**
|
304 | * @param {?} route
|
305 | * @param {?} naco
|
306 | * @param {?} storage
|
307 | */
|
308 | constructor(route, naco, storage) {
|
309 | this.route = route;
|
310 | this.naco = naco;
|
311 | this.storage = storage;
|
312 | this.message = 'Authenticating...';
|
313 | this.route.queryParams.subscribe((params) => this.handle(params));
|
314 | }
|
315 | /**
|
316 | * @param {?} params
|
317 | * @return {?}
|
318 | */
|
319 | handle(params) {
|
320 | if (params["state"]) {
|
321 | this.naco.getState().then((state) => {
|
322 | if (state !== params["state"]) {
|
323 | this.message = 'Invalid CSRF';
|
324 | return;
|
325 | }
|
326 | this.authenticate(params);
|
327 | });
|
328 | }
|
329 | else {
|
330 | this.authenticate(params);
|
331 | }
|
332 | }
|
333 | /**
|
334 | * @param {?} params
|
335 | * @return {?}
|
336 | */
|
337 | authenticate(params) {
|
338 | const /** @type {?} */ signature = {
|
339 | expiresIn: params["expires_in"],
|
340 | type: params["token_type"],
|
341 | token: params["access_token"],
|
342 | };
|
343 | this.naco.setSignature(signature);
|
344 | this.naco.getUser().subscribe((user) => {
|
345 | if (null !== user) {
|
346 | this.storage.get('naco_intended_url').then((url) => {
|
347 | window.location.href = url ? url : '/';
|
348 | });
|
349 | return;
|
350 | }
|
351 | this.message = 'Unauthenticated!';
|
352 | });
|
353 | }
|
354 | }
|
355 | AuthPage.decorators = [
|
356 | { type: Component, args: [{
|
357 | selector: 'naker-auth-page',
|
358 | template: '{{ message }}',
|
359 | },] },
|
360 | ];
|
361 | /** @nocollapse */
|
362 | AuthPage.ctorParameters = () => [
|
363 | { type: ActivatedRoute },
|
364 | { type: NacoService },
|
365 | { type: Storage }
|
366 | ];
|
367 |
|
368 | /**
|
369 | * @fileoverview added by tsickle
|
370 | * @suppress {checkTypes} checked by tsc
|
371 | */
|
372 | const /** @type {?} */ routes = [
|
373 | {
|
374 | path: 'auth',
|
375 | component: AuthPage
|
376 | },
|
377 | ];
|
378 | const /** @type {?} */ AUTH_ROUTING = RouterModule.forChild(routes);
|
379 |
|
380 | /**
|
381 | * @fileoverview added by tsickle
|
382 | * @suppress {checkTypes} checked by tsc
|
383 | */
|
384 | class NacoViewModule {
|
385 | }
|
386 | NacoViewModule.decorators = [
|
387 | { type: NgModule, args: [{
|
388 | imports: [
|
389 | AUTH_ROUTING,
|
390 | ],
|
391 | declarations: [
|
392 | AuthPage,
|
393 | ],
|
394 | },] },
|
395 | ];
|
396 |
|
397 | /**
|
398 | * @fileoverview added by tsickle
|
399 | * @suppress {checkTypes} checked by tsc
|
400 | */
|
401 | class NacoModule {
|
402 | /**
|
403 | * @param {?} config
|
404 | * @return {?}
|
405 | */
|
406 | static forRoot(config) {
|
407 | return {
|
408 | ngModule: NacoModule,
|
409 | providers: [
|
410 | {
|
411 | provide: NACO_CONFIG,
|
412 | useValue: config,
|
413 | },
|
414 | {
|
415 | provide: NacoService,
|
416 | useFactory: nacoFactory,
|
417 | deps: [NACO_CONFIG, Router, Storage, HttpClient],
|
418 | },
|
419 | AuthenticatedGuard,
|
420 | ],
|
421 | };
|
422 | }
|
423 | }
|
424 | NacoModule.decorators = [
|
425 | { type: NgModule, args: [{
|
426 | imports: [
|
427 | UbudStorageModule,
|
428 | NacoViewModule,
|
429 | ],
|
430 | },] },
|
431 | ];
|
432 |
|
433 | /**
|
434 | * @fileoverview added by tsickle
|
435 | * @suppress {checkTypes} checked by tsc
|
436 | */
|
437 |
|
438 | /**
|
439 | * @fileoverview added by tsickle
|
440 | * @suppress {checkTypes} checked by tsc
|
441 | */
|
442 |
|
443 | export { NacoService, User, Signature, Config, AuthenticatedGuard, AuthInterceptor, NacoModule, NACO_CONFIG as ɵe, nacoFactory as ɵd, NacoViewModule as ɵa, AuthPage as ɵc, AUTH_ROUTING as ɵb };
|
444 |
|
445 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"naker-naco.js.map","sources":["ng://@naker/naco/domains/values/config.ts","ng://@naker/naco/domains/models/user.ts","ng://@naker/naco/domains/services/naco.service.ts","ng://@naker/naco/domains/values/signature.ts","ng://@naker/naco/guards/authenticated.guard.ts","ng://@naker/naco/interceptors/auth.interceptor.ts","ng://@naker/naco/factories/naco-factory.ts","ng://@naker/naco/views/pages/auth.page.ts","ng://@naker/naco/views/routes.ts","ng://@naker/naco/views/module.ts","ng://@naker/naco/naco.module.ts"],"sourcesContent":["export class Config {\n    public endpoint: string = 'https://account.kemnaker.go.id';\n    public clientId: string;\n\n    public constructor(data?: Partial<Config>) {\n        Object.assign(this, data);\n    }\n}\n","import { forwardRef } from '@angular/core';\nimport { Type } from 'class-transformer';\n\nexport class User {\n    public id: string;\n    public username: string;\n    public email?: string;\n    public name: string;\n    public status: number;\n\n    @Type(forwardRef(() => Date) as any)\n    public updatedAt: Date;\n}\n","import { Injectable } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { Storage } from '@ubud/storage';\nimport { Config } from '../values/config';\nimport { User } from '../models/user';\nimport { Observable, of } from 'rxjs';\nimport { Signature } from '../values/signature';\nimport { fromPromise } from 'rxjs/internal/observable/fromPromise';\nimport { map, switchMap } from 'rxjs/internal/operators';\nimport { plainToClass } from 'class-transformer';\nimport { HttpClient } from '@angular/common/http';\n\n@Injectable()\nexport class NacoService {\n    public readonly VERSION = 'v1';\n\n    private signature: Signature | null = null;\n    private user: User | null = null;\n\n    public constructor(private config: Config, private router: Router, private storage: Storage, private http: HttpClient) {\n    }\n\n    public getUser(): Observable<User | null> {\n        if (null !== this.user) {\n            return of(this.user);\n        }\n\n        return fromPromise(this.storage.get('user')).pipe(\n            switchMap((user: User | null) => {\n                if (null !== user) {\n                    return of(user);\n                }\n\n                const uri = this.config.endpoint + '/api/' + this.VERSION + '/users/me';\n\n                return fromPromise(this.getSignature()).pipe(\n                    switchMap((signature: Signature | null) => {\n                        if (null === signature) {\n                            return of(null);\n                        }\n\n                        const options = {\n                            headers: {\n                                Authorization: `${signature.type} ${signature.token}`,\n                            },\n                        };\n\n                        return this.http.get<any>(uri, options).pipe(\n                            map((res: any) => {\n                                if (res.data) {\n                                    return res.data;\n                                }\n\n                                throw new Error('There are no body to be transformed');\n                            }),\n                            map((data: any) => {\n                                const authUser = plainToClass(User, data);\n\n                                this.storage.set('user', authUser);\n\n                                return authUser;\n                            }),\n                        );\n                    }),\n                );\n            }),\n        );\n    }\n\n    public getSignature(): Promise<Signature | null> {\n        if (null !== this.signature) {\n            return Promise.resolve(this.signature);\n        }\n\n        return this.storage.get('signature');\n    }\n\n    public setSignature(signature: Signature): void {\n        this.signature = signature;\n        this.storage.set('signature', signature);\n    }\n\n    public login(scopes: string, redirectUri?: string): string {\n        if (!redirectUri) {\n            redirectUri = this.router.url;\n        }\n\n        const state = this.generateState();\n\n        this.storage.set('state', state);\n\n        const query: string = this.buildQueryString(\n            {\n                'response_type': 'token',\n                'scopes': scopes,\n                'client': this.config.clientId,\n                'state': state,\n                'continue': redirectUri,\n            },\n        );\n\n        return this.config.endpoint + '/auth?' + query;\n    }\n\n    public logout(redirectUri?: string): Promise<string> {\n        this.signature = null;\n        this.user = null;\n\n        return new Promise(resolve => {\n            Promise.all([\n                this.storage.remove('signature'),\n                this.storage.remove('user'),\n            ]).then(() => {\n                let endpoint = this.config.endpoint + '/auth/logout';\n\n                if (redirectUri) {\n                    endpoint += '?continue=' + redirectUri;\n                }\n\n                resolve(endpoint);\n            });\n        });\n    }\n\n    public getState() {\n        return this.storage.get('state');\n    }\n\n    private generateState(): string {\n        const possible = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n        let text = '';\n\n        for (let i = 0; i < 5; i++) {\n            text += possible.charAt(Math.floor(Math.random() * possible.length));\n        }\n\n        return text;\n    }\n\n    private buildQueryString(params: object): string {\n        const queryParams = Object.keys(params).map((key: string) => {\n            return encodeURIComponent(key) + '=' + encodeURIComponent(params[key]);\n        });\n\n        return queryParams.join('&');\n    }\n}\n","export class Signature {\n    public expiresIn: number;\n    public token: string;\n    public type: string;\n}\n","import { Injectable } from '@angular/core';\nimport { CanActivate, CanActivateChild } from '@angular/router';\nimport { NacoService } from '../domains/services/naco.service';\nimport { first, map } from 'rxjs/internal/operators';\nimport { User } from '../domains/models/user';\nimport { Observable } from 'rxjs';\nimport { Storage } from '@ubud/storage';\n\n@Injectable()\nexport class AuthenticatedGuard implements CanActivate, CanActivateChild {\n    public constructor(private service: NacoService, private storage: Storage) {\n    }\n\n    public canActivate(): Observable<boolean> {\n        return this.service.getUser().pipe(\n            first(),\n            map((user: User | null) => {\n                if (null === user) {\n                    let redirectUri = document.location.protocol + '//' + document.location.hostname;\n\n                    if (document.location.port) {\n                        redirectUri += ':' + document.location.port;\n                    }\n\n                    this.storage.set('naco_intended_url', window.location.href).then(() => {\n                        window.location.href = this.service.login(\n                            'basic email',\n                            redirectUri + '/auth',\n                        );\n                    });\n                }\n\n                return !!user;\n            }),\n        );\n    }\n\n    public canActivateChild(): Observable<boolean> {\n        return this.canActivate();\n    }\n}\n","import { HttpErrorResponse, HttpEvent, HttpHandler, HttpInterceptor, HttpRequest } from '@angular/common/http';\nimport { Observable } from 'rxjs';\nimport { NacoService } from '../domains/services/naco.service';\nimport { fromPromise } from 'rxjs/internal/observable/fromPromise';\nimport { Signature } from '../domains/values/signature';\nimport { catchError, switchMap } from 'rxjs/internal/operators';\nimport { ErrorObservable } from 'rxjs-compat/observable/ErrorObservable';\nimport { Injectable } from '@angular/core';\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n    public constructor(private naco: NacoService) {\n    }\n\n    public intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\n        return fromPromise(this.naco.getSignature()).pipe(\n            switchMap((signature: Signature | null) => {\n                if (!signature) {\n                    return next.handle(req);\n                }\n\n                return next\n                    .handle(\n                        req.clone({\n                            setHeaders: {\n                                Authorization: `${signature.type} ${signature.token}`,\n                            },\n                        }),\n                    )\n                    .pipe(\n                        catchError((error: HttpErrorResponse) => {\n                            if (error.status === 401) {\n                                // TODO: Refresh token\n                            }\n\n                            return ErrorObservable.create(error);\n                        }),\n                    );\n            }),\n        );\n    }\n}\n","import { NacoService } from '../domains/services/naco.service';\nimport { Config } from '../domains/values/config';\nimport { Router } from '@angular/router';\nimport { Storage } from '@ubud/storage';\nimport { InjectionToken } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\n\nexport function nacoFactory(config: object, router: Router, storage: Storage, http: HttpClient) {\n    return new NacoService(\n        new Config({ ...config }),\n        router,\n        storage,\n        http\n    );\n}\n\nexport const NACO_CONFIG = new InjectionToken<object>('NACO_CONFIG');\n","import { Component } from '@angular/core';\nimport { ActivatedRoute, Params } from '@angular/router';\nimport { NacoService } from '../../domains/services/naco.service';\nimport { Signature } from '../../domains/values/signature';\nimport { User } from '../../domains/models/user';\nimport { Storage } from '@ubud/storage';\n\n@Component({\n    selector: 'naker-auth-page',\n    template: '{{ message }}',\n})\nexport class AuthPage {\n    public message: string = 'Authenticating...';\n\n    public constructor(private route: ActivatedRoute, private naco: NacoService, private storage: Storage) {\n        this.route.queryParams.subscribe((params: Params) => this.handle(params));\n    }\n\n    public handle(params: Params): void {\n        if (params.state) {\n            this.naco.getState().then((state: string | null) => {\n                if (state !== params.state) {\n                    this.message = 'Invalid CSRF';\n\n                    return;\n                }\n\n                this.authenticate(params);\n            });\n        } else {\n            this.authenticate(params);\n        }\n    }\n\n    private authenticate(params: Params): void {\n        const signature: Signature = {\n            expiresIn: params.expires_in,\n            type: params.token_type,\n            token: params.access_token,\n        };\n\n        this.naco.setSignature(signature);\n\n        this.naco.getUser().subscribe((user: User | null) => {\n            if (null !== user) {\n                this.storage.get('naco_intended_url').then((url: any) => {\n                    window.location.href = url ? url : '/';\n                });\n\n                return;\n            }\n\n            this.message = 'Unauthenticated!';\n        });\n    }\n}\n\n","import { ModuleWithProviders } from '@angular/core';\nimport { RouterModule, Routes } from '@angular/router';\nimport { AuthPage } from './pages/auth.page';\n\nconst routes: Routes = [\n    {\n        path: 'auth',\n        component: AuthPage\n    },\n];\n\nexport const AUTH_ROUTING: ModuleWithProviders = RouterModule.forChild(routes);\n","import { NgModule } from '@angular/core';\nimport { AUTH_ROUTING } from './routes';\nimport { AuthPage } from './pages/auth.page';\n\n@NgModule({\n    imports: [\n        AUTH_ROUTING,\n    ],\n    declarations: [\n        AuthPage,\n    ],\n})\nexport class NacoViewModule {\n}\n","import { ModuleWithProviders, NgModule } from '@angular/core';\nimport { NacoService } from './domains/services/naco.service';\nimport { AuthenticatedGuard } from './guards/authenticated.guard';\nimport { NACO_CONFIG, nacoFactory } from './factories/naco-factory';\nimport { Router } from '@angular/router';\nimport { Storage, UbudStorageModule } from '@ubud/storage';\nimport { NacoViewModule } from './views/module';\nimport { HttpClient } from '@angular/common/http';\n\n@NgModule({\n    imports: [\n        UbudStorageModule,\n        NacoViewModule,\n    ],\n})\nexport class NacoModule {\n    public static forRoot(config: { clientId: string, endpoint?: string }): ModuleWithProviders {\n        return {\n            ngModule: NacoModule,\n            providers: [\n                {\n                    provide: NACO_CONFIG,\n                    useValue: config,\n                },\n                {\n                    provide: NacoService,\n                    useFactory: nacoFactory,\n                    deps: [NACO_CONFIG, Router, Storage, HttpClient],\n                },\n                AuthenticatedGuard,\n            ],\n        };\n    }\n}\n"],"names":[],"mappings":"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"} |
\ | No newline at end of file |