Skip to content

Mergent migration guide #1988

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 2 commits into from
Apr 28, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions docs/docs.json
Original file line number Diff line number Diff line change
Expand Up @@ -355,6 +355,10 @@
"guides/examples/vercel-sync-env-vars"
]
},
{
"group": "Migration guides",
"pages": ["migration-mergent"]
},
{
"group": "Community packages",
"pages": [
Expand Down
140 changes: 140 additions & 0 deletions docs/migration-mergent.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,140 @@
---
title: "Migrating from Mergent"
description: "A guide for migrating from Mergent to Trigger.dev"
sidebarTitle: "Migrating from Mergent"
---

Mergent is being absorbed into Resend, so if you’re running background jobs or scheduled tasks on Mergent, now is a good time to migrate. Trigger.dev is a modern, developer-friendly platform for background jobs, workflows, and scheduling.

### Why Trigger.dev?

- **Long-running, reliable tasks:** Write typical async code, no unfamiliar syntax to learn.
- **Automatic retries, concurrency, and scheduling:** Configure your tasks in your `trigger.config.ts` file.
- **Local dev that matches prod:** Run and debug jobs locally and view everything in the dashboard.
- **Scales with you:** Deploy your tasks to Trigger.dev Cloud with no infrastructure to manage. Or self-host.

## How to migrate to Trigger.dev

### Step 1: Set up Trigger.dev

1. **Create an account** at [Trigger.dev Cloud](https://cloud.trigger.dev).
2. **Create an organization and a project.**
3. **Install the CLI** and run the local dev server:

```bash
npx trigger.dev@latest init
npx trigger.dev@latest dev
```

You’ll get a local server that behaves just like production, and you’ll see your runs in the dashboard.

### Step 2: Convert your Mergent task to a Trigger.dev task

#### Example: Basic Mergent Task

Here’s a simple Mergent task that processes an image:

```ts processVideo.ts
export async function processVideoTask(req: { body: { videoUrl: string } }) {
const { videoUrl } = req.body;
// Do some video processing
const result = await processVideo(videoUrl);
return { success: true, processedUrl: result.url };
}
```

This is typically called by Mergent via HTTP POST, and you’d register the endpoint in the Mergent dashboard.

#### The same task in Trigger.dev

```ts trigger/processVideo.ts
import { task } from "@trigger.dev/sdk/v3";

export const processVideoTask = task({
id: "process-video",
run: async (payload: { videoUrl: string }) => {
const result = await processVideo(payload.videoUrl);
return { success: true, processedUrl: result.url };
},
});
```

**Key differences:**

- In Mergent, your task is an HTTP handler; in Trigger.dev, it’s a `task()` function that gets deployed on a managed worker for you.
- Trigger.dev gives you a typed payload, not a raw HTTP request.
- No need to handle HTTP status codes or errors—Trigger.dev handles retries and failures for you.
- You can export multiple tasks from a single file.

---

#### Scheduled task example

**Mergent scheduled task:**

You’d set up a schedule in the Mergent dashboard to hit your HTTP endpoint on a cron.

```ts dailyReport.ts
export async function dailyReportTask(req) {
await sendDailyReport();
}
```

**Trigger.dev scheduled task:**

```ts trigger/dailyReport.ts
import { schedules } from "@trigger.dev/sdk/v3";

export const dailyReportTask = schedules.task({
id: "daily-report",
cron: "0 0 * * *", // every day at midnight UTC
run: async () => {
await sendDailyReport();
},
});
```

- In Trigger.dev, you can define the schedule right in your code (or attach it in the dashboard).
- No need to set up HTTP endpoints for each scheduled job.

## Triggering your tasks

**Mergent:** You’d trigger a task by calling the Mergent API, specifying the URL and payload.

```ts
const Mergent = require("mergent");
const mergent = new Mergent("API_KEY");

mergent.tasks.create({
request: {
url: "https://your-app.com/api/processImage",
body: JSON.stringify({ imageUrl: "...", filters: ["blur"] }),
headers: { "Content-Type": "application/json" },
},
delay: { minutes: 5 },
});
```

**Trigger.dev:** You trigger a task directly from your codebase, no HTTP endpoint needed.

```ts
import { processImageTask } from "@/trigger/processImage";

await processImageTask.trigger({
imageUrl: "...",
filters: ["blur"],
}, {
delay: "5m",
});
```

- You can trigger tasks immediately, or add logic inside the task to delay execution (using `wait.for` or `wait.until`).
- No need to expose HTTP endpoints for every task.

**Summary:**
- Mergent tasks are HTTP handlers; Trigger.dev tasks are functions that get deployed on a managed worker for you.
- Scheduling and retries are built-in and configured in code.
- Trigger.dev tasks are type-safe, and easy to debug.
- You don’t need to manage endpoints or handle HTTP manually.

That’s it. You’re ready to migrate. If you need more advanced features such as concurrency, retries, metadata, chaining tasks, and more, check out the [Trigger.dev docs](https://trigger.dev/docs).