Remix setup guide
This guide will show you how to setup Trigger.dev in your existing Remix project, test an example task, and view the run.
Prerequisites
- Setup a project in
- Ensure TypeScript is installed
- Create a Trigger.dev account
- Create a new Trigger.dev project
Initial setup
Run the CLI `init` command
The easiest way to get started is to use the CLI. It will add Trigger.dev to your existing project, create a /trigger
folder and give you an example task.
Run this command in the root of your project to get started:
It will do a few things:
- Log you into the CLI if you’re not already logged in.
- Create a
trigger.config.ts
file in the root of your project. - Ask where you’d like to create the
/trigger
directory. - Create the
/trigger
directory with an example task,/trigger/example.[ts/js]
.
Install the “Hello World” example task when prompted. We’ll use this task to test the setup.
Run the CLI `dev` command
The CLI dev
command runs a server for your tasks. It watches for changes in your /trigger
directory and communicates with the Trigger.dev platform to register your tasks, perform runs, and send data back and forth.
It can also update your @trigger.dev/*
packages to prevent version mismatches and failed deploys. You will always be prompted first.
Perform a test run using the dashboard
The CLI dev
command spits out various useful URLs. Right now we want to visit the Test page
You should see our Example task in the list
, select it. Most tasks have a “payload” which you enter in the JSON editor , but our example task doesn’t need any input.Press the “Run test” button
.View your run
Congratulations, you should see the run page which will live reload showing you the current state of the run.
If you go back to your terminal you’ll see that the dev command also shows the task status and links to the run log.
Set your secret key locally
Set your TRIGGER_SECRET_KEY
environment variable in your .env
file. This key is used to authenticate with Trigger.dev, so you can trigger runs from your Remix app. Visit the API Keys page in the dashboard and select the DEV secret key.
For more information on authenticating with Trigger.dev, see the API keys page.
Triggering your task in Remix
Create an API route
Create a new file called api.hello-world.ts
(or api.hello-world.js
) in the app/routes
directory like this: app/routes/api.hello-world.ts
.
Add your task
Add this code to your api.hello-world.ts
file which imports your task:
Trigger your task
Run your Remix app:
Run the dev server from Step 2. of the Initial Setup section above if it’s not already running:
Now visit the URL in your browser to trigger the task. Ensure the port number is the same as the one you’re running your Remix app on. For example, if you’re running your Remix app on port 3000, visit:
You should see the CLI log the task run with a link to view the logs in the dashboard.
Visit the Trigger.dev dashboard to see your run.
Manually add your environment variables (optional)
If you have any environment variables in your tasks, be sure to add them in the dashboard so deployed code runs successfully. In Node.js, these environment variables are accessed in your code using process.env.MY_ENV_VAR
.
In the sidebar select the “Environment Variables” page, then press the “New environment variable” button.
You can add values for your local dev environment, staging and prod.
You can also add environment variables in code by following the steps on the Environment Variables page.
Deploying your task to Trigger.dev
For this guide, we’ll manually deploy your task by running the CLI deploy command below. Other ways to deploy are listed in the next section.
Other ways to deploy
Use GitHub Actions to automatically deploy your tasks whenever new code is pushed and when the trigger
directory has changes in it. Follow this guide to set up GitHub Actions.
Deploying to Vercel Edge Functions
Before we start, it’s important to note that:
- We’ll be using a type-only import for the task to ensure compatibility with the edge runtime.
- The
@trigger.dev/sdk/v3
package supports the edge runtime out of the box.
There are a few extra steps to follow to deploy your /api/hello-world
API endpoint to Vercel Edge Functions.
Update your API route
Update your API route to use the runtime: "edge"
option and change it to an action()
so we can trigger the task from a curl request later on.
Update the Vercel configuration
Create or update the vercel.json
file with the following:
Update package.json scripts
Update your package.json
to include the following scripts:
Deploy to Vercel
Push your code to a Git repository and create a new project in the Vercel dashboard. Select your repository and follow the prompts to complete the deployment.
Add your Vercel environment variables
In the Vercel project settings, add your Trigger.dev secret key:
You can find this key in the Trigger.dev dashboard under API Keys and select the environment key you want to use.
Deploy your project
Once you’ve added the environment variable, deploy your project to Vercel.
Ensure you have also deployed your Trigger.dev task. See deploy your task step.
Test your task in production
After deployment, you can test your task in production by running this curl command:
This sends a POST request to your API endpoint with a JSON payload.
Additional notes
The vercel-build
script in package.json
is specific to Remix projects on Vercel, ensuring that static assets are correctly copied to the build output.
The runtime: "edge"
configuration in the API route allows for better performance on Vercel’s Edge Network.
Additional resources for Remix
Remix - triggering tasks using webhooks
How to create a webhook handler in a Remix app, and trigger a task from it.
Useful next steps
Was this page helpful?