Overview
Contexts allow you to persist user data across multiple browser sessions, enabling smoother automation, seamless authentication, and faster end-to-end workflows. By default, each Browserbase session starts with a fresh user data directory, meaning cookies and application data are wiped between sessions. With Contexts, you can reuse this data across sessions, making automation workflows more reliable and eliminating repeated logins. Browser cookies are stored in the user data directory. Contexts are configured by:- Creating a context via the Contexts API
- Passing the context ID into the Create Sessions API
View or run the example template here
Why use Contexts?
- Reusing Cookies & Session Data: Maintain login states across multiple sessions without needing to log in repeatedly.
- Preserving Authentication: Store and reuse authentication tokens, reducing the need to re-enter credentials.
- Retaining Application Data: Persist localStorage, IndexedDB, and other site-specific data written by web applications.
- Faster Workflows: Skip login flows and re-authentication steps, reducing the total time of your automation runs.
What data does a Context store?
What data does a Context store?
A Context persists the contents of the Chromium user data directory, including:
- Cookies — including session cookies, explicitly backed up and restored between sessions
- localStorage — per-origin key-value storage
- IndexedDB — structured client-side databases
- Session Storage — tab-scoped storage
- Service Workers — site-controlled caching and offline support
- Web Data — form autofill entries and saved form data
- Browser preferences — site-level settings, permissions, and security state (e.g., HSTS)
Context data can include stored credentials and other sensitive browsing
data. Because of this, contexts are uniquely encrypted at rest to ensure
security.
Create a Context
To create a context, use the Create Context API. This will return a unique context ID, which you can pass into new sessions to persist data.- Node.js
- Python
- cURL
Use a Context
After creating a context, you can use it in a new session to reuse cookies, authentication, and application data. This allows you to create a returning user experience, speeding up your workflow and eliminating the need to log in again.After closing a session with
persist: true, wait a few seconds before reusing the context to ensure data is synchronized.- Node.js
- Python
Set Persist
If you need to store new cookies, authentication tokens, or application data, you must setpersist: true when creating a session. This ensures that any changes made during the session—such as logging in or saving site preferences—are retained for future sessions instead of being lost when the session ends. The data will be saved when the session closes.
persist: false prevents changes from being saved to the context. This is useful for less common use cases, such as:
- Read-only session: If you need to access saved cookies or data without modifying them.
- Prevent session state changes: Avoids overwriting stored login tokens or user data.
Login Workflow
A typical flow to persist a website login across Browserbase sessions would be as follows:- Create a context (get a
contextId). - Start a first Browserbase session with that
contextIdandpersist: true. - Log in to a website inside this first session, either manually through our live view feature or programmatically.
- End this session.
- Wait a few seconds to ensure that the context is updated.
- Start a second Browserbase session (and future sessions) with the same
contextIdand visit the same website — you should now be signed in automatically without having to repeat the login process.
Login Best Practices
Browserbase Contexts have no expiration on our end (see Context Expiration), but sites can still force a log out. Here are a few additional best practices:- Avoid simultaneous logins — Avoid having multiple sessions using the same context at once. Sites may force a log out.
- Use a consistent geolocation — Some sites check user location, use a geolocated proxy for these cases.
- One context per site, per login — Prevent an individual context from becoming too large, which can slow down your session.
Context Expiration
Contexts are designed to live indefinitely on Browserbase’s infrastructure. Once created, a context will persist until you explicitly delete it or it becomes invalidated. This means you can create a context once and reuse it across sessions for weeks or months without worrying about expiration. However, there are several ways a context can become invalid or unusable:Client-side invalidation
- Explicit deletion: Calling the Delete Context API permanently removes the context
- Project deletion: If the parent project is deleted, all associated contexts are removed
- Account changes: Account suspension or deletion will invalidate all contexts
Application-level invalidation
While the context itself persists, the data stored within it can become stale or invalid due to external factors:- Session expiration: Websites may expire authentication cookies after a set period (e.g., 30 days), requiring re-authentication even with a persisted context
- Password changes: If you change your password on a website, stored session cookies may be invalidated by that website
- Server-side logout: Websites can invalidate sessions server-side (e.g., “log out of all devices”)
- Token revocation: OAuth tokens or API keys stored in cookies may be revoked by the service provider
- Security events: Websites may force re-authentication after detecting suspicious activity
To handle application-level invalidation, implement checks in your automation
to detect logged-out states and re-authenticate when necessary.
Delete a Context
When you no longer need a context, you can delete it using the Delete Context API. Once deleted, a context cannot be used to create new sessions.Deleting a context is permanent and cannot be undone.
- Node.js
- Python
- cURL
Handling Authentication
Once you set up contexts, follow our authentication guide to easily log into
websites.