
Security News
PEP 810 Proposes Explicit Lazy Imports for Python 3.15
An opt-in lazy import keyword aims to speed up Python startups, especially CLIs, without the ecosystem-wide risks that sank PEP 690.
puppeteer-tab-recorder
Advanced tools
Record a tab with puppeteer. Implemented using getDisplayMedia and MediaRecorder API.
pnpm add -D puppeteer-tab-recorder
import puppeteer from 'puppeteer';
import { recommandChromeArgs, createTabRecorder } from 'puppeteer-tab-recorder';
// launch browser
const browser = await puppeteer.launch({
headless: 'new', // use `'new'` for headless mode, and `false` for headful mode
defaultViewport: null, // viewport will fit the window size
args: [...recommandChromeArgs], // recommanded, for skipping capture window selection dialog
// puppeteer is using 'Chrome for Testing', which doesn't have h264 codec support.
// if you want to play videos using h264 codec, you need to use your own Chrome.
executablePath: '<Optional, path to your Chrome>',
});
// open a new page
const page = await browser.newPage();
// go to the site you want to record
await page.goto('https://developers.google.com/);
// create recorder
const recorder = await createTabRecorder(page);
// start recording
await recorder.start(); // audio recording is enabled by default. to disable, use `recorder.start({ audio: false })`
// do something
await delay(5000);
// ...
// stop recording
await recorder.stop();
// save recording (only .webm is supported currently, saved to defulat download folder)
await recorder.save({ filename: 'recording.webm' });
// wait for download to finish
await delay(1000);
// close browser
await browser.close();
import puppeteer from 'puppeteer';
import { createTabRecorder, recommandChromeArgs } from 'puppeteer-tab-recorder';
const browser = await puppeteer.launch({
headless: 'new',
defaultViewport: null,
args: [...recommandChromeArgs],
});
const page1 = await browser.newPage();
await page1.goto('https://developer.apple.com/');
const recorder1 = await createTabRecorder(page);
await recorder1.start({ audio: true });
const page2 = await browser.newPage();
await page2.goto('https://developer.apple.com/');
const recorder2 = await createTabRecorder(page);
await recorder2.start({ audio: true });
// record 2 tabs for 5 seconds at the same time, both with its own audio
await delay(5000);
await recorder1.stop();
await recorder2.stop();
await recorder1.save({ filename: 'recording1.webm' });
await recorder2.save({ filename: 'recording2.webm' });
await delay(1000);
await browser.close();
git clone https://github.com/reekystive/puppeteer-tab-recorder.git
cd puppeteer-tab-recorde
pnpm install
pnpm exec ts-node-esm -T examples/youtube.ts
FAQs
Record browser tabs with audio
We found that puppeteer-tab-recorder demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
An opt-in lazy import keyword aims to speed up Python startups, especially CLIs, without the ecosystem-wide risks that sank PEP 690.
Security News
Socket CEO Feross Aboukhadijeh discusses the recent npm supply chain attacks on PodRocket, covering novel attack vectors and how developers can protect themselves.
Security News
Maintainers back GitHub’s npm security overhaul but raise concerns about CI/CD workflows, enterprise support, and token management.