]>
Commit | Line | Data |
---|---|---|
f375bb3d C |
1 | import { from, Observable } from 'rxjs' |
2 | import { mergeMap, switchMap } from 'rxjs/operators' | |
93cae479 C |
3 | import { Injectable } from '@angular/core' |
4 | import { PluginService } from '@app/core/plugins/plugin.service' | |
42b40636 | 5 | import { logger } from '@root-helpers/logger' |
67ed6552 | 6 | import { ClientActionHookName, ClientFilterHookName, PluginClientScope } from '@shared/models' |
faeec106 | 7 | import { AuthService, AuthStatus } from '../auth' |
93cae479 C |
8 | |
9 | type RawFunction<U, T> = (params: U) => T | |
10 | type ObservableFunction<U, T> = RawFunction<U, Observable<T>> | |
11 | ||
12 | @Injectable() | |
13 | export class HooksService { | |
faeec106 C |
14 | constructor ( |
15 | private authService: AuthService, | |
16 | private pluginService: PluginService | |
17 | ) { | |
18 | // Run auth hooks | |
19 | this.authService.userInformationLoaded | |
20 | .subscribe(() => this.runAction('action:auth-user.information-loaded', 'common', { user: this.authService.getUser() })) | |
21 | ||
22 | this.authService.loginChangedSource.subscribe(obj => { | |
23 | if (obj === AuthStatus.LoggedIn) { | |
24 | this.runAction('action:auth-user.logged-in', 'common') | |
25 | } else if (obj === AuthStatus.LoggedOut) { | |
26 | this.runAction('action:auth-user.logged-out', 'common') | |
27 | } | |
28 | }) | |
29 | } | |
93cae479 | 30 | |
9df52d66 C |
31 | wrapObsFun <P, R, H1 extends ClientFilterHookName, H2 extends ClientFilterHookName> |
32 | (fun: ObservableFunction<P, R>, params: P, scope: PluginClientScope, hookParamName: H1, hookResultName: H2) { | |
93cae479 C |
33 | return from(this.pluginService.ensurePluginsAreLoaded(scope)) |
34 | .pipe( | |
0912f1b4 | 35 | mergeMap(() => this.wrapObjectWithoutScopeLoad(params, hookParamName)), |
93cae479 C |
36 | switchMap(params => fun(params)), |
37 | mergeMap(result => this.pluginService.runHook(hookResultName, result, params)) | |
38 | ) | |
39 | } | |
40 | ||
9df52d66 C |
41 | async wrapFun <P, R, H1 extends ClientFilterHookName, H2 extends ClientFilterHookName> |
42 | (fun: RawFunction<P, R>, params: P, scope: PluginClientScope, hookParamName: H1, hookResultName: H2) { | |
c2023a9f C |
43 | await this.pluginService.ensurePluginsAreLoaded(scope) |
44 | ||
0912f1b4 | 45 | const newParams = await this.wrapObjectWithoutScopeLoad(params, hookParamName) |
c2023a9f | 46 | const result = fun(newParams) |
93cae479 | 47 | |
c2023a9f | 48 | return this.pluginService.runHook(hookResultName, result, params) |
93cae479 C |
49 | } |
50 | ||
c9e3eeed C |
51 | runAction<T, U extends ClientActionHookName> (hookName: U, scope: PluginClientScope, params?: T) { |
52 | this.pluginService.ensurePluginsAreLoaded(scope) | |
23bdacf8 | 53 | .then(() => this.pluginService.runHook(hookName, undefined, params)) |
42b40636 | 54 | .catch((err: any) => logger.error('Fatal hook error.', err)) |
93cae479 | 55 | } |
c2023a9f | 56 | |
0912f1b4 C |
57 | async wrapObject<T, U extends ClientFilterHookName> (result: T, scope: PluginClientScope, hookName: U) { |
58 | await this.pluginService.ensurePluginsAreLoaded(scope) | |
59 | ||
60 | return this.wrapObjectWithoutScopeLoad(result, hookName) | |
61 | } | |
62 | ||
63 | private wrapObjectWithoutScopeLoad<T, U extends ClientFilterHookName> (result: T, hookName: U) { | |
c2023a9f C |
64 | return this.pluginService.runHook(hookName, result) |
65 | } | |
93cae479 | 66 | } |