Collection Hooks
Collection Hooks are Hooks that run on Documents within a specific Collection. They allow you to execute your own logic during specific events of the Document lifecycle.
To add Hooks to a Collection, use the hooks
property in your Collection Config:
Config Options
All Collection Hooks accept an array of synchronous or asynchronous functions. Each Collection Hook receives specific arguments based on its own type, and has the ability to modify specific outputs.
beforeOperation
The beforeOperation
hook can be used to modify the arguments that operations accept or execute side-effects that run before an operation begins.
Available Collection operations include create
, read
, update
, delete
, login
, refresh
, and forgotPassword
.
The following arguments are provided to the beforeOperation
hook:
Option | Description |
---|---|
collection | The Collection in which this Hook is running against. |
context | Custom context passed between Hooks. More details. |
operation | The name of the operation that this hook is running within. |
req | The Web Request object. This is mocked for Local API operations. |
beforeValidate
Runs before the create
and update
operations. This hook allows you to add or format data before the incoming data is validated server-side.
Please do note that this does not run before the client-side validation. If you added a validate
function, this would be the lifecycle:
validate
runs on the client- if successful,
beforeValidate
runs on the server validate
runs on the server
The following arguments are provided to the beforeValidate
hook:
Option | Description |
---|---|
collection | The Collection in which this Hook is running against. |
context | Custom context passed between Hooks. More details. |
data | The incoming data passed through the operation. |
operation | The name of the operation that this hook is running within. |
originalDoc | The Document before changes are applied. |
req | The Web Request object. This is mocked for Local API operations. |
beforeChange
Immediately following validation, beforeChange
hooks will run within create
and update
operations. At this stage, you can be confident that the data that will be saved to the document is valid in accordance to your field validations. You can optionally modify the shape of data to be saved.
The following arguments are provided to the beforeChange
hook:
Option | Description |
---|---|
collection | The Collection in which this Hook is running against. |
context | Custom context passed between hooks. More details. |
data | The incoming data passed through the operation. |
operation | The name of the operation that this hook is running within. |
originalDoc | The Document before changes are applied. |
req | The Web Request object. This is mocked for Local API operations. |
afterChange
After a document is created or updated, the afterChange
hook runs. This hook is helpful to recalculate statistics such as total sales within a global, syncing user profile changes to a CRM, and more.
The following arguments are provided to the afterChange
hook:
Option | Description |
---|---|
collection | The Collection in which this Hook is running against. |
context | Custom context passed between hooks. More details. |
doc | The resulting Document after changes are applied. |
operation | The name of the operation that this hook is running within. |
previousDoc | The Document before changes were applied. |
req | The Web Request object. This is mocked for Local API operations. |
beforeRead
Runs before find
and findByID
operations are transformed for output by afterRead
. This hook fires before hidden fields are removed and before localized fields are flattened into the requested locale. Using this Hook will provide you with all locales and all hidden fields via the doc
argument.
The following arguments are provided to the beforeRead
hook:
Option | Description |
---|---|
collection | The Collection in which this Hook is running against. |
context | Custom context passed between hooks. More details. |
doc | The resulting Document after changes are applied. |
query | The Query of the request. |
req | The Web Request object. This is mocked for Local API operations. |
afterRead
Runs as the last step before documents are returned. Flattens locales, hides protected fields, and removes fields that users do not have access to.
The following arguments are provided to the afterRead
hook:
Option | Description |
---|---|
collection | The Collection in which this Hook is running against. |
context | Custom context passed between hooks. More details. |
doc | The resulting Document after changes are applied. |
query | The Query of the request. |
req | The Web Request object. This is mocked for Local API operations. |
beforeDelete
Runs before the delete
operation. Returned values are discarded.
The following arguments are provided to the beforeDelete
hook:
Option | Description |
---|---|
collection | The Collection in which this Hook is running against. |
context | Custom context passed between hooks. More details. |
id | The ID of the Document being deleted. |
req | The Web Request object. This is mocked for Local API operations. |
afterDelete
Runs immediately after the delete
operation removes records from the database. Returned values are discarded.
The following arguments are provided to the afterDelete
hook:
Option | Description |
---|---|
collection | The Collection in which this Hook is running against. |
context | Custom context passed between hooks. More details. |
doc | The resulting Document after changes are applied. |
id | The ID of the Document that was deleted. |
req | The Web Request object. This is mocked for Local API operations. |
afterOperation
The afterOperation
hook can be used to modify the result of operations or execute side-effects that run after an operation has completed.
Available Collection operations include create
, find
, findByID
, update
, updateByID
, delete
, deleteByID
, login
, refresh
, and forgotPassword
.
The following arguments are provided to the afterOperation
hook:
Option | Description |
---|---|
args | The arguments passed into the operation. |
collection | The Collection in which this Hook is running against. |
req | The Web Request object. This is mocked for Local API operations. |
operation | The name of the operation that this hook is running within. |
result | The result of the operation, before modifications. |
afterError
The afterError
Hook is triggered when an error occurs in the Payload application. This can be useful for logging errors to a third-party service, sending an email to the development team, logging the error to Sentry or DataDog, etc. The output can be used to transform the result object / status code.
The following arguments are provided to the afterError
Hook:
Argument | Description |
---|---|
error | The error that occurred. |
context | Custom context passed between Hooks. More details. |
graphqlResult | The GraphQL result object, available if the hook is executed within a GraphQL context. |
req | The PayloadRequest object that extends Web Request. Contains currently authenticated user and the Local API instance payload . |
collection | The Collection in which this Hook is running against. |
result | The formatted error result object, available if the hook is executed from a REST context. |
beforeLogin
For Auth-enabled Collections, this hook runs during login
operations where a user with the provided credentials exist, but before a token is generated and added to the response. You can optionally modify the user that is returned, or throw an error in order to deny the login operation.
The following arguments are provided to the beforeLogin
hook:
Option | Description |
---|---|
collection | The Collection in which this Hook is running against. |
context | Custom context passed between hooks. More details. |
req | The Web Request object. This is mocked for Local API operations. |
user | The user being logged in. |
afterLogin
For Auth-enabled Collections, this hook runs after successful login
operations. You can optionally modify the user that is returned.
The following arguments are provided to the afterLogin
hook:
Option | Description |
---|---|
collection | The Collection in which this Hook is running against. |
context | Custom context passed between hooks. More details. |
req | The Web Request object. This is mocked for Local API operations. |
token | The token generated for the user. |
user | The user being logged in. |
afterLogout
For Auth-enabled Collections, this hook runs after logout
operations.
The following arguments are provided to the afterLogout
hook:
Option | Description |
---|---|
collection | The Collection in which this Hook is running against. |
context | Custom context passed between hooks. More details. |
req | The Web Request object. This is mocked for Local API operations. |
afterMe
For Auth-enabled Collections, this hook runs after me
operations.
The following arguments are provided to the afterMe
hook:
Option | Description |
---|---|
collection | The Collection in which this Hook is running against. |
context | Custom context passed between hooks. More details. |
req | The Web Request object. This is mocked for Local API operations. |
response | The response to return. |
afterRefresh
For Auth-enabled Collections, this hook runs after refresh
operations.
The following arguments are provided to the afterRefresh
hook:
Option | Description |
---|---|
collection | The Collection in which this Hook is running against. |
context | Custom context passed between hooks. More details. |
exp | The expiration time of the token. |
req | The Web Request object. This is mocked for Local API operations. |
token | The newly refreshed user token. |
afterForgotPassword
For Auth-enabled Collections, this hook runs after successful forgotPassword
operations. Returned values are discarded.
The following arguments are provided to the afterForgotPassword
hook:
Option | Description |
---|---|
args | The arguments passed into the operation. |
collection | The Collection in which this Hook is running against. |
context | Custom context passed between hooks. More details. |
refresh
For Auth-enabled Collections, this hook allows you to optionally replace the default behavior of the refresh
operation with your own. If you optionally return a value from your hook, the operation will not perform its own logic and continue.
The following arguments are provided to the afterRefresh
hook:
Option | Description |
---|---|
args | The arguments passed into the operation. |
user | The user being logged in. |
me
For Auth-enabled Collections, this hook allows you to optionally replace the default behavior of the me
operation with your own. If you optionally return a value from your hook, the operation will not perform its own logic and continue.
The following arguments are provided to the me
hook:
Option | Description |
---|---|
args | The arguments passed into the operation. |
user | The user being logged in. |
TypeScript
Payload exports a type for each Collection hook which can be accessed as follows: