Edge Developer Platform
  • Edge Functions
    • Overview
    • Getting Started
    • Operation Guide
      • Function Management
      • Web Debugging
      • Function Trigger
      • Environment Variable
    • Runtime APIs
      • addEventListener
      • Cache
      • Cookies
      • Encoding
      • Fetch
      • FetchEvent
      • Headers
      • Request
      • Response
      • Streams
        • ReadableStream
        • ReadableStreamBYOBReader
        • ReadableStreamDefaultReader
        • TransformStream
        • WritableStream
        • WritableStreamDefaultWriter
      • Web Crypto
      • Web standards
      • Images
        • ImageProperties
    • Sample Functions
      • Example Overview
      • 301 Redirect
      • Obtaining Client URL Information
      • Customization Based on Client Geo Location
      • Obtaining Client Geo Location Information
      • Batch Redirect
      • Returning an HTML Page
      • Returning a JSON Object
      • Fetch Remote Resources
      • Authenticating a Request Header
      • Modifying a Response Header
      • Performing an A/B Test
      • Setting Cookies
      • Performing Redirect Based on the Request Location
      • Using the Cache API
      • Caching POST Requests
      • Responding in Streaming Mode
      • Merging Resources and Responding in Streaming Mode
      • Protecting Data from Tampering
      • Rewriting a m3u8 File and Configuring Authentication
      • Adaptive Image Resize
      • Image Adaptive WebP
      • Customize Referer restriction rules
      • Remote Authentication
      • HMAC Digital Signature
      • Naming a Downloaded File
      • Obtaining Client IP Address
    • Best Practices
      • Adaptive Image Format Conversion via Edge Functions

Environment Variable

Overview

Environment variables are key-value pairs set in the runtime environment of edge functions, which can be accessed as global variables in edge function scripts without the need for explicit importing or initialization. By using environment variables, function code can be decoupled from configuration. Their common uses are as follows:
Configuration decoupling: Environment variables allow developers to configure edge functions without modifying the function's code, meaning developers can set different variable values for different environments (such as development, testing, and production) to control function behavior.
Security: By storing sensitive information (like API keys) in environment variables instead of hardcoding them into the code, application security is enhanced. This approach reduces the risk of leakage of sensitive information in the code repository and simplifies key management.
Flexibility: Environment variables provide great flexibility for edge functions, allowing developers to adjust the behavior of edge functions as needed. For example, developers can use environment variables to achieve grayscale release by controlling different user groups to access different versions of code or configuration.

Directions

1. Log in to the EdgeOne console, and click Site List in the left menu bar. Subsequently, in the Site List, click the Site you want to configure.
2. On the site details page, click Edge Functions > Function Management.
3. On the Function Management page, click the specific function name. At the bottom of the page, find the Environment Variables module. If the function has not been created, follow the Creating and Deploying a Function guide to complete the function creation first.

Creating and Deploying Environment Variables

1. In the Environment Variables module, click Quick add and configure the relevant parameters.

Parameter Name
Description
Variable name
Required. It can only include uppercase and lowercase letters, digits, and special characters limited to @, ., -, ,. The length is restricted to 1 to 64 characters. The variable name cannot be duplicated and cannot be modified after creation. For example, keytest.
Variable type
Required. It supports String and JSON types.
String: After this option is selected, the input variable value content will be saved as a string. For specific usage, refer to the Edge Functions Referencing Environment Variables section for the variable type String.
JSON: After this option is selected, the input variable value content will be saved as a JSON array. The edge functions will automatically parse the variable value into a JavaScript object without the need to manually call JSON.parse(). For specific usage, refer to the Edge Functions Referencing Environment Variables section for the variable type JSON.
Value
Required. It supports a maximum of 5 KB. For example, if the type is String, enter valuetest as the variable value. If the type is JSON, the variable value will be validated to check if the input content follows the JSON data structure. If it does not, there will be an exception prompt.
2. Click OK to complete the creation of the environment variable. A single edge function supports creating up to 64 environment variables.

3. Click Deploy to make it effective.

Edge Functions Referencing Environment Variables

If the environment variables referenced by the function do not contain special characters @, ., -, ,, they can be referenced in the form of env.envname. For example, if the environment variable envname is keytest, the way to reference it in edge function code is env.keytest. For specific usage, refer to the section for the variable type String.
If the name of the environment variable referenced by the function contains special characters @, ., -, ,, it can be referenced in the form of env['envname']. For example, if the environment variable envname is test-@.-a, the way to reference it in edge function code is env['test-@.-a'].
Below are sample codes for edge functions referencing environment variables of types String and JSON. Developers can adjust them according to actual situations.

Variable Type: String

Through the above steps to create and deploy environment variables, create an environment variable named keytest with the value valuetest. The edge function reference is as follows:
// Entry function
addEventListener('fetch', event => {
event.respondWith(handleRequest(event.request));
});

// Function to handle requests
async function handleRequest(request) {
// Obtain a value from an environment variable, and this environment variable needs to be created and deployed in edge function environment variables.
const valueFromEnv = env.keytest;
// Create response.
const response = new Response(valueFromEnv, {
headers: {
'Content-Type': 'text/plain' // Set the response Content-Type.
}
});

// Return the response.
return response;
}
The semantic summary of the above code is to obtain the environment variable that the function has created and deployed, and respond it to the client as text.
Deploy the code, and you can view the result by accessing the trigger rules or default access of the function.


Variable Type: JSON

Repeat the steps to create and deploy environment variables, and create and deploy an environment variable of type JSON named keytestjson, as shown below:

// Entry function
addEventListener('fetch', event => {
event.respondWith(handleRequest(event.request));
});

async function handleRequest(request) {
// Obtain a value from an environment variable, and this environment variable needs to be created and deployed in edge function environment variables.
const myJsonData = env.keytestjson;
// Create response body.
const response = new Response(JSON.stringify(myJsonData), {
headers: {
'Content-Type': 'application/json'
}
});
// Return the response.
return response;
}
The semantic summary of the above code is to obtain the environment variable that the function has created and deployed, and respond it to the client as JSON data.
Deploy the code, and you can view the result by accessing the trigger rules or default access of the function.


Editing Environment Variables

1. In the Environment Variables module, click Edit for a specific environment variable. In the pop-up window, you can change the variable type and the variable value. Click OK to save the edited content.
2. In the Environment Variables module, click Deploy. The pop-up window will display the specific updates for this operation. Click OK to complete the deployment.


Deleting Environment Variables

In the Environment Variables module, click Delete for a specific environment variable, and then click Deploy. The pop-up window will display the specific environment variable being deleted in this operation. Click OK to complete the deployment.

Note:
If the environment variables referenced by the function are deleted through the above operations, adjust the logic of related references in the function code.