InventorySystem MCP Server

InventorySystem MCP Server

A Python MCP server that connects to an Inventory Management System, providing 15 tools for CRUD operations on users, inventory items, and bills.

Category
Visit Server

README

InventorySystem MCP Server

A Python based MCP (Model Context Protocol) Server that connects to an Inventory Management System and provides various tools to handle CRUD operations to it.

This is a simple side project I tried myself for fun to try enable AI compatibility to one of our college miniprojects.

What this MCP Server does

  • Serves as an Interface between InventorySystem Server and MCP Client (eg: Claude)
  • Provides 15 MCP tools to conduct CRUD operations on Inventory Management System Database.
    • Create and Read Registered Users.
    • Create, Update and Read Inventory Items.
    • Create, Read, Update and Delete Bills.
  • Uses Pydantic to validate data inputs given by LLM before passing to main server.
  • Logs server logs for easy debugging.

Tools

Below are the tools that this MCP server provides.

S.No Tool Description
1 fetch_users Reads all the Users Registered to System
2 add_user Adds a New User to the System
3 fetch_inventory_items Reads all the Items Stored in the Inventory
4 add_inventory_item Adds a New Item to the Inventory
5 update_inventory_item Updates Details of an Item in Inventory
6 update_inventory_item_stock Updates only the Stock of an Item in Inventory
7 fetch_bill_records Reads all the Bills Created in the System
8 fetch_bill_records_by_cashier Reads the Bills Filtered by Cashier who created them
9 open_bill Reads the Item Entries in a Bill
10 create_bill Creates a New Bill by the Product Id and Stock
11 issue_bill Issues a Bill (Bill is Paid)
12 discard_bill Discards a Draft Bill (Unpaid Bill)
13 add_item_to_bill Adds a new Item to a bill.
14 edit_bill_item_quantity Changes the Quantity of a Item entry in a Bill
15 delete_bill_item Deletes the Item entry from the bill

How to Setup this MCP Server

Prerequisites

  • Python 3.8 or higher
  • uv (Python package manager for MCP servers)
  • XAMPP Apache Server with InventorySystem server set up correctly.
  • An MCP client that supports MCP servers eg: Claude Desktop, Cursor, WindSurf, etc.
  • [Optional] Node.js (for inspecting the MCP server)

Setup InventorySystem Main Server

  1. Install XAMPP from XAMPP Official Site
  2. Make sure Apache and MySQL (MariaDB) services are running
  3. Navigate to htdocs folder (Location where XAMPP is installed eg: C://xampp/htdocs)
  4. Make a new directory invmgmt (or name of your choice)
mkdir invmgmt
cd invmgmt
  1. Clone the mcp branch from InventorySystem Repository on this folder
git clone -b mcp --single-branch https://github.com/AllanSJoseph/InventorySystem.git

Setup MCP Server

Setup uv

For Windows users:

powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"

For Linux/Mac users (Note: This server is ran and tested on Windows):

curl -LsSf https://astral.sh/uv/install.sh | sh

Install Project Dependencies

  1. Clone this repository

  2. Open the directory in terminal

  3. Install the required dependencies using uv

    uv sync
    
  4. Open an MCP Client (here I am using Claude Desktop).

  5. Go To Claude Settings Ctrl + ,.

  6. Go to the Developer tab.

  7. Click on Edit Config under Local MCP Servers.

  8. It highlights the claude_desktop_config.json file, Open it in your favourite text editor.

  9. Add the below code to the mcp_servers list in the JSON file save and close.

"mcpServers": {
        "inventory_mgmt_mcp": {
            "command": "uv",
            "args": [
                "--directory",
                "your_project_directory_path",
                "run",
                "main.py"
            ]
        }
    }
  1. Restart Claude Desktop
  2. Open a new chat and click on tools button on the chat box and you will see the documentation tool available.
  3. Try a prompt like below:
Could you list the users that are registered to Inventory Management System.
  1. The LLM will use the fetch_users tool to search for the answer and return it in the chat. If it askes for permission click on Allow always.

Please Note that free version of Claude has a limitation of number of tokens or characters, so it may not give results as desired and can sometimes give you an error of exceeding the token limit. You can try with a paid version of Claude or use other MCP clients like Cursor, WindSurf, etc.

Refer the official MCP Documentation from Antropic for more details on how to setup MCP servers in your client For Server Developers - Model Context Protocol

Sample Prompts to try with Claude

Add a Demo User

Could you add a demo user with a name of your choice and details of your choice, user must be a Cashier.

Add a Product

Could you add the below product to the Inventory Server.
AMUL MILK with stock 200 and price 20. Add a description of your choice.

Create a bill and issue it

Could you create a bill with the items 2 units of product id 1, 5 units of product id 21 and 3 units of product id 5, Issue the bill with payment method 'UPI'

Note: These products should be already in the inventory management main server. The database won't have any items just after setup.

Checking the logs

In the project root directory find serverlogs.log, which will contain the logs. It is ignored in git but it will be created when server is up.

Inspect this MCP Server

To inspect the tools and check if tools are working properly, run the below command in terminal on the project directory.

npx @modelcontextprotocol/inspector uv run main.py

Verified on MSeeP

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured