Skip to content

isContext

predicates
Source Code | Documentation

Returns a predicate that checks whether the hook context matches the given criteria. You can filter by path (service name), type (before/after/around/error), and/or method (find/get/create/update/patch/remove).

ts
  import { 
isContext
} from 'feathers-utils/predicates';

Example

ts
import { iff, isContext } from 'feathers-utils/predicates'

app.service('users').hooks({
  before: { all: [iff(isContext({ method: 'create', type: 'before' }), validateHook())] }
})

Hooks for predicates

HookDescription
iff

Conditionally executes a series of hooks when the predicate is truthy. The predicate can be a boolean value or a sync/async function. Supports an .else(...) chain for the falsy branch. Also exported as when.

iffElse

Executes one array of hooks when the predicate is truthy, or another array when it is falsy. The predicate can be a boolean or a sync/async function. Unlike iff, both branches are provided upfront without chaining.

skippable

Wraps a hook so it can be conditionally skipped based on a predicate. When the predicate returns true, the wrapped hook is skipped entirely. Commonly used with shouldSkip and addSkip for runtime hook control.

throwIf

Throws a BadRequest error when the given predicate function returns true. The predicate receives the hook context and can be async. Useful for validating conditions before proceeding with a request.

unless

Executes a series of hooks when the predicate is falsy --- the inverse of iff. The predicate can be a boolean or a sync/async function. Useful for applying hooks to all contexts except those matching a condition.

Type declaration

Show Type Declarations
ts
export type IsContextOptions = {
  path?: MaybeArray<string>
  type?: MaybeArray<HookType>
  method?: MaybeArray<MethodName>
}
/**
 * Returns a predicate that checks whether the hook context matches the given criteria.
 * You can filter by `path` (service name), `type` (before/after/around/error),
 * and/or `method` (find/get/create/update/patch/remove).
 *
 * @example
 * ```ts
 *
 *
 * app.service('users').hooks({
 *   before: { all: [iff(isContext({ method: 'create', type: 'before' }), validateHook())] }
 * })
 * ```
 *
 * @see https://utils.feathersjs.com/predicates/is-context.html
 */
export declare const isContext: (
  options: IsContextOptions,
) => (context: any) => boolean
ArgumentTypeDescription
optionsIsContextOptions

Released under the MIT License.