Edge Functions

Getting Started with Edge Functions

Learn how to create, test, and deploy your first Edge Function using the Supabase CLI.


This guide walks you through creating, testing locally, deploying, and invoking a Supabase Edge Function using the CLI. By the end, you'll have a working function running on Supabase's global edge network.

You can also create and deploy functions directly from the Supabase Dashboard. Read the Dashboard Quickstart guide for more information.

Prerequisites#

  • Make sure you have the Supabase CLI installed and configured. Read the CLI installation guide for installation methods and troubleshooting.
  • Running and testing Supabase Edge Functions locally requires Docker or a Docker-compatible runtime.

Step 1: Create or configure your project#

If you don't have a project yet, initialize a new Supabase project in your current directory.

1
mkdir my-edge-functions-project
2
cd my-edge-functions-project
3
supabase init

If you already have a project locally, navigate to your project directory. If you haven't configured the project for Supabase yet, make sure to run the supabase init command.

1
cd your-existing-project
2
supabase init # Initialize Supabase, if you haven't already

Step 2: Create your first function#

Within your project, generate a new Edge Function with a basic template:

1
supabase functions new hello-world

This creates a new function at supabase/functions/hello-world/index.ts with this starter code:

1
export default {
2
fetch: withSupabase({ allow: ['public', 'secret'] }, async (req, ctx) => {
3
const { name } = await req.json()
4
5
return Response.json({
6
message: `Hello ${name}!`,
7
})
8
}),
9
}

This function accepts a JSON payload with a name field and returns a greeting message.

Step 3: Test your function locally#

After starting Docker, start the local development server to test your function:

1
supabase start # Start all Supabase services
2
supabase functions serve hello-world

On first use, the supabase start command downloads Docker images, and starts all Supabase services locally, which can take a few minutes.

Your function is now running at http://localhost:54321/functions/v1/hello-world. Hot reloading is enabled, which means that the server automatically reloads when you save changes to your function code. Keep this terminal window open.

Function not starting locally?#

  • Make sure Docker is running
  • Run supabase stop then supabase start to restart services

Port already in use?#

  • Check what's running with supabase status
  • Stop other Supabase instances with supabase stop

Step 4: Send a test request#

Open a new terminal and test your function with curl. You can find your local Publishable key, by running supabase status, or you can find the complete curl command already in functions/hello-world/index.ts.

1
curl -i --location --request POST 'http://127.0.0.1:54321/functions/v1/hello-world' \
2
--header 'apiKey: <SUPABASE_PUBLISHABLE_KEY>' \
3
--data '{"name":"Functions"}'

After running this curl command, you should see:

1
{ "message": "Hello Functions!" }

You can also try different inputs. Change "Functions" to "World" in the curl command and run it again to see the response change.

Step 5: Connect to your Supabase project#

To deploy your function globally, you need to connect your local project to a Supabase project.

First, login to the CLI if you haven't already, and authenticate with Supabase. This opens your browser to authenticate with Supabase; complete the login process in your browser.

1
supabase login

Next, list your Supabase projects to find your project ID:

1
supabase projects list

Next, copy your project ID from the output, then connect your local project to your remote Supabase project. Replace YOUR_PROJECT_ID with the ID from the previous step.

1
supabase link --project-ref [YOUR_PROJECT_ID]

Step 6: Deploy to production#

Deploy your function to Supabase's global edge network:

1
supabase functions deploy hello-world

If you want to deploy all functions, run the deploy command without specifying a function name:

1
supabase functions deploy

When the deployment is successful, your function is automatically distributed to edge locations worldwide.

Step 7: Test your live function#

🎉 Your function is now live! Test it with your project's publishable key that you can find in the Settings > API Keys section of the Dashboard:

1
curl --request POST 'https://[YOUR_PROJECT_ID].supabase.co/functions/v1/hello-world' \
2
--header 'apikey: <SUPABASE_PUBLISHABLE_KEY>' \
3
--header 'Content-Type: application/json' \
4
--data '{"name":"Production"}'

Expected response:

1
{ "message": "Hello Production!" }

Usage#

Now that your function is deployed, you can invoke it from within an app:

1
import { createClient } from '@supabase/supabase-js'
2
3
const supabase = createClient('https://[YOUR_PROJECT_ID].supabase.co', 'YOUR_PUBLISHABLE_KEY')
4
5
const { data, error } = await supabase.functions.invoke('hello-world', {
6
body: { name: 'JavaScript' },
7
})
8
9
console.log(data) // { message: "Hello JavaScript!" }