All files / lib/hooks/authorize authorize.hook.ts

0% Statements 0/14
0% Branches 0/11
0% Functions 0/2
0% Lines 0/14

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50                                                                                                   
import { shouldSkip } from "@artesa/feathers-utils";
 
import { makeDefaultOptions } from "./authorize.hook.utils";
import authorizeAfter from "./authorize.hook.after";
import authorizeBefore from "./authorize.hook.before";
 
import {
  HookContext
} from "@feathersjs/feathers";
 
import {
  getAbility
} from "./authorize.hook.utils";
 
import {
  AuthorizeHookOptions
} from "../../types";
 
const HOOKNAME = "authorize";
 
export default (options?: AuthorizeHookOptions): ((context: HookContext) => Promise<HookContext>) => {
  options = makeDefaultOptions(options);
  const beforeHook = authorizeBefore(options);
  const afterHook = authorizeAfter(options);
  return async (context: HookContext): Promise<HookContext> => {
    if (
      shouldSkip(HOOKNAME, context) ||
      !context.params ||
      context.type === "error"
    ) {
      return context;
    }
 
    const modelName = options.getModelName(context);
    if (!modelName) {
      return Promise.resolve(context);
    }
 
    context.params.ability = await getAbility(context, options);
    if (!context.params.ability) {
      // Interne Anfrage oder nicht authentifiziert -> Ignorieren
      return context;
    }
 
    return (context.type === "before") 
      ? await beforeHook(context) 
      : await afterHook(context);
  };
};