Documentation Index Fetch the complete documentation index at: https://tbd-6fc993ce-hypeship-document-pool-profile-update-behavior.mintlify.app/llms.txt
Use this file to discover all available pages before exploring further.
Replays capture browser sessions as video recordings that you can view or download later. You have full control over when replays start and stop, allowing you to capture specific interactions or workflows.
Starting and stopping recordings
To start recording a browser session, use the replays API on an active browser:
Typescript/Javascript
Python
import Kernel from '@onkernel/sdk' ;
const kernel = new Kernel ();
const kernelBrowser = await kernel . browsers . create ();
const replay = await kernel . browsers . replays . start ( kernelBrowser . session_id );
console . log ( `Recording started with ID: ${ replay . replay_id } ` );
// Perform some automation...
await kernel . browsers . replays . stop ( replay . replay_id , { id: kernelBrowser . session_id });
console . log ( 'Recording stopped and processing' );
Multiple recordings per session
You can create multiple replay recordings for a single browser session. Each recording gets a unique replay_id and can be started and stopped independently:
Typescript/Javascript
Python
const replay1 = await kernel . browsers . replays . start ( kernelBrowser . session_id );
// Perform some automation...
await kernel . browsers . replays . stop ( replay1 . replay_id , { id: kernelBrowser . session_id });
const replay2 = await kernel . browsers . replays . start ( kernelBrowser . session_id );
// Perform different automation...
await kernel . browsers . replays . stop ( replay2 . replay_id , { id: kernelBrowser . session_id });
Downloading all replays
To access all replays for a browser session, list and access them via url or as downloads:
Typescript/Javascript
Python
import fs from 'fs' ;
import { Buffer } from 'buffer' ;
const replays = await kernel . browsers . replays . list ( kernelBrowser . session_id );
for ( const replay of replays ) {
console . log ( `Replay ID: ${ replay . replay_id } ` );
console . log ( `View URL: ${ replay . replay_view_url } ` );
const videoData = await kernel . browsers . replays . download (
replay . replay_id ,
{ id: kernelBrowser . session_id }
);
const content = await videoData . blob ();
const buffer = Buffer . from ( await content . arrayBuffer ());
const filename = `replay- ${ replay . replay_id } - ${ kernelBrowser . session_id } .mp4` ;
fs . writeFileSync ( filename , buffer );
}