npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@striderlabs/mcp-uber

v0.1.0

Published

MCP server connector for Uber ride-sharing — request rides, get fare estimates, track trips via browser automation

Downloads

13

Readme

@striderlabs/mcp-uber

MCP server connector for Uber ride-sharing — request rides, get fare estimates, and track trips via browser automation.

Installation

npx @striderlabs/mcp-uber

Or install globally:

npm install -g @striderlabs/mcp-uber

MCP Configuration

Add to your claude_desktop_config.json:

{
  "mcpServers": {
    "uber": {
      "command": "npx",
      "args": ["@striderlabs/mcp-uber"]
    }
  }
}

Tools

status

Check Uber authentication and session status, including the current pickup/destination if set.

| Name | Type | Required | Description | |------|------|----------|-------------| | (no parameters) | | | |


login

Authenticate with Uber using email/phone and password via browser automation.

| Name | Type | Required | Description | |------|------|----------|-------------| | identifier | string | Yes | Uber account email address or phone number | | password | string | Yes | Uber account password | | headless | boolean | No | Run browser in headless mode (default: true). Set false to see the browser and complete OTP/captcha manually. |

Note: Uber often requires phone OTP verification. If OTP is triggered, run with headless: false to complete verification in the visible browser window, then call login again.


logout

Clear the Uber session and all stored cookies.

| Name | Type | Required | Description | |------|------|----------|-------------| | (no parameters) | | | |


set_pickup

Set the pickup location for a ride request. Persists across tool calls.

| Name | Type | Required | Description | |------|------|----------|-------------| | address | string | Yes | Pickup address (e.g., "123 Main St, New York, NY" or "JFK Airport") |


set_destination

Set the destination for a ride request. Persists across tool calls.

| Name | Type | Required | Description | |------|------|----------|-------------| | address | string | Yes | Destination address (e.g., "456 Park Ave, New York, NY" or "LaGuardia Airport") |


get_fare_estimate

Get fare estimates for all available ride types between pickup and destination.

| Name | Type | Required | Description | |------|------|----------|-------------| | pickup | string | No | Override pickup address (uses stored pickup if not provided) | | destination | string | No | Override destination address (uses stored destination if not provided) | | headless | boolean | No | Run browser in headless mode (default: true) |

Note: Set pickup and destination first with set_pickup / set_destination, or provide them directly as parameters.


get_ride_options

Get available ride types (UberX, Comfort, XL, Black, etc.) with pricing and ETAs for the current route.

| Name | Type | Required | Description | |------|------|----------|-------------| | pickup | string | No | Override pickup address | | destination | string | No | Override destination address | | headless | boolean | No | Run browser in headless mode (default: true) |


request_ride

Request an Uber ride. Returns a confirmation preview by default — does not automatically confirm.

| Name | Type | Required | Description | |------|------|----------|-------------| | ride_type | string | No | Ride type (e.g., "UberX", "Comfort", "XL", "Black"). Defaults to "UberX". | | confirm | boolean | No | Set true to actually place the ride request. Default false (preview only). | | headless | boolean | No | Run browser in headless mode (default: true) |

Warning: Setting confirm: true will attempt to place a real ride request. Make sure pickup, destination, and ride type are correct before confirming.


get_ride_status

Get the status of your current or most recent Uber ride.

| Name | Type | Required | Description | |------|------|----------|-------------| | headless | boolean | No | Run browser in headless mode (default: true) |


cancel_ride

Cancel a pending or active Uber ride request.

| Name | Type | Required | Description | |------|------|----------|-------------| | confirm | boolean | No | Set true to confirm cancellation. Default false (shows cancellation info only). | | headless | boolean | No | Run browser in headless mode (default: true) |

Note: A cancellation fee may apply if a driver has already been assigned. Review the cancellation policy before confirming.


get_ride_history

Get recent Uber ride history.

| Name | Type | Required | Description | |------|------|----------|-------------| | limit | number | No | Number of recent trips to return (default: 10) | | headless | boolean | No | Run browser in headless mode (default: true) |


Typical Workflow

1. login          → Authenticate with Uber
2. set_pickup     → "Times Square, New York, NY"
3. set_destination → "JFK Airport, Queens, NY"
4. get_fare_estimate → Review prices for UberX, Comfort, XL, etc.
5. request_ride   → Preview the ride (confirm: false)
6. request_ride   → confirm: true to place the request
7. get_ride_status → Track your driver
8. cancel_ride    → Cancel if needed (confirm: true)

Session Storage

Sessions and route data are stored in:

~/.striderlabs/uber/
├── cookies.json   # Browser session cookies
├── auth.json      # Account metadata
└── route.json     # Current pickup/destination

Technical Details

  • Transport: stdio (MCP standard)
  • Browser: Chromium via Playwright with stealth patches
  • Stealth: Patches navigator.webdriver, spoof plugins/languages, remove automation markers
  • Geolocation: Defaults to New York City (40.7128, -74.006)
  • User Agent: Chrome 120 on macOS

Notes

  • OTP/Captcha: Uber may require phone OTP or CAPTCHA during login. Use headless: false to handle these manually.
  • Fare Estimates: Available without login via uber.com/global/en/price-estimate/
  • Ride Requests: Require an active logged-in session.
  • Cancellation Fees: Uber may charge a fee if you cancel after a driver is assigned.
  • Mobile App: Uber is primarily a mobile app. The web interface (riders.uber.com) is used for automation, which may have different features than the mobile app.

License

MIT — Strider Labs