n8n-nodes-playwright-core
v0.1.1
Published
n8n community node for browser automation with Playwright Core browser agnostic
Maintainers
Readme
@ia-generative/n8n-nodes-playwright-core
This is an n8n community node. It lets you automate browser actions in your n8n workflows using Playwright Core over a remote CDP or WebSocket endpoint.
n8n is a fair-code licensed workflow automation platform.
Operations Sessions File Downloads Custom Scripts Remote browser server Installation Compatibility Resources Version history Acknowledgements
Operations
This node supports the following operations:
- Navigate: Navigate to a URL and return the current page content
- Get Text: Extract text from an element using CSS selector or XPath
- Click Element: Click an element using CSS selector or XPath
- Fill Form: Fill one or more form fields using CSS selectors or XPath
- Take Screenshot: Capture the current page as binary data
- Download File: Download a file either from a clicked element or a direct URL
- Run Custom Script: Execute custom JavaScript code with access to Playwright and n8n helpers
- Close Session: Explicitly close a previously opened browser session
Selectors and form filling
For Get Text, Click Element, and element-based Download File, you can choose between:
- CSS Selector
- XPath
For Fill Form, each field accepts either a CSS selector or an XPath expression. XPath is detected automatically when the selector starts with / or (.
This allows a single form operation to fill multiple fields in sequence.
Screenshots
The Take Screenshot operation stores the screenshot as binary data and supports:
- Full-page screenshots
- Optional output path
- Custom binary property name
Sessions
This fork adds reusable browser session support so multiple Playwright nodes can work on the same remote browser session within a single workflow execution.
Session key resolution
Each operation resolves its session key in the following order of priority:
- Explicit Session ID — if provided in the node parameters, it is used as-is
- Propagated session key — if a previous Playwright node in the same execution passed a session key downstream, it is reused automatically
- Random UUID — if neither of the above is set, a new unique session key is generated for this execution
Session lifecycle
- If Leave Session Open is enabled, the session stays alive after the operation and is available for subsequent Playwright nodes
- If Leave Session Open is disabled, the session is closed immediately after the operation
- The Close Session operation terminates a session explicitly at any point in the workflow
- Sessions are automatically removed from memory when the remote browser disconnects
Connection modes
New sessions connect to the remote browser using one of two modes:
- CDP (Chrome DevTools Protocol) — supported for Chromium only
- Playwright WS (WebSocket) — supported for Chromium and Firefox
⚠️ Only Chromium and Firefox are currently supported. WebKit is not supported.
Firefox is only available in Playwright WS mode. CDP mode is Chromium-only.
Typical session workflow
- Navigate to a login page
- Fill and submit the login form
- Extract data from the authenticated session
- Download a file
- Close the session explicitly
File Downloads
The Download File operation supports two download modes.
Download from element
The node can click a page element and try several strategies to capture the downloaded file, including:
- Playwright download events
- Direct response capture
- Popup response capture
- Fetching the resolved target URL when available
This is useful for flows where clicking a link or button triggers a document download or opens a PDF in a new page.
Download from URL
The node can also fetch a file directly from a provided URL.
When needed, it can resolve relative URLs against the current page and try both:
- In-page browser fetch with credentials
- Direct request through the Playwright request context
Downloaded files are returned as n8n binary data under the configured binary property name.
Custom Scripts
The Run Custom Script operation gives you direct access to the current Playwright session and useful n8n helpers inside a sandboxed JavaScript environment.
Available variables
Your script can access:
$page- current Playwright page$browser- current Playwright browser$playwright- Playwright Core module$helpers- n8n helper methods$json- current input item JSON$input- access to input data$getNodeParameter()- access node parameters- other standard n8n Code node variables available through the workflow data proxy
Notes
- Your script must return an array of items
- Binary data can be created with
$helpers.prepareBinaryData() console.log()output is available in manual executions- The script runs in a sandboxed VM environment
Example
const title = await $page.title();
return [
{
json: {
title,
url: $page.url(),
},
},
];Remote browser server
This node does not launch browsers locally. It connects to a remote Playwright server that exposes a WebSocket endpoint. You need to run such a server separately.
Why a separate server?
Running browsers inside an n8n container introduces significant complexity: heavy system dependencies, large image sizes, sandboxing constraints, and security concerns. Offloading the browser to a dedicated container keeps the n8n image lean and lets you scale or replace the browser service independently.
Using the provided Dockerfile-playwright
This repository includes a Dockerfile-playwright that builds a ready-to-use Playwright server image:
FROM mcr.microsoft.com/playwright:v1.58.2-jammy
ENV PLAYWRIGHT_BROWSERS_PATH=/ms-playwright
ENV XDG_RUNTIME_DIR=/tmp/.chromium
ENV XDG_CACHE_HOME=/tmp/.chromium
ENV NPM_CONFIG_CACHE=/tmp/.npm
RUN npx --yes [email protected] install firefox
RUN npx --yes [email protected] install chromium
CMD ["npx", "[email protected]", "run-server", "--port", "3000"]What it does:
- Starts from the official Microsoft Playwright base image pinned to v1.58.2 — the same version used by this node
- Installs Chromium and Firefox browser binaries
- Runs
playwright run-serveron port 3000, which exposes a WebSocket endpoint compatible withplaywright.connect()
The Playwright version in this image must match the
playwright-coreversion used by the node (currently1.58.2). See the Compatibility section for details.
Using with Docker Compose
The repository also includes a docker-compose.yml that wires the n8n node and the Playwright server together:
services:
n8n:
build: .
image: n8n-playwright-core
ports:
- '5678:5678'
environment:
- N8N_COMMUNITY_PACKAGES_ENABLED=true
- N8N_CUSTOM_EXTENSIONS=/opt/custom-nodes
# ...
playwright:
image: ghcr.io/ia-generative/playwright:v1.58.2-jammy-browsers
build:
dockerfile: Dockerfile-playwright
ports:
- '3000:3000'Start the full stack with:
docker compose upIn your n8n Playwright node credentials, set the browser endpoint to:
ws://playwright:3000The playwright hostname resolves automatically via Docker Compose's internal network.
Using a pre-built image
A pre-built image is published at:
ghcr.io/ia-generative/playwright:v1.58.2-jammy-browsersYou can use it directly without building locally:
playwright:
image: ghcr.io/ia-generative/playwright:v1.58.2-jammy-browsers
ports:
- '3000:3000'Relation to IA-Generative/n8n-image
The companion repository IA-Generative/n8n-image provides production-ready Docker images for the full stack:
n8n-image/playwright/— the Dockerfile for the remote Playwright browser server (mirrorsDockerfile-playwrightin this repo)n8n-image/nodes/— the package manifest that pins this node (n8n-nodes-playwright-core) as a dependency of the n8n image
⚠️ Version parity is required. The version of
playwright-coredeclared in this package must match the Playwright version used inn8n-image/playwright/Dockerfile. Any mismatch between the two repositories will cause connection or protocol errors at runtime.
When upgrading playwright-core in this package, the corresponding Playwright version in n8n-image must be updated at the same time. Both repositories are currently developed in sync on their respective dev branches.
Installation
1. Install the package
npm install n8n-nodes-playwright-core
# or
pnpm install n8n-nodes-playwright-core2. Using in a custom n8n Docker image
To integrate this node into a custom n8n image:
FROM n8nio/n8n:latest
USER root
RUN npm install n8n-nodes-playwright-core
USER nodeThen build the image:
docker build -t my-n8n .Compatibility
This node requires:
- n8n 1.0.0 or later
- Node.js 22.22.1 or later
- A Playwright-compatible remote browser endpoint reachable over CDP or WebSocket (e.g. a self-hosted Playwright server or any equivalent service, including Browserless)
This fork does not install browser binaries automatically. Browser execution is expected to be handled by a remote Playwright-compatible service.
Playwright version compatibility
This node uses playwright-core 1.58.2.
⚠️ The version of
playwright-coreused by this node must match the version of Playwright installed on your remote browser server.A version mismatch between the client (this node) and the server (your browser endpoint) can cause connection failures, protocol errors, or unpredictable behavior. Always ensure both sides run the same Playwright version.
If you are building your own remote browser Docker image, pin the Playwright version explicitly:
RUN npx --yes [email protected] install --with-deps firefox chromiumOr with npm:
npm install [email protected]Resources
- n8n community nodes documentation
- Playwright documentation
- Playwright API reference
- IA-Generative/n8n-image — companion repository with production Docker images for the full n8n + Playwright stack
Version history
0.1.0
Initial public version of this fork.
Main changes compared with the original upstream project:
- Migrated to
playwright-core(no local browser binaries) - Switched to a remote CDP/WebSocket-based browser connection model
- Added support for Playwright WebSocket connection mode in addition to CDP
- Added reusable session support with automatic key propagation across nodes
- Sessions are stored in memory and cleaned up automatically on browser disconnect
- Added explicit session closing with the Close Session operation
- Added Download File operation with multiple download strategies
- Improved form filling with support for multiple fields and XPath selectors
- Kept custom script execution with sandboxed access to Playwright and n8n helpers
- Pinned
playwright-coreto 1.58.2 for predictable server compatibility
Acknowledgements
This project started as a fork of toema/n8n-playwright and was adapted in March 2026 to support a Playwright Core remote workflow with reusable sessions and extended download handling.
It is based on the original work by Mohamed Toema. Many thanks to him for the initial implementation and for making the original project available as open source.
