Skip to content

Latest commit

 

History

History
74 lines (53 loc) · 2.13 KB

README.md

File metadata and controls

74 lines (53 loc) · 2.13 KB

browser-agent

This is an experiemental project that exposes an x.com account as API, it need you run Chrome with CDP enabled and login the x.com account first.

API Endpoints

GET /home_timeline

Retrieves the home timeline tweets.

GET /user/:screen_name

Retrieves tweets from a specific user's timeline.

  • :screen_name - The Twitter screen name of the user

GET /mentions

Retrieves mentions for the authenticated user.

GET /user/:screen_name/:tweet_id

Retrieves a specific tweet.

  • :screen_name - The Twitter screen name of the user
  • :tweet_id - The ID of the tweet

GET /user/:screen_name/status/:tweet_id

Alternative endpoint to retrieve a specific tweet.

  • :screen_name - The Twitter screen name of the user
  • :tweet_id - The ID of the tweet

POST /tweets

Posts a new tweet.

  • Request body: { "text": "Your tweet content here" }

Running the Server

The server runs on port 3000 by default, or on the port specified by the PORT environment variable.

Advanced Environment Configuration

The development environment can be customized through a .env file in the project root. Below are the available configuration options:

Chrome/Chromium Settings

# Chrome DevTools Protocol (CDP) port
# Default: 9222
CDP_PORT=9222

# Chrome user data directory
# If not specified, will use default directory based on OS:
# - macOS: ~/Library/Application Support/BrowserAgent
# - Windows: %APPDATA%/Local/BrowserAgent
# - Linux: ~/.browseragent
CHROME_USER_DATA_DIR=/path/to/your/chrome/profile

# Run Chrome in headless mode
# Set to 'true' to run Chrome without GUI
# Default: false
CHROME_HEADLESS=false

Example Configuration

A complete .env file might look like this:

CDP_PORT=9333
CHROME_USER_DATA_DIR=/Users/username/Projects/browser-agent/chrome-data
CHROME_HEADLESS=true

Notes

  • All settings are optional and have sensible defaults
  • The CDP URL will be automatically injected into your development environment as process.env.CDP_URL
  • Chrome/Chromium executable is automatically detected on your system
  • If running in CI/CD environments, it's recommended to set CHROME_HEADLESS=true