InventorySystem_MCP_Server

AllanSJoseph/InventorySystem_MCP_Server

3.2

If you are the rightful owner of InventorySystem_MCP_Server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.

InventorySystem MCP Server is a Python-based server that connects to an Inventory Management System, providing tools for CRUD operations.

Tools
15
Resources
0
Prompts
0

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.NoToolDescription
1fetch_usersReads all the Users Registered to System
2add_userAdds a New User to the System
3fetch_inventory_itemsReads all the Items Stored in the Inventory
4add_inventory_itemAdds a New Item to the Inventory
5update_inventory_itemUpdates Details of an Item in Inventory
6update_inventory_item_stockUpdates only the Stock of an Item in Inventory
7fetch_bill_recordsReads all the Bills Created in the System
8fetch_bill_records_by_cashierReads the Bills Filtered by Cashier who created them
9open_billReads the Item Entries in a Bill
10create_billCreates a New Bill by the Product Id and Stock
11issue_billIssues a Bill (Bill is Paid)
12discard_billDiscards a Draft Bill (Unpaid Bill)
13add_item_to_billAdds a new Item to a bill.
14edit_bill_item_quantityChanges the Quantity of a Item entry in a Bill
15delete_bill_itemDeletes 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