+import { RegisteredExternalAuthConfig } from '@shared/models'
import { HookType } from '../../models/plugins/hook-type.enum'
-import { isCatchable, isPromise } from '../miscs/miscs'
+import { isCatchable, isPromise } from '../common/promises'
function getHookType (hookName: string) {
if (hookName.startsWith('filter:')) return HookType.FILTER
return HookType.STATIC
}
-async function internalRunHook <T>(handler: Function, hookType: HookType, result: T, params: any, onError: (err: Error) => void) {
+async function internalRunHook <T> (options: {
+ handler: Function
+ hookType: HookType
+ result: T
+ params: any
+ onError: (err: Error) => void
+}) {
+ const { handler, hookType, result, params, onError } = options
+
try {
if (hookType === HookType.FILTER) {
const p = handler(result, params)
- if (isPromise(p)) result = await p
- else result = p
+ const newResult = isPromise(p)
+ ? await p
+ : p
- return result
+ return newResult
}
// Action/static hooks do not have result value
}
if (hookType === HookType.ACTION) {
- if (isCatchable(p)) p.catch(err => onError(err))
+ if (isCatchable(p)) p.catch((err: any) => onError(err))
return undefined
}
return result
}
+function getExternalAuthHref (apiUrl: string, auth: RegisteredExternalAuthConfig) {
+ return apiUrl + `/plugins/${auth.name}/${auth.version}/auth/${auth.authName}`
+}
+
export {
getHookType,
- internalRunHook
+ internalRunHook,
+ getExternalAuthHref
}