Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rebrowser/rebrowser-puppeteer
A drop-in replacement for puppeteer patched with rebrowser-patches. It allows to pass modern automation detection tests.
https://github.com/rebrowser/rebrowser-puppeteer
automation bot bot-detection captcha chrome headless puppeteer rebrowser rebrowser-patches scraping web-scraping
Last synced: 3 months ago
JSON representation
A drop-in replacement for puppeteer patched with rebrowser-patches. It allows to pass modern automation detection tests.
- Host: GitHub
- URL: https://github.com/rebrowser/rebrowser-puppeteer
- Owner: rebrowser
- Created: 2024-09-17T19:55:29.000Z (4 months ago)
- Default Branch: 23.3.1
- Last Pushed: 2024-10-17T21:19:09.000Z (3 months ago)
- Last Synced: 2024-10-18T00:27:21.784Z (3 months ago)
- Topics: automation, bot, bot-detection, captcha, chrome, headless, puppeteer, rebrowser, rebrowser-patches, scraping, web-scraping
- Homepage: https://github.com/rebrowser/rebrowser-patches
- Size: 273 KB
- Stars: 1
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# rebrowser-puppeteer
> ⚠️ This is the original [`puppeteer`](https://www.npmjs.com/package/puppeteer) patched with [`rebrowser-patches`](https://github.com/rebrowser/rebrowser-patches).
>
> 🕵️ The ultimate goal is to pass all automation detection tests presented in [`rebrowser-bot-detector`](https://github.com/rebrowser/rebrowser-bot-detector).
>
> 🪄 It's designed to be a drop-in replacement for the original `puppeteer` without changing your codebase. Each major and minor version of this repo matches the original repo, patch version could differ due to changes related to the patch itself.
>
> ☝️ Make sure to read: [How to Access Main Context Objects from Isolated Context](https://rebrowser.net/blog/how-to-access-main-context-objects-from-isolated-context-in-puppeteer-and-playwright-23741)
>
> 🐛 Please report any issues in the [`rebrowser-patches`](https://github.com/rebrowser/rebrowser-patches/issues) repo.# Puppeteer
[![build](https://github.com/puppeteer/puppeteer/actions/workflows/ci.yml/badge.svg?branch=main)](https://github.com/puppeteer/puppeteer/actions/workflows/ci.yml)
[![npm puppeteer package](https://img.shields.io/npm/v/puppeteer.svg)](https://npmjs.org/package/puppeteer)> Puppeteer is a JavaScript library which provides a high-level API to control
> Chrome or Firefox over the
> [DevTools Protocol](https://chromedevtools.github.io/devtools-protocol/) or [WebDriver BiDi](https://pptr.dev/webdriver-bidi).
> Puppeteer runs in the headless (no visible UI) by default## [Get started](https://pptr.dev/docs) | [API](https://pptr.dev/api) | [FAQ](https://pptr.dev/faq) | [Contributing](https://pptr.dev/contributing) | [Troubleshooting](https://pptr.dev/troubleshooting)
## Installation
```bash npm2yarn
npm i puppeteer # Downloads compatible Chrome during installation.
npm i puppeteer-core # Alternatively, install as a library, without downloading Chrome.
```## Example
```ts
import puppeteer from 'puppeteer';
// Or import puppeteer from 'puppeteer-core';// Launch the browser and open a new blank page
const browser = await puppeteer.launch();
const page = await browser.newPage();// Navigate the page to a URL.
await page.goto('https://developer.chrome.com/');// Set screen size.
await page.setViewport({width: 1080, height: 1024});// Type into search box.
await page.locator('.devsite-search-field').fill('automate beyond recorder');// Wait and click on first result.
await page.locator('.devsite-result-item-link').click();// Locate the full title with a unique string.
const textSelector = await page
.locator('text/Customize and automate')
.waitHandle();
const fullTitle = await textSelector?.evaluate(el => el.textContent);// Print the full title.
console.log('The title of this blog post is "%s".', fullTitle);await browser.close();
```