mirror of
https://github.com/browseros-ai/BrowserOS.git
synced 2026-05-13 15:46:22 +00:00
* docs: update bring your own llm section * docs: update mcp clients info * chore: updated docs with comparison page * docs: fix tool count * docs: updated cowork section * feat: connect apps screen * feat: setup sync to cloud section * feat: added soul.md * feat: memory section * feat: open claw comparison section * feat: scheduled tasks page * fix: info text * feat: provide link to llms.txt * fix: kimi section
223 lines
9.0 KiB
Plaintext
223 lines
9.0 KiB
Plaintext
---
|
|
title: "Cowork"
|
|
description: "Give the agent controlled access to local files and commands alongside browser automation"
|
|
---
|
|
|
|
Cowork lets you describe complex tasks and let the agent handle them end-to-end. It combines browser automation with local file operations: research on the web, then save reports directly to your folder. Read code, edit files, run shell commands, and search through your project, all in the same session as your browser tasks.
|
|
|
|
Here's what it looks like to give the agent access to your local files:
|
|
|
|
<video
|
|
controls
|
|
className="w-full aspect-video rounded-xl"
|
|
src="https://pub-80f8a01e6e8b4239ae53a7652ef85877.r2.dev/resources/feature-videos/3-filesystem-access.mp4"
|
|
></video>
|
|
|
|
## Why Cowork?
|
|
|
|
Without Cowork, the agent can only interact with browser tabs. With Cowork enabled, it gains full access to a folder on your machine through 7 filesystem tools:
|
|
|
|
<CardGroup cols={3}>
|
|
<Card title="Read & write files" icon="file-lines">
|
|
Read documents and data files, write reports, markdown, HTML, and other outputs
|
|
</Card>
|
|
<Card title="Edit files" icon="pen-to-square">
|
|
Make targeted edits to existing files with surgical string replacement
|
|
</Card>
|
|
<Card title="Run commands" icon="terminal">
|
|
Execute shell commands within the sandboxed folder
|
|
</Card>
|
|
<Card title="Search content" icon="magnifying-glass">
|
|
Search file contents with regex or literal patterns across your project
|
|
</Card>
|
|
<Card title="Find files" icon="folder-tree">
|
|
Find files by glob pattern, with smart filtering of build directories
|
|
</Card>
|
|
<Card title="Browse directories" icon="list">
|
|
List directory contents with file sizes, sorted and organized
|
|
</Card>
|
|
</CardGroup>
|
|
|
|
The real power: do both browser automation AND file operations in a single task. Describe what you want, step away, and come back to finished work.
|
|
|
|
## Setting Up Cowork
|
|
|
|
<Steps>
|
|
<Step title="Open the Cowork selector">
|
|
Click the **Cowork** dropdown next to the prompt input
|
|
</Step>
|
|
<Step title="Choose a folder">
|
|
Select a recent folder or click **Choose a different folder**
|
|
</Step>
|
|
<Step title="Grant access">
|
|
Allow BrowserOS to access that folder when prompted
|
|
</Step>
|
|
</Steps>
|
|
|
|
<Frame caption="Select a folder for the agent to operate in">
|
|
<img src="/features/cowork/cowork-selector.png" alt="Select a folder for the agent to operate in" />
|
|
</Frame>
|
|
|
|
The agent is sandboxed to your selected folder. It cannot access files outside of it.
|
|
|
|
<Note>
|
|
Cowork is available in **Agent Mode** only. In Chat Mode, the agent works with browser tabs only.
|
|
</Note>
|
|
|
|
<Tip>
|
|
To disable file access, select **No folder** and the agent will work with browser tabs only.
|
|
</Tip>
|
|
|
|
## Filesystem Tools
|
|
|
|
Cowork provides 7 filesystem tools that the agent can use alongside browser automation:
|
|
|
|
<AccordionGroup>
|
|
<Accordion title="filesystem_read" icon="file-import">
|
|
Read a file from the filesystem. Returns text content with line numbers, or image data for image files (PNG, JPG, GIF, WEBP, BMP, SVG, ICO). Supports pagination through large files with `offset` and `limit` parameters.
|
|
|
|
| Parameter | Type | Description |
|
|
|-----------|------|-------------|
|
|
| `path` | string (required) | File path relative to working directory |
|
|
| `offset` | number (optional) | Starting line number (1-indexed) |
|
|
| `limit` | number (optional) | Max lines to read |
|
|
|
|
Responses are capped at 2000 lines or 50KB per request.
|
|
</Accordion>
|
|
|
|
<Accordion title="filesystem_write" icon="file-export">
|
|
Create or overwrite a file. Automatically creates parent directories if they don't exist.
|
|
|
|
| Parameter | Type | Description |
|
|
|-----------|------|-------------|
|
|
| `path` | string (required) | File path relative to working directory |
|
|
| `content` | string (required) | Complete file content to write |
|
|
</Accordion>
|
|
|
|
<Accordion title="filesystem_edit" icon="pen-to-square">
|
|
Make a targeted edit by replacing an exact string match. If the exact match fails, a whitespace-tolerant fuzzy match is attempted. Preserves original line endings (CRLF, CR, LF) and BOM.
|
|
|
|
| Parameter | Type | Description |
|
|
|-----------|------|-------------|
|
|
| `path` | string (required) | File path relative to working directory |
|
|
| `old_string` | string (required) | Exact text to find |
|
|
| `new_string` | string (required) | Replacement text |
|
|
|
|
Returns a side-by-side diff of the change.
|
|
</Accordion>
|
|
|
|
<Accordion title="filesystem_bash" icon="terminal">
|
|
Execute a shell command and return its output. Commands run in `sh`/`bash` on Unix or `cmd` on Windows.
|
|
|
|
| Parameter | Type | Description |
|
|
|-----------|------|-------------|
|
|
| `command` | string (required) | Shell command to execute |
|
|
| `timeout` | number (optional) | Timeout in seconds (default: 120) |
|
|
|
|
Output is truncated to the last 2000 lines if too large. Returns the exit code on failure.
|
|
</Accordion>
|
|
|
|
<Accordion title="filesystem_find" icon="folder-tree">
|
|
Find files matching a glob pattern. Searches recursively while skipping common build directories (`node_modules`, `.git`, `dist`, `build`, `.next`, `coverage`, `__pycache__`, and more).
|
|
|
|
| Parameter | Type | Description |
|
|
|-----------|------|-------------|
|
|
| `pattern` | string (required) | Glob pattern (e.g., `*.ts`, `**/*.json`) |
|
|
| `path` | string (optional) | Directory to search (default: working directory) |
|
|
| `limit` | number (optional) | Max results (default: 1000) |
|
|
|
|
Returns relative file paths sorted alphabetically.
|
|
</Accordion>
|
|
|
|
<Accordion title="filesystem_grep" icon="magnifying-glass">
|
|
Search file contents using regex or literal string matching. Skips binary files and files over 2MB.
|
|
|
|
| Parameter | Type | Description |
|
|
|-----------|------|-------------|
|
|
| `pattern` | string (required) | Search pattern (regex by default) |
|
|
| `path` | string (optional) | Directory or file to search |
|
|
| `glob` | string (optional) | Filter files by glob (e.g., `*.ts`) |
|
|
| `ignore_case` | boolean (optional) | Case-insensitive search |
|
|
| `literal` | boolean (optional) | Treat pattern as literal string |
|
|
| `context` | number (optional) | Lines of context around matches |
|
|
| `limit` | number (optional) | Max matches (default: 100) |
|
|
</Accordion>
|
|
|
|
<Accordion title="filesystem_ls" icon="list">
|
|
List directory contents. Shows directories first (with trailing `/`), then files with human-readable sizes.
|
|
|
|
| Parameter | Type | Description |
|
|
|-----------|------|-------------|
|
|
| `path` | string (optional) | Directory path (default: working directory) |
|
|
| `limit` | number (optional) | Max entries (default: 500) |
|
|
|
|
Entries are sorted alphabetically, case-insensitive.
|
|
</Accordion>
|
|
</AccordionGroup>
|
|
|
|
## Try It: Research and Create a Report
|
|
|
|
With Cowork enabled, try this prompt:
|
|
|
|
```
|
|
Read the top 3 stories on Hacker News, read the comments too, and write an HTML report.
|
|
```
|
|
|
|
The agent will:
|
|
|
|
<Steps>
|
|
<Step title="Navigate to Hacker News">
|
|
Opens the site and identifies top stories
|
|
</Step>
|
|
<Step title="Read stories and comments">
|
|
Clicks into each story and reads discussion threads
|
|
</Step>
|
|
<Step title="Generate report">
|
|
Creates an HTML report summarizing the findings
|
|
</Step>
|
|
<Step title="Save to folder">
|
|
Writes the report to your selected folder
|
|
</Step>
|
|
</Steps>
|
|
|
|
<Frame caption="Agent researching Hacker News and generating an HTML report">
|
|
<img src="/features/cowork/cowork-research-example.png" alt="Agent researching Hacker News and generating an HTML report" />
|
|
</Frame>
|
|
|
|
## Example Use Cases
|
|
|
|
<AccordionGroup>
|
|
<Accordion title="Organize your downloads" icon="folder-tree">
|
|
> Go through my Downloads folder and organize files by type: documents, images, videos, archives.
|
|
</Accordion>
|
|
<Accordion title="Competitive research report" icon="magnifying-glass-chart">
|
|
> Research key trends about [topic] on Reddit, Twitter, and LinkedIn. Create an HTML report with your findings.
|
|
</Accordion>
|
|
<Accordion title="Web scraping to files" icon="spider-web">
|
|
> Visit these 10 product pages, extract the name, price, and description, and save the results as a markdown file.
|
|
</Accordion>
|
|
<Accordion title="Content aggregation" icon="newspaper">
|
|
> Find the top posts from these 5 subreddits today and compile them into a daily digest document.
|
|
</Accordion>
|
|
<Accordion title="Codebase exploration" icon="code">
|
|
> Search my project for all TODO comments, list them with file paths and line numbers, then create a summary markdown file.
|
|
</Accordion>
|
|
<Accordion title="Log analysis" icon="file-lines">
|
|
> Grep through the log files in this folder for errors from the last 24 hours and write a summary of what went wrong.
|
|
</Accordion>
|
|
</AccordionGroup>
|
|
|
|
## Security
|
|
|
|
<CardGroup cols={3}>
|
|
<Card title="Sandboxed access" icon="box">
|
|
The agent can only access the folder you select. No parent directories, no path traversal.
|
|
</Card>
|
|
<Card title="Revoke anytime" icon="ban">
|
|
Select **No folder** to instantly disable file access
|
|
</Card>
|
|
<Card title="Local only" icon="house-laptop">
|
|
All file operations happen locally on your machine
|
|
</Card>
|
|
</CardGroup>
|