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 🙏

© 2025 – Pkg Stats / Ryan Hefner

@tomaspavlin/rohlik-mcp

v3.0.0

Published

MCP server for controlling Rohlik.cz grocery shopping website

Downloads

95

Readme

Rohlik MCP Server

Enhance your favourite LLM with capabilities to buy groceries.

[!WARNING] This MCP server is made for study purposes with use of reverse engineered Rohlik API. It is for personal use only.

This is a Model Context Protocol (MCP) server that enables AI assistants to interact with the Rohlik Group's online grocery delivery services across multiple countries. This server provides tools for searching products, managing shopping carts, and accessing account info.

Supported Services:

Example LLM prompts that work very well with the Rohlik MCP:

🛒 Regular Shopping:

  • Add ingredients for apple pie to the cart. Only gluten-free and budget-friendly.
  • Or actually, instead of apple pie I want to make pumpkin pie. Change the ingredients.
  • What are the items in my cart?
  • Add the items in the attached shopping list photo to the cart.
  • Add the bread I marked as favorite in Rohlik to my cart.

🤖 Smart Shopping:

  • "Add breakfast items I typically order"
  • "Show me lunch suggestions for this week"
  • "What do I usually buy for dinner?"
  • "I need snacks - suggest what I normally order"
  • "Show my top 20 most purchased items"
  • "What can I do with Rohlik MCP?"

📅 Planning:

  • What are the cheapest delivery slots for tomorrow?
  • When is my next delivery?
  • Show my last 5 orders

📚 Documentation

New to Rohlik MCP? Check out our Complete Guide for Newcomers!

Usage

Claude Desktop Configuration

Add the MCP to Claude Desktop configuration:

  • On MacOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • On Windows: %APPDATA%/Claude/claude_desktop_config.json

Add the following configuration:

{
  "mcpServers": {
    "rohlik": {
      "command": "npx",
      "args": ["-y", "@tomaspavlin/rohlik-mcp"],
      "env": {
        "ROHLIK_USERNAME": "[email protected]",
        "ROHLIK_PASSWORD": "your-password",
        "ROHLIK_BASE_URL": "https://www.rohlik.cz"
      }
    }
  }
}

Supported Regions

The server supports multiple Rohlik regions by setting the ROHLIK_BASE_URL environment variable:

  • Czech Republic: https://www.rohlik.cz (default)
  • Germany: https://www.knuspr.de
  • Austria: https://www.gurkerl.at
  • Hungary: https://www.kifli.hu
  • Romania: https://www.sezamo.ro
  • Italy (planned): https://www.sezamo.it
  • Spain (planned): https://www.sezamo.es

If ROHLIK_BASE_URL is not specified, it defaults to the Czech version.

Tools

Core Shopping

  • search_products - Search for grocery products by name with filtering options
  • add_to_cart - Add multiple products to your shopping cart
  • get_cart_content - View current cart contents and totals
  • remove_from_cart - Remove items from your shopping cart
  • get_shopping_list - Retrieve shopping lists by ID

🤖 Smart Shopping

  • get_meal_suggestions - Get personalized suggestions for breakfast, lunch, dinner, snacks, baking, drinks, or healthy eating based on your order history
  • get_frequent_items - Analyze order history to find most frequently purchased items (overall + per category)
  • get_shopping_scenarios - Interactive guide showing what you can do with the MCP

Getting info

  • get_account_data - Get comprehensive account information including delivery details, orders, announcements, cart, and premium status
  • get_order_history - View your past delivered orders with details
  • get_order_detail - Get detailed information about a specific order including all products
  • get_upcoming_orders - See your scheduled upcoming orders
  • get_delivery_info - Get current delivery information and fees
  • get_delivery_slots - View available delivery time slots for your address
  • get_premium_info - Check your Rohlik Premium subscription status and benefits
  • get_announcements - View current announcements and notifications
  • get_reusable_bags_info - Track your reusable bags and environmental impact

Development

Installation

npm install
npm run build

Scripts

  • npm run build - Compile TypeScript to JavaScript
  • npm start - Launch the production server
  • npm run dev - Start development mode with watch
  • npm run inspect - Test with MCP Inspector
  • npm test - Run unit tests
  • npm run test:watch - Run tests in watch mode
  • npm run test:coverage - Generate test coverage report

Testing

Unit Tests

The project includes unit tests for smart shopping data transformation logic:

# Run all tests
npm test

# Run tests in watch mode (development)
npm run test:watch

# Generate coverage report
npm run test:coverage

What's tested:

  • Frequency analysis algorithms (get_frequent_items)
  • Meal suggestion filtering and ranking (get_meal_suggestions)
  • Price averaging and calculations
  • Category filtering and grouping
  • Edge cases (empty data, missing fields, etc.)

See tests/README.md for detailed testing documentation.

Testing with Claude Desktop

Add this to configuration:

{
  "mcpServers": {
    "rohlik-local": {
      "command": "node",
      "args": ["/path/to/rohlik-mcp/dist/index.js"],
      "env": {
        "ROHLIK_USERNAME": "[email protected]",
        "ROHLIK_PASSWORD": "your-password",
        "ROHLIK_BASE_URL": "https://www.rohlik.cz"
      }
    }
  }
}

Debug Mode

If you're experiencing authentication issues, enable debug mode to see detailed logs:

{
  "mcpServers": {
    "rohlik-local": {
      "command": "node",
      "args": ["/path/to/rohlik-mcp/dist/index.js"],
      "env": {
        "ROHLIK_USERNAME": "[email protected]",
        "ROHLIK_PASSWORD": "your-password",
        "ROHLIK_BASE_URL": "https://www.rohlik.cz",
        "ROHLIK_DEBUG": "true"
      }
    }
  }
}

Debug logs will appear in ~/Library/Logs/Claude/mcp-server-rohlik-local.log (macOS) or %APPDATA%/Claude/logs/mcp-server-rohlik-local.log (Windows).

Testing with MCP Inspector

You can test the MCP server using the official MCP Inspector (https://modelcontextprotocol.io/legacy/tools/inspector):

npm run inspect

In the Inspector, set the ROHLIK_USERNAME and ROHLIK_PASSWORD envs.

API Validation Tool

To validate that all Rohlik API endpoints are working correctly and diagnose authentication issues:

npm run validate-api

This will:

  • Test all 11 API endpoints used by the MCP server
  • Show detailed HTTP request/response logs in the console
  • Generate a JSON report: tests/validation-results.json
  • Generate a beautiful HTML report: tests/validation-report.html

The validator automatically loads credentials from your Claude Desktop config or environment variables. Open the HTML report in your browser for an easy-to-read summary of all tests.

Troubleshooting

Common Issues

"Login failed" Error

Possible causes:

  1. Wrong username/password in configuration
  2. Rohlik API changed or is temporarily unavailable
  3. Network connectivity issues

Solutions:

  1. Verify credentials in your claude_desktop_config.json
  2. Enable debug mode: "ROHLIK_DEBUG": "true" in env section
  3. Check logs: ~/Library/Logs/Claude/mcp-server-rohlik*.log (macOS) or %APPDATA%\Claude\logs\mcp-server-rohlik*.log (Windows)
  4. Run API validator: npm run validate-api to test all endpoints

"No order history found"

Cause: Your account has no past orders, or orders are not accessible

Solution: Ensure you have at least one completed order on Rohlik before using smart shopping features (get_meal_suggestions, get_frequent_items)

Slow response times

Causes:

  • Analyzing too many orders (smart shopping features)
  • Network latency to Rohlik servers
  • API rate limiting

Solutions:

  • For smart shopping: reduce number of orders analyzed (try 10 instead of default 20)
  • Use fewer requests or add delays between bulk operations
  • Check your network connection

Products not found or search returns no results

Causes:

  • Product out of stock or discontinued
  • Product ID changed in Rohlik system
  • Spelling mistake in search query

Solutions:

  • Search by partial name instead of full product name
  • Try alternative spellings or broader search terms
  • Verify product exists on Rohlik website directly

Enabling Debug Mode

Add ROHLIK_DEBUG to your configuration to see detailed logs:

{
  "mcpServers": {
    "rohlik-local": {
      "command": "node",
      "args": ["/path/to/rohlik-mcp/dist/index.js"],
      "env": {
        "ROHLIK_USERNAME": "[email protected]",
        "ROHLIK_PASSWORD": "your-password",
        "ROHLIK_BASE_URL": "https://www.rohlik.cz",
        "ROHLIK_DEBUG": "true"
      }
    }
  }
}

View logs:

# macOS
tail -f ~/Library/Logs/Claude/mcp-server-rohlik-local.log

# Windows
type %APPDATA%\Claude\logs\mcp-server-rohlik-local.log

Using the API Validation Tool

If you encounter authentication or API issues, run the validator:

npm run validate-api

This will:

  • Test all 11 API endpoints used by the MCP
  • Show detailed HTTP request/response information
  • Generate validation-results.json with test results
  • Create validation-report.html for easy viewing in browser
  • Help identify which specific endpoints are failing

Publishing as NPM package

  1. Update version in package.json
  2. npm publish

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgements

  • https://github.com/dvejsada/HA-RohlikCZ for reverse engineering the Rohlik.cz API