mirror of
https://github.com/lingble/twenty.git
synced 2025-11-01 21:27:58 +00:00

* Begin docs improvement * Keep improving documentation * Upgrade Docusarus * Fix broken links
48 lines
1.4 KiB
Plaintext
48 lines
1.4 KiB
Plaintext
---
|
|
title: Message Queue
|
|
sidebar_position: 5
|
|
sidebar_custom_props:
|
|
icon: TbSchema
|
|
---
|
|
|
|
Queues facilitate async operations to be performed. They can be used for performing background tasks such as sending a welcome email on register.
|
|
Each use case will have its own queue class extended from `MessageQueueServiceBase`.
|
|
|
|
Currently, queue supports two drivers which can be configurred by env variable `MESSAGE_QUEUE_TYPE`.
|
|
1. `pg-boss`: this is the default driver, which uses [pg-boss](https://github.com/timgit/pg-boss) under the hood.
|
|
2. `bull-mq`: this uses [bull-mq](https://bullmq.io/) under the hood.
|
|
|
|
## Steps to create and use a new queue
|
|
|
|
1. Add a queue name for your new queue under enum `MESSAGE_QUEUES`.
|
|
2. Provide the factory implementation of the queue with the queue name as the dependency token.
|
|
3. Inject the queue that you created in the required module/service with the queue name as the dependency token.
|
|
4. Add worker class with token based injection just like producer.
|
|
|
|
### Example usage
|
|
```ts
|
|
class Resolver {
|
|
constructor(@Inject(MESSAGE_QUEUES.custom) private queue: MessageQueueService) {}
|
|
|
|
async onSomeAction() {
|
|
//business logic
|
|
await this.queue.add(someData);
|
|
}
|
|
}
|
|
|
|
//async worker
|
|
class CustomWorker {
|
|
constructor(@Inject(MESSAGE_QUEUES.custom) private queue: MessageQueueService) {
|
|
this.initWorker();
|
|
}
|
|
|
|
async initWorker() {
|
|
await this.queue.work(async ({ id, data }) => {
|
|
//worker logic
|
|
});
|
|
}
|
|
}
|
|
|
|
```
|
|
|