tencent cloud

Tencent Cloud EdgeOne

DocumentationTencent Cloud EdgeOneEdge FunctionsSample FunctionsMerging Resources and Responding in Streaming Mode

Merging Resources and Responding in Streaming Mode

PDF
Focus Mode
Font Size
Last updated: 2025-06-18 16:27:43
In this example, three video clips are merged into one video, and the merged video is played on a client based on the order in which the video clips are merged. This example demonstrates how to use an edge function to fetch multiple remote resources, read and merge the resources in streaming mode, and respond to a client request by using the merged resource in streaming mode.

Sample Code

async function sequentialCombine(urls, destination) {
try {
// Process each URL in order
for (let i = 0; i < urls.length; i++) {
const url = urls[i];

// Get the current clip
const response = await fetch(url);

if (!response.ok) {
console.error(`Failed to obtain video clip: ${url}, Error code: ${response.status}`);
continue;
}

// Get a readable stream
const readable = response.body;

// Execute pipeTo immediately to write the current clip to the target stream
try {
await readable.pipeTo(destination, {
preventClose: true // Keep the stream open for subsequent writing
});
} catch (e) {
console.error(`Stream processing errors (${url}): ${e.message}`);
}
}
} catch (err) {
console.error(`Merging video streams error: ${err.message}`);
} finally {
// Close the stream after all fragments are processed
const writer = destination.getWriter();
writer.close();
writer.releaseLock();
}
}

async function handleRequest(request) {
// The URLs of the video clips.
const urls = [
'https://vod.example.com/stream-01.mov',
'https://vod.example.comm/stream-02.mov',
'https://vod.example.com/stream-03.mov',
];

// Creating a Transformation Flow
const { readable, writable } = new TransformStream();

// Get and merge video clips in sequence
sequentialCombine(urls, writable);

// Returns the merged video stream response
return new Response(readable, {
headers: {
'content-type': 'video/mp4',
}
});
}

// Listening for fetch events
addEventListener('fetch', event => {
event.respondWith(handleRequest(event.request));
});

Sample Preview

In the address bar of the browser, enter a URL that matches a trigger rule of the edge function to preview the merged video. View the response header and verify that the video is transferred in chunked mode.




References

Help and Support

Was this page helpful?

Help us improve! Rate your documentation experience in 5 mins.

Feedback