cloudflare-browser
от cloudflare
Управление безголовым Chrome через Cloudflare Browser Rendering CDP WebSocket. Используется для создания скриншотов, навигации по страницам, скрапинга и захвата видео, когда браузер…
npx skills add https://github.com/cloudflare/moltworker --skill cloudflare-browserCloudflare Browser Rendering
Control headless browsers via Cloudflare's Browser Rendering service using CDP (Chrome DevTools Protocol) over WebSocket.
Prerequisites
CDP_SECRETenvironment variable set- Browser profile configured in openclaw.json with
cdpUrlpointing to the worker endpoint:"browser": { "profiles": { "cloudflare": { "cdpUrl": "https://your-worker.workers.dev/cdp?secret=..." } } }
Quick Start
Screenshot
node /path/to/skills/cloudflare-browser/scripts/screenshot.js https://example.com output.png
Multi-page Video
node /path/to/skills/cloudflare-browser/scripts/video.js "https://site1.com,https://site2.com" output.mp4
CDP Connection Pattern
The worker creates a page target automatically on WebSocket connect. Listen for Target.targetCreated event to get the targetId:
const WebSocket = require('ws');
const CDP_SECRET = process.env.CDP_SECRET;
const WS_URL = `wss://your-worker.workers.dev/cdp?secret=${encodeURIComponent(CDP_SECRET)}`;
const ws = new WebSocket(WS_URL);
let targetId = null;
ws.on('message', (data) => {
const msg = JSON.parse(data.toString());
if (msg.method === 'Target.targetCreated' && msg.params?.targetInfo?.type === 'page') {
targetId = msg.params.targetInfo.targetId;
}
});
Key CDP Commands
| Command | Purpose |
|---|---|
| Page.navigate | Navigate to URL |
| Page.captureScreenshot | Capture PNG/JPEG |
| Runtime.evaluate | Execute JavaScript |
| Emulation.setDeviceMetricsOverride | Set viewport size |
Common Patterns
Navigate and Screenshot
await send('Page.navigate', { url: 'https://example.com' });
await new Promise(r => setTimeout(r, 3000)); // Wait for render
const { data } = await send('Page.captureScreenshot', { format: 'png' });
fs.writeFileSync('out.png', Buffer.from(data, 'base64'));
Scroll Page
await send('Runtime.evaluate', { expression: 'window.scrollBy(0, 300)' });
Set Viewport
await send('Emulation.setDeviceMetricsOverride', {
width: 1280,
height: 720,
deviceScaleFactor: 1,
mobile: false
});
Creating Videos
- Capture frames as PNGs during navigation
- Use ffmpeg to stitch:
ffmpeg -framerate 10 -i frame_%04d.png -c:v libx264 -pix_fmt yuv420p output.mp4
Troubleshooting
- No target created: Race condition - wait for Target.targetCreated event with timeout
- Commands timeout: Worker may have cold start delay; increase timeout to 30-60s
- WebSocket hangs: Verify CDP_SECRET matches worker configuration
Больше skills от cloudflare
write-endpoints
cloudflare
Всеобъемлющее руководство по созданию конечных точек OpenAPI с помощью chanfana — определение схемы, проверка запросов, операции CRUD, интеграция с базой данных D1 и…
official
agents-sdk
cloudflare
Создавайте AI-агентов на Cloudflare Workers с помощью Agents SDK. Загружайте при создании stateful-агентов, долговечных рабочих процессов, приложений с WebSocket в реальном времени, запланированных задач,…
official
building-ai-agent-on-cloudflare
cloudflare
Создаёт AI-агентов с использованием Cloudflare Agents SDK, обеспечивая постоянное состояние, общение в реальном времени и интеграцию инструментов.
official
building-mcp-server-on-cloudflare
cloudflare
Создаёт готовые к продакшену серверы Model Context Protocol на Cloudflare Workers с инструментами, аутентификацией и развёртыванием.
official
changelog
cloudflare
Создаёт, обновляет и просматривает записи журнала изменений продукта для сайта документации Cloudflare. Загружать при генерации MDX-файлов журнала изменений, редактировании существующих…
official
cloudflare
cloudflare
Всесторонний навык платформы Cloudflare, охватывающий Workers, Pages, хранилища (KV, D1, R2), ИИ (Workers AI, Vectorize, Agents SDK), сетевые технологии (Tunnel, Spectrum),…
official
code-review
cloudflare
Проверяет код Workers и Cloudflare Developer Platform на корректность типов, использование API и валидность конфигурации. Загружать при рецензировании TypeScript/JavaScript…
official
docs-review
cloudflare
Проверяет PR с документацией и предоставляет предложения для GitHub PR. Загружается, когда просят проверить, предложить изменения или дать обратную связь по содержимому документации. Охватывает MDX,…
official