Create an Edge Functions integration
It’s possible for frameworks and other tools to dynamically create edge function files and declarations through integrations with the build process. For inspiration, you can explore the framework-specific examples on the Edge Functions overview. The examples highlight different use cases for developing build-generated edge functions.
This page will help you learn how to integrate your framework with Edge Functions by generating edge function files and declarations. If your framework’s build process uses Vite, then you can use the Netlify Edge Functions Vite plugin to generate a catch-all edge function file and declaration to serve all requests.
# Generate function files
To generate edge function files, a framework emits one function file per edge function under .netlify/edge-functions
. Build-generated edge function files go in this internal directory so as to not interfere with user-created files.
The generated function must be compatible with the Deno runtime. This means the following:
- Imports of Node built-in modules must be prefixed with
node:
, for exampleimport { randomBytes } from "node:crypto"
. - All npm modules must be bundled in the function or changed to use URL imports. You can make a URL import directly in the edge function, for example
import React from "https://esm.sh/react"
, or by using an import map. - The generated file should use ES Modules format.
- If your bundler supports build targets, it should target
browser
orworker
.
# Generate declarations
The framework must generate declarations either inline in the function files or in a manifest file at .netlify/edge-functions/manifest.json
. The manifest file is a JSON object with the same structure as the edge_functions
object from netlify.toml
.
Avoid collisions between integrations
If you expect your integration to be used in conjunction with other integrations, avoid overwriting declarations from other integrations and be mindful about declaration order.
Declarations for build-generated edge functions support additional properties not available to user-created edge functions. Which additional properties are supported depends on whether the function is declared inline or in manifest.json
.
Build-generated property | Supported inline | Supported in manifest.json |
---|---|---|
generator | ✓ | ✓ |
name | ✓ | ✓ |
import_map | ✓ | |
version | ✓ |
These additional properties are for the following purposes:
generator
is an optional property for noting the integration that generated the edge function. Setting this for your integration helps Netlify’s observability; this does not affect the user experience. We recommend using a value with a format of@integration-name/plugin-name@1.2.3
, where the plugin version is included at the end.name
is an optional property that allows you to set a display name for the function that appears in the Netlify UI.import_map
is an optional property for specifying the path to an import map file. If this path is relative, it will be resolved in relation to the manifest file itself. Themanifest.json
declaration example below uses an import map found at.netlify/edge-functions/import_map.json
, for example:Note that any imports prefixed with{ "imports": { "example": "https://example.com", "netlify:edge": "this will be ignored, netlify: is a reserved prefix" } }
netlify:
are reserved, and may be overridden by built-in definitions.version
is a required metadata property formanifest.json
that tracks the version of the manifest format being used. Set this to1
as demonstrated in themanifest.json
example below.
Here are examples of build-generated declarations:
import type { IntegrationsConfig } from "@netlify/edge-functions";
export default async () => new Response("Hello, world!", {
headers: {
'cache-control': 'public, s-maxage=3600'
}
});
export const config: IntegrationsConfig = {
path: "/hello",
generator: "@cool-framework/nice-plugin@1.0.0",
name: "greeting",
cache: "manual",
onError: "bypass"
};
{
"functions": [
{
"path": "/admin",
"function": "auth",
"generator": "@cool-framework/nice-plugin@1.0.0",
"name": "/admin auth handler",
"onError": "/unavailable"
},
{
"pattern": "^/dashboard(?:/([^/#\\?]+?))[/#\\?]?$",
"function": "auth",
"name": "/dashboard/* auth handler"
},
{
"path": "/blog/*",
"excludedPath": "/blog/img/*",
"function": "rewriter",
"cache": "manual",
"onError": "bypass",
},
{
"pattern": "/products/(.*)",
"excludedPattern": "/products/things/(.*)",
"function": "highlight"
}
],
"import_map": "./import_map.json",
"version": 1
}
# Contact us
If you’d like to create an Edge Functions integration for a framework or other developer tool, we encourage you to let us know by reaching out through our technology partner program so we can help you.
We welcome your feedback on building integrations with this feature. Visit our Forums to join the conversation about Edge Functions.
Did you find this doc useful?
Your feedback helps us improve our docs.