Open Source
Self Hosting
Tutorial
Sep 8, 2023
In this article, we'll walk you through how to deploy and self-host Documenso using Vercel, Supabase, and Resend.
You'll learn:
How to set up a Postgres database using Supabase,
How to install SMTP with Resend,
How to deploy your project with Vercel.
If you don't know what Documenso is, it's an open-source alternative to DocuSign, with the mission to create an open signing infrastructure while embracing openness, cooperation, and transparency.
Prerequisites
Before we start, make sure you have a GitHub account. You also need Node.js and npm installed on your local machine (note: you also have the option to host it on a cloud environment using Gitpod for example; that would be another post). If you need accounts on Vercel, Supabase, and Resend, create them by visiting the Vercel, Supabase, and Resend websites.
Checklist:
Have a GitHub account
Install Node.js
Install npm
Have a Vercel account
Have a Supabase account
Have a Resend account
Step-by-Step guide to deploying Documenso with Vercel, Supabase, and Resend
To deploy Documenso, we'll take the following steps:
Fork the Documenso repository
Clone the forked repository and install dependencies
Create a new project on Supabase
Copy the Supabase Postgres database connection URL
Create a `.env` file
Run the migration on the Supabase Postgres Database
Get your SMTP Keys on Resend
Create a new project on Vercel
Add Environment Variables to your Vercel project
So, you're ready? Let’s dive in!
Step 1: Fork the Documenso repository
Start by creating a fork of Documenso on GitHub. You can do this by visiting the Documenso repository and clicking on the 'Fork' button. (Also, star the repo!)
Choose your GitHub profile as the owner and click on 'Create fork' to create a fork of the repo.
Step 2: Clone the forked repository and install dependencies
Clone the forked repository to your local machine in any directory of your choice. Open your terminal and enter the following commands:
You can now navigate into the directory and install the project’s dependencies:
Step 3: Create a new project on Supabase
Now, let's set up the database.
If you haven't already, create a new project on Supabase. This will automatically create a new Postgres database for you.
On your Supabase dashboard, click the 'New project' button and choose your organization.
On the 'Create a new project' page, set a database name of documenso and a secure password for your database. Choose a region closer to you, a pricing plan, and click on 'Create new project' to create your project.
Step 4: Copy the Supabase Postgres database connection URL
In your project, click the 'Settings' icon at the bottom left.
Under the 'Project Settings' section, click 'Database' and scroll down to the 'Connection string' section. Copy the 'URI' and update it with the password you chose in the previous step.
Step 5: Create a `.env` file
Create a .env file in the root of your project by copying the contents of the .env.example file.
Add the connection string you copied from your Supabase dashboard to the DATABASE_URL variable in the .env file.
The .env should look like this:
Step 6: Run the migration on the Supabase Postgres Database
Run the migration on the Supabase Postgres Database using the following command:
Step 7: Get your SMTP Keys on Resend
So, you've just cloned Documenso, installed dependencies on your local machine, and set your database using Supabase. Now, SMTP is missing. Emails won't go out! Let's fix it with Resend.
In the Resend dashboard, click 'Add API Key' to create a key for Resend SMTP.
Next, add and verify your domain in the 'Domains' section on the sidebar. This will allow you to send emails from any address associated with your domain.
You can update your `.env` file with the following:
Step 8: Create a new project on Vercel
You set the database with Supabase and are SMTP-ready with Resend. Almost there! The next step is to deploy the project — we'll use Vercel for that.
On your Vercel dashboard, create a new project using the forked project from your GitHub repositories. Select the project among the options and click 'Import' to start running Documenso.
Step 9: Add Environment Variables to your Vercel project
In the 'Configure Project' page, adding the required Environmental Variables is essential to ensure the application deploys without any errors.
Specifically, for the NEXT_PUBLIC_WEBAPP_URL and NEXTAUTH_URL variables, you must add .vercel.app to your Project Name. This will form the deployment URL, which will be in the format: https://[project_name].vercel.app.
For example, in my case, the deployment URL is https://documenso-supabase-web.vercel.app.
This is a sample .env to deploy. Copy and paste it to auto-populate the fields and click Deploy. Now, you only need to wait for your project to deploy. You’re going live — enjoy!
Wrapping up
Congratulations! 🎉 You've successfully deployed Documenso using Vercel, Supabase, and Resend. You're now ready to create and sign your own documents with your self-hosted Documenso!
In this step-by-step guide, you learned how to:
set up a Postgres database using Supabase,
install SMTP with Resend,
deploy your project with Vercel.
Over to you! How was the tutorial? If you enjoyed it, please do share! And if you have any questions or comments, please reach out to me on Twitter / X (DM open) or Discord.
We're building an open-source alternative to DocuSign and welcome every contribution. Head over to the GitHub repository and leave us a Star!