X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Flib%2Fplugins%2Fhooks.ts;h=327aaece2d6f762c4cba1431daa39aa8ae05c390;hb=daa0226b0a2ae1d19b342c2b7a54267d2fd8d30e;hp=7bb907e6a79d1cd96dd2ea6e6a0513f193a9e883;hpb=b4055e1c23eeefb0c8a85a77f312b2827d98f483;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/lib/plugins/hooks.ts b/server/lib/plugins/hooks.ts index 7bb907e6a..327aaece2 100644 --- a/server/lib/plugins/hooks.ts +++ b/server/lib/plugins/hooks.ts @@ -1,22 +1,31 @@ -import { ServerActionHookName, ServerFilterHookName } from '../../../shared/models/plugins/server-hook.model' -import { PluginManager } from './plugin-manager' +import Bluebird from 'bluebird' +import { ServerActionHookName, ServerFilterHookName } from '../../../shared/models' import { logger } from '../../helpers/logger' -import * as Bluebird from 'bluebird' +import { PluginManager } from './plugin-manager' + +type PromiseFunction = (params: U) => Promise | Bluebird +type RawFunction = (params: U) => T // Helpers to run hooks const Hooks = { - wrapObject: (obj: T, hookName: U) => { - return PluginManager.Instance.runHook(hookName, obj) as Promise + wrapObject: (result: T, hookName: U) => { + return PluginManager.Instance.runHook(hookName, result) }, - wrapPromise: async (fun: Promise | Bluebird, hookName: U) => { - const result = await fun + wrapPromiseFun: async (fun: PromiseFunction, params: U, hookName: V) => { + const result = await fun(params) - return PluginManager.Instance.runHook(hookName, result) + return PluginManager.Instance.runHook(hookName, result, params) + }, + + wrapFun: async (fun: RawFunction, params: U, hookName: V) => { + const result = fun(params) + + return PluginManager.Instance.runHook(hookName, result, params) }, runAction: (hookName: U, params?: T) => { - PluginManager.Instance.runHook(hookName, params) + PluginManager.Instance.runHook(hookName, undefined, params) .catch(err => logger.error('Fatal hook error.', { err })) } }