@envelop/types
5.2.1
Patch Changes
- #2486
914f9edThanks @EmrysMyrddin ! - Fix the name of the new envelop instrumentation API
5.2.0
Minor Changes
-
#2430
a107c89Thanks @EmrysMyrddin ! - ## NewInstrumentsAPIIntroducation of a new API allowing to instrument the graphql pipeline.
This new API differs from already existing Hooks by not having access to intup/output of phases. The goal of
Instrumentsis to run allow running code before, after or araound the whole process of a phase, incuding plugins hooks executions.The main use case of this new API is observability (monitoring, tracing, etc…).
Basic usage
import { envelop } from '@envelop/core' import Sentry from '@sentry/node' const getEnveloped = envelop({ plugins: [ { instruments: { execute: ({ context }, wrapped) => Sentry.startSpan({ name: 'Graphql Operation' }, async () => { try { await wrapped() } catch (err) { Sentry.captureException(err) } }) } } ] })Mutliple instruments plugins
It is possilbe to have multiple instruments plugins (Prometheus and Sentry for example), they will be automatically composed by envelop in the same order than the plugin array (first is outtermost, last is inner most).
import { useOpentelemetry } from '@envelop/opentelemetry' import { useSentry } from '@envelop/sentry' const getEnveloped = envelop({ plugins: [useSentry(), useOpentelemetry()] })Custom instruments ordering
If the default composition ordering doesn’t suite your need, you can mannually compose instruments. This allows to have a different execution order of hooks and instruments.
import { useOpentelemetry } from '@envelop/opentelemetry' import { composeInstruments, useSentry } from '@envelop/sentry' const { instruments: sentryInstruments, ...sentryPlugin } = useSentry() const { instruments: otelInstruments, ...otelPlugin } = useOpentelemetry() const instruments = composeInstruments([otelInstruments, sentryInstruments]) const getEnveloped = envelop({ plugins: [{ instruments }, sentryPlugin, otelPlugin] })
5.1.1
Patch Changes
- #2455
5b6a166Thanks @ardatan ! - dependencies updates:- Added dependency
@whatwg-node/promise-helpers@^1.0.0↗︎ (todependencies)
- Added dependency
5.1.0
Minor Changes
- #2438
9bd1b20Thanks @ardatan ! - Addcontextfield toonExecuteandonSubscribehooks payloads. This harmonize all the hooks invovled in the handling of a graphql operation.
5.0.0
Major Changes
- #1986
68e7a2a5Thanks @EmrysMyrddin ! - Breaking Change: Support of Node 16 is dropped.
4.0.1
Patch Changes
- #1896
834e1e39Thanks @EmrysMyrddin ! - add support for @defer and @stream
4.0.0
Major Changes
3.0.2
Patch Changes
-
#1725
c1eb2c09Thanks @n1ru4l ! - dependencies updates:- Updated dependency
tslib@^2.5.0↗︎ (from^2.4.0, independencies)
- Updated dependency
3.0.1
Patch Changes
- #1587
e2ff77edThanks @enisdenjo ! - Don’t useIdTypeScript generic utility that can cause a circular constraint error
2.4.0
Minor Changes
-
#1499
1f7af02bThanks @viniciuspalma ! - Adding tslib to package dependenciesProjects that currently are using yarn Berry with PnP or any strict dependency resolver, that requires that all dependencies are specified on package.json otherwise it would endue in an error if not treated correct
Since https://www.typescriptlang.org/tsconfig#importHelpers is currently being used, tslib should be exported as a dependency to external runners get the proper import.
Change on each package:
// package.json { "dependencies": { "tslib": "^2.4.0" } }
2.3.1
Patch Changes
- 071f946: Fix CommonJS TypeScript resolution with
moduleResolutionnode16ornodenext
2.3.0
Minor Changes
- 8bb2738: Support TypeScript module resolution.
2.2.1
Patch Changes
- fbf6155: update package.json repository links to point to the new home
2.2.0
Minor Changes
-
af23408: Pass context to registerContextErrorHandler
export const useMyHook = (): Plugin => { return { onPluginInit(context) { context.registerContextErrorHandler(({ context }) => { console.error( 'Error occurred during context creation but at least I have the context so far', context ) }) } } }
2.1.0
Minor Changes
- d5115b4: add
setResulttoAfterValidateEventPayloadfor altering the validation errors.
2.0.0
Major Changes
-
aac65ef: Move
onResolverCalledfrom withinOnExecuteHookResultandOnSubscribeHookResultto thePlugintype.import type { Plugin } from "@envelop/core"; const plugin: Plugin = { onExecute() { - return { - onResolverCalled() {} - } - } + }, + onResolverCalled() {}, }We highly recommend avoiding to use any plugins that use
onResolverCalledwithin your production environment as it has severe impact on the performance of the individual resolver functions within your schema.The schema resolver functions are now ONLY wrapped if any plugin in your envelop setup uses the
onResolverCalledhook.If you need any shared state between
onExecuteandonResolverCalledyou can share it by extending the context object.import type { Plugin } from '@envelop/core' const sharedStateSymbol = Symbol('sharedState') const plugin: Plugin = { onExecute({ extendContext }) { extendContext({ [sharedStateSymbol]: { value: 1 } }) }, onResolverCalled({ context }) { const sharedState = context[sharedStateSymbol] // logs 1 console.log(sharedState.value) } }
Minor Changes
-
4106e08: Add new option
breakContextBuildingtoOnContextBuildingEventPayload.This allows short-circuiting the context building phase. Please use this with care as careless usage of it can result in severe errors during the execution phase, as the context might not include all the fields your schema resolvers need.
1.5.1
Patch Changes
-
b1a0331: Properly list
@envelop/coreas apeerDependencyin plugins.This resolves issues where the bundled envelop plugins published to npm had logic inlined from the
@envelop/corepackage, causinginstanceofcheck ofEnvelopErrorto fail.
1.5.0
Minor Changes
- 090cae4: GraphQL v16 support
1.4.0
Minor Changes
- 04120de: add support for GraphQL.js 16
1.3.0
Minor Changes
- 365a982: Allow async OnExecuteDone hook
1.2.0
Minor Changes
- d65e35d: add enableIf utility to enable plugins conditionally
- 26475c9: useErrorHandler: Pass in the execution arguments to the error handler callbacks.
1.1.0
Minor Changes
-
7704fc3: Add API for registering a context creation error handler.
export const useMyHook = (): Plugin => { return { onPluginInit(context) { context.registerContextErrorHandler(({ error, setError }) => { console.error('Error occurred during context creation.', error) setError(new Error('Something went wrong :(')) }) } } }
1.0.2
Patch Changes
- 94db02d: Added new helper
handleStreamOrSingleExecutionResult - 94db02d: Update usage of plugins to use the correct
isAsyncIterableand new helperhandleStreamOrSingleExecutionResult
1.0.1
Patch Changes
- c24a8fd: re-use graphql “execute” & “subscribe” types
- adca399: add jsdoc comments for hook types
1.0.0
Major Changes
- 40bc444: v1 major release for envelop packages
Minor Changes
- dbb241d: allow hooking into published subscribe values
0.4.2
Patch Changes
- a7321e1: Fix issues with compiled d.ts
0.4.1
Patch Changes
- 932f6a8: Added better type-safety for contextValue in OnExecute hook
0.4.0
Minor Changes
- 50dffaa: Added new hook for onEnveloped
Patch Changes
- 778c207: Better type safety for OnEnveloped hook
0.3.0
Minor Changes
- 2113527: Extend Envelop plugin API with the ability to access and replace resolver function
Patch Changes
- 28ad742: Improve TypeScript types
0.2.1
Patch Changes
- 7f4901d: Fix issues with contextFactory and missing context coming from GraphQL pipeline orchestrator
0.2.0
Minor Changes
- a5bee94: * Allow access to context in all phases
- Improve usage of
getEnvelopedfunction and allow to pass initial context there
- Improve usage of
- eb6f53b: ESM Support for all plugins and envelop core
0.1.4
Patch Changes
- ced704e: Allow plugins to stop execution and return errors
0.1.3
Patch Changes
- 5fc65a4: Improve type safety for plugins context
0.1.2
Patch Changes
- f5177eb: Added
setResultto the result of onResolverCalled
0.1.1
Patch Changes
- 925a1ea: Extend
onSchemaChangeand allow to override schema. Make sure to avoid infinite loops.
0.1.0
Minor Changes
- 2fba0b4: Initial version bump
0.0.2
Patch Changes
- b1333b0: Initial packages release
0.0.1
Patch Changes
- c499ae8: First bump as envelop
- 2cfc726: Fixes