PSX MCP Server

PSX MCP Server

Provides 12 tools to scrape and access Pakistan Stock Exchange market data, including current prices, historical data, intraday, sector search, and volume analysis.

Category
Visit Server

README

PSX MCP Server

A Model Context Protocol (MCP) server that provides tools to scrape and access Pakistan Stock Exchange (PSX) market data.

🎥 Demo Video

PSX MCP Server Demo

Watch this demo to see the PSX MCP Server in action with real-time market data!

Features

This MCP server provides 12 powerful tools for comprehensive PSX data access:

📊 Basic Tools (Simple & Intuitive)

  1. market_data() - Get current market data for all 460+ stocks listed on PSX
  2. intraday(symbol) - Get intraday time series data for a specific stock
  3. history(symbol) - Get end-of-day historical data for a specific stock (past 5 years)
  4. sector(sector) - Search stocks by sector
  5. gainers(limit) - Get top gaining stocks
  6. losers(limit) - Get top losing stocks

🎯 Advanced Tools (Clean & Powerful)

  1. date_range(symbol, start, end) - Get EOD data for specific date range (YYYY-MM-DD format)
  2. time_range(symbol, start, end) - Get intraday data for specific time range (YYYY-MM-DD HH:MM:SS format)
  3. ohlcv(symbol) - Get OHLCV (Open, High, Low, Close, Volume) data for specific stock
  4. multi_ohlcv(symbols) - Get OHLCV data for multiple stocks (comma-separated symbols)
  5. price_at_time(symbol, timestamp) - Get closest price data at specific Unix timestamp
  6. volume_analysis(symbol, days) - Analyze volume patterns over specified number of days

Installation

Option 1: Direct Installation

  1. Install dependencies:
pip install -r requirements.txt
  1. Configure Gemini CLI (copy and customize the template):
cp gemini_config.template.json gemini_config.json
# Edit gemini_config.json with your project path
  1. Run the MCP server:
python scripts/start_server.py

Option 2: Development Installation

  1. Install with development tools:
make setup
# or
pip install -e ".[dev]"
  1. Run with Makefile:
make run-server

Option 3: Docker

  1. Build the Docker image:
docker build -t psx-mcp-server .
  1. Run the container:
docker run -it psx-mcp-server

Configuration

Template Files

The project includes template configuration files for easy setup:

  • gemini_config.template.json - Simple Gemini CLI configuration template
  • mcp_config.template.json - Advanced MCP configuration template with additional settings

Quick Setup

  1. Copy the template file:
cp gemini_config.template.json gemini_config.json
  1. Edit the configuration with your project path:
{
  "mcpServers": {
    "psx-scraper": {
      "command": "python",
      "args": ["/your/actual/path/scripts/start_server.py"],
      "env": {
        "PYTHONPATH": "/your/actual/path/src"
      }
    }
  }
}
  1. Connect Gemini CLI:
gemini --config gemini_config.json

Development

Available Commands

make help          # Show all available commands
make test          # Run test suite
make lint          # Run linting checks
make format        # Format code with black
make run-demo      # Run demonstrations
make clean         # Clean build artifacts

Data Sources

The server scrapes data from the following PSX endpoints:

  • https://dps.psx.com.pk/market-watch - Market watch data
  • https://dps.psx.com.pk/timeseries/int/{SYMBOL} - Intraday data
  • https://dps.psx.com.pk/timeseries/eod/{SYMBOL} - End-of-day data

Usage

The server can be used with any MCP client, such as Gemini CLI. The tools return JSON data that can be processed by the client.

Example Queries

Basic Data (Super Simple):

  • "Show me market data" → market_data()
  • "Get HBL intraday data" → intraday('HBL')
  • "Show HBL history" → history('HBL')
  • "Find banking stocks" → sector('Banking')
  • "Top 5 gainers" → gainers(5)

Advanced Filtering (Clean & Intuitive):

  • "HBL data from Jan to Feb" → date_range('HBL', '2024-01-01', '2024-02-01')
  • "HBL intraday 9AM to 3PM" → time_range('HBL', '2024-10-04 09:00:00', '2024-10-04 15:00:00')
  • "HBL OHLCV data" → ohlcv('HBL')
  • "OHLCV for HBL,OGDC" → multi_ohlcv('HBL,OGDC')
  • "HBL volume analysis" → volume_analysis('HBL', 30)

Example Stock Symbols

  • HBL - Habib Bank Limited
  • OGDC - Oil and Gas Development Company
  • PTC - Pakistan Telecommunication Company
  • LUCK - Lucky Cement
  • ENGRO - Engro Corporation

Data Models

Stock Data

  • Symbol, Sector, Listed In
  • LDCP, Open, High, Low, Current prices
  • Change amount and percentage
  • Volume traded

Time Series Data

  • Unix timestamp
  • Price/Close price
  • Volume
  • Open price (for EOD data)

Error Handling

All tools include proper error handling and return error messages in JSON format if requests fail.

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