Morocco Open Data MCP

Morocco Open Data MCP

Provides unified access to Moroccan government data, financial markets, geographic information, and more via natural language queries.

Category
Visit Server

README

πŸ‡²πŸ‡¦ Morocco Open Data MCP Server

A comprehensive Model Context Protocol (MCP) server providing unified access to Moroccan government data sources, financial markets, geographic information, and more.

πŸ“‹ Table of Contents

✨ Features

πŸ›οΈ National Open Data

  • Access to data.gov.ma - Morocco's national open data portal
  • Search datasets in Arabic, French, and English
  • Browse by organization, tags, and categories
  • Download resources in various formats (CSV, JSON, XML, etc.)

πŸ’° Financial & Macroeconomic Data

  • Bank Al-Maghrib (Central Bank)

    • Exchange rates (daily updates)
    • Key interest rates and monetary policy
    • Inflation and consumer price indices
    • Money supply aggregates (M1, M2, M3)
    • Treasury bills auction results
    • Foreign reserves data
  • Casablanca Stock Exchange (BVC)

    • Real-time stock quotes
    • Market indices (MASI, MASIX, etc.)
    • Company information and financials
    • Government and corporate bonds
    • Market statistics and trading data

🌍 International Data

  • World Bank Indicators
    • GDP and economic growth
    • Population and demographics
    • Poverty and social indicators
    • Trade and balance of payments
    • Environmental statistics

πŸ•Œ Islamic Services

  • Prayer times for all major Moroccan cities
  • Weekly and monthly prayer schedules
  • Qibla direction calculations
  • Hijri calendar integration

πŸ—ΊοΈ Geography & GIS

  • Administrative divisions (12 regions)
  • City coordinates and metadata
  • Searchable city database
  • Regional information in multiple languages

🀝 Humanitarian & Crisis Data

  • Humanitarian Data Exchange (HDX) integration
  • Emergency response datasets
  • Refugee and displacement data
  • Health and education statistics

🌱 Climate & Environment

  • Climate data and weather patterns
  • Environmental indicators
  • CO2 emissions tracking
  • Renewable energy statistics

πŸš€ Quick Start

Prerequisites

  • Node.js 18.0 or higher
  • npm or yarn
  • Claude Desktop (for MCP integration)

1. Clone the Repository

cd "MoroccoOpenData MCP"

2. Install Dependencies

npm install

3. Build the Server

npm run build

4. Configure Environment

cp .env.example .env
# Edit .env and add your API keys

5. Test the Server

npm test

6. Run the Server

# Development mode (with hot reload)
npm run dev

# Production mode
npm start

πŸ“¦ Installation

Using npm

npm install -g morocco-open-data-mcp

From Source

git clone https://github.com/kcbdev/morocco-open-data-mcp.git
cd morocco-open-data-mcp
npm install
npm run build

Using Docker

# Build the image
docker build -t morocco-open-data-mcp .

# Run the container
docker run -d \
  --name morocco-mcp \
  -e MCP_TRANSPORT=http \
  -e MCP_PORT=3000 \
  -e BAM_KEY_CHANGES=your_key \
  morocco-open-data-mcp

Using Docker Compose

# Create .env file with your API keys
cp .env.example .env

# Start all services
docker-compose up -d

# View logs
docker-compose logs -f

βš™οΈ Configuration

Environment Variables

Variable Description Default
MCP_TRANSPORT Transport mode: stdio or http auto
MCP_PORT HTTP server port (when using HTTP transport) 3000
MCP_HOST HTTP server host 0.0.0.0
BAM_KEY_CHANGES Bank Al-Maghrib API key for exchange rates Required for BAM data
BAM_KEY_OBLIGATIONS BAM API key for government obligations Required for obligations
BAM_KEY_TBILLS BAM API key for treasury bills Required for T-bills
WORLD_BANK_API_KEY World Bank API key Optional (some endpoints)
ACLED_API_KEY ACLED API key for crisis data Optional
OPENWEATHER_API_KEY OpenWeatherMap API key Optional
CACHE_TTL_DEFAULT Default cache TTL (seconds) 3600
CACHE_TTL_SHORT Short-term cache TTL (seconds) 300
CACHE_TTL_LONG Long-term cache TTL (seconds) 86400
RATE_LIMIT_DEFAULT Default rate limit (req/min) 60
RATE_LIMIT_STRICT Strict rate limit (req/min) 10

Claude Desktop Configuration

Add to your claude_desktop_config.json:

macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
Linux: ~/.config/Claude/claude_desktop_config.json

For Local Development (stdio transport):

{
  "mcpServers": {
    "morocco-open-data": {
      "command": "node",
      "args": ["/home/kcb/Work/LABS/MOPD/MoroccoOpenData MCP/dist/index.js"],
      "env": {
        "BAM_KEY_CHANGES": "your_key_here",
        "BAM_KEY_OBLIGATIONS": "your_key_here",
        "BAM_KEY_TBILLS": "your_key_here"
      }
    }
  }
}

For Remote Server (HTTP SSE transport):

{
  "mcpServers": {
    "morocco-open-data": {
      "url": "https://morocco-opendata-mcp.kcb.ma",
      "transportType": "sse"
    }
  }
}

Using mcp-remote:

{
  "mcpServers": {
    "morocco-open-data": {
      "command": "npx",
      "args": ["-y", "mcp-remote@latest"],
      "env": {
        "MCP_SERVER_URL": "https://morocco-opendata-mcp.kcb.ma/sse"
      }
    }
  }
}

πŸ› οΈ Available Tools

Open Data (data.gov.ma)

Tool Description
search_datasets Search for datasets on Morocco's open data portal
get_dataset Get detailed information about a specific dataset
list_organizations List all data-publishing organizations
search_by_tag Search datasets by tag

Financial & Macroeconomic

Tool Description
get_exchange_rates Get current exchange rates from Bank Al-Maghrib
get_interest_rates Get key interest rates and monetary policy rates
get_inflation_data Get inflation and CPI data
get_money_supply Get money supply aggregates (M1, M2, M3)
get_treasury_bills Get treasury bills auction results
get_world_bank_indicators Get World Bank development indicators
get_morocco_economic_summary Get comprehensive economic summary

Capital Markets

Tool Description
get_stock_quotes Get stock quotes from Casablanca Stock Exchange
get_market_summary Get today's market summary
get_market_indices Get market indices (MASI, MASIX, etc.)
get_bond_quotes Get government and corporate bond quotes
get_company_info Get detailed company information

Geography & GIS

Tool Description
get_morocco_regions Get all administrative regions of Morocco
get_city_coordinates Get coordinates for Moroccan cities
search_cities Search for cities by name or region

Prayer Times

Tool Description
get_prayer_times Get prayer times for a specific date
get_weekly_prayer_times Get prayer times for the next 7 days
get_next_prayer Get the next upcoming prayer time
list_prayer_cities List all available Moroccan cities

Humanitarian & Crisis

Tool Description
get_humanitarian_datasets Search humanitarian datasets from HDX

Climate & Environment

Tool Description
get_climate_data Get climate and weather data
get_environmental_indicators Get environmental indicators (CO2, renewable energy, etc.)

Knowledge Graph

Tool Description
search_knowledge_graph Search the Morocco knowledge graph
get_data_sources Get list of all available data sources

πŸ“– Usage Examples

Example 1: Search for Economic Datasets

Search for datasets about Morocco's economy on data.gov.ma

Example 2: Get Current Exchange Rates

What's the current exchange rate for EUR to MAD?
Show me all exchange rates from Bank Al-Maghrib

Example 3: Stock Market Information

Get me the current stock price for Attijariwafa Bank
Show me today's market summary from Casablanca Stock Exchange
What are the top gainers today?

Example 4: Prayer Times

What are the prayer times for today in Marrakech?
When is the next prayer in Rabat?
Show me the weekly prayer schedule for Casablanca

Example 5: Economic Indicators

Get Morocco's GDP growth rate for the last 5 years
Show me the current inflation rate
What's the unemployment rate in Morocco?

Example 6: Geographic Data

List all regions of Morocco with their capitals
What are the coordinates of Fes?
Search for cities in the Souss-Massa region

πŸ“Š Data Sources

Tier 1 - Native REST APIs

Source Type Status
data.gov.ma CKAN API βœ… Active
Bank Al-Maghrib REST API βœ… Active
Casablanca Stock Exchange REST API βœ… Active
World Bank REST API βœ… Active
Aladhan (Prayer Times) REST API βœ… Active

Tier 2 - Structured Downloads

Source Type Status
HCP (High Commission for Planning) Portal πŸ”„ Pending
Ministry of Economy & Finance Portal πŸ”„ Pending
Ministry of Health Portal πŸ”„ Pending

Tier 3 - International Sources

Source Type Status
Humanitarian Data Exchange API πŸ”„ Pending
ACLED (Crisis Data) API πŸ”„ Pending
OpenWeatherMap API πŸ”„ Pending

🚒 Deployment

Production Deployment with Docker

  1. Build the production image:
docker build -t morocco-open-data-mcp:latest --target production .
  1. Run with environment variables:
docker run -d \
  --name morocco-mcp \
  --restart unless-stopped \
  -e NODE_ENV=production \
  -e MCP_TRANSPORT=http \
  -e MCP_PORT=3000 \
  -e BAM_KEY_CHANGES=your_key \
  -e BAM_KEY_OBLIGATIONS=your_key \
  -e BAM_KEY_TBILLS=your_key \
  -e CACHE_TTL_DEFAULT=3600 \
  -e RATE_LIMIT_DEFAULT=60 \
  morocco-open-data-mcp:latest
  1. Monitor the container:
docker logs -f morocco-mcp
docker stats morocco-mcp

Coolify Deployment

For deployment on Coolify (https://coolify.kcb.ma):

  1. Create new resource from Git repository
  2. Repository: https://github.com/kcbdev/morocco-open-data-mcp
  3. Branch: main
  4. Domain: morocco-opendata-mcp.kcb.ma
  5. Environment Variables:
    MCP_TRANSPORT=http
    MCP_PORT=3000
    MCP_HOST=0.0.0.0
    NODE_ENV=production
    BAM_KEY_CHANGES=your_key
    BAM_KEY_OBLIGATIONS=your_key
    BAM_KEY_TBILLS=your_key
    

Kubernetes Deployment (Optional)

apiVersion: apps/v1
kind: Deployment
metadata:
  name: morocco-mcp
spec:
  replicas: 3
  selector:
    matchLabels:
      app: morocco-mcp
  template:
    metadata:
      labels:
        app: morocco-mcp
    spec:
      containers:
      - name: mcp-server
        image: ghcr.io/kcbdev/morocco-open-data-mcp:latest
        env:
        - name: NODE_ENV
          value: "production"
        - name: MCP_TRANSPORT
          value: "http"
        - name: BAM_KEY_CHANGES
          valueFrom:
            secretKeyRef:
              name: mcp-secrets
              key: bam-key-changes
        resources:
          limits:
            cpu: "1"
            memory: "512Mi"
          requests:
            cpu: "250m"
            memory: "128Mi"

πŸ‘¨β€πŸ’» Development

Project Structure

morocco-open-data-mcp/
β”œβ”€β”€ src/
β”‚   β”œβ”€β”€ clients/          # API clients for each data source
β”‚   β”‚   β”œβ”€β”€ ckan.ts       # data.gov.ma client
β”‚   β”‚   β”œβ”€β”€ bam.ts        # Bank Al-Maghrib client
β”‚   β”‚   β”œβ”€β”€ worldbank.ts  # World Bank client
β”‚   β”‚   β”œβ”€β”€ bvc.ts        # Casablanca Stock Exchange client
β”‚   β”‚   β”œβ”€β”€ prayer.ts     # Prayer times client
β”‚   β”‚   β”œβ”€β”€ geo.ts        # Geography/GIS client
β”‚   β”‚   β”œβ”€β”€ hdx.ts        # Humanitarian Data Exchange client
β”‚   β”‚   └── weather.ts    # Weather API client
β”‚   β”œβ”€β”€ lib/              # Core utilities
β”‚   β”‚   β”œβ”€β”€ cache.ts      # Caching layer
β”‚   β”‚   β”œβ”€β”€ rateLimiter.ts # Rate limiting
β”‚   β”‚   β”œβ”€β”€ arabic.ts     # Arabic text processing
β”‚   β”‚   └── errors.ts     # Error handling
β”‚   β”œβ”€β”€ sync/             # Data synchronization jobs
β”‚   β”œβ”€β”€ index.ts          # Main server entry point
β”‚   └── test.ts           # Test suite
β”œβ”€β”€ package.json
β”œβ”€β”€ tsconfig.json
β”œβ”€β”€ Dockerfile
β”œβ”€β”€ docker-compose.yml
β”œβ”€β”€ claude_desktop_config.json
└── README.md

Development Commands

# Install dependencies
npm install

# Run in development mode with hot reload
npm run dev

# Build for production
npm run build

# Run tests
npm test

# Run sync jobs manually
npm run sync

# Start production server
npm start

Running Tests

# Run all tests
npm test

# Run tests with external APIs disabled
SKIP_EXTERNAL_APIS=true npm test

# Run specific test file
npx tsx src/test.ts

πŸ”‘ API Keys

Required API Keys

Bank Al-Maghrib (BAM)

  • Registration: Visit Bank Al-Maghrib and request API access
  • Endpoints: Exchange rates, treasury bills, government obligations
  • Rate Limits: 30 requests/minute

World Bank

Optional API Keys

Service Purpose Registration
ACLED Crisis/conflict data ACLED
OpenWeatherMap Weather data OpenWeatherMap
HDX Humanitarian data HDX

πŸ› Troubleshooting

Common Issues

1. "Module not found" errors

# Rebuild the project
rm -rf dist/
npm run build

2. API rate limit errors

  • Check your rate limit status in logs
  • Increase RATE_LIMIT_DEFAULT in .env
  • Implement request caching

3. BAM API authentication errors

  • Verify API keys are correct
  • Check if keys have expired
  • Ensure keys have correct permissions

4. Claude Desktop integration issues

  • Verify path to dist/index.js is correct
  • Check Claude Desktop logs
  • Restart Claude Desktop after config changes

5. SSE Connection Failed

  • Ensure MCP_TRANSPORT=http is set in environment variables
  • Verify the server is running in HTTP mode
  • Check firewall allows connections to port 3000

Debug Mode

Enable verbose logging:

NODE_ENV=development DEBUG=* npm run dev

Health Checks

# Check if server is running (HTTP mode)
curl https://morocco-opendata-mcp.kcb.ma/health

# Check if server is running (local stdio mode)
node -e "console.log('MCP server healthy')"

# The server will log status of all data sources on startup

🀝 Contributing

We welcome contributions! Please follow these guidelines:

Getting Started

  1. Fork the repository: https://github.com/kcbdev/morocco-open-data-mcp
  2. Create a feature branch: git checkout -b feature/your-feature
  3. Make your changes
  4. Run tests: npm test
  5. Commit your changes: git commit -am 'Add new feature'
  6. Push to the branch: git push origin feature/your-feature
  7. Submit a pull request

Code Style

  • Follow TypeScript best practices
  • Use ESLint rules (coming soon)
  • Write meaningful commit messages
  • Add tests for new features
  • Update documentation

Areas for Contribution

  • [ ] Additional data sources (ministries, agencies)
  • [ ] More geographic data (provinces, communes)
  • [ ] Historical data archives
  • [ ] Data visualization tools
  • [ ] Arabic/French language improvements
  • [ ] Performance optimizations
  • [ ] Documentation translations

πŸ“„ License

This project is licensed under the Creative Commons Attribution-NonCommercial 4.0 International License (CC BY-NC 4.0).

See the LICENSE file for details.

What This Means:

  • βœ… You CAN: Share, copy, redistribute, adapt, and build upon this material
  • βœ… You MUST: Give appropriate credit, provide a link to the license, and indicate if changes were made
  • ❌ You CANNOT: Use this material for commercial purposes
  • ❌ You CANNOT: Apply legal terms or technological measures that restrict others from doing anything the license permits

For commercial licensing inquiries, contact: oss@kcb.ma


πŸ“ž Support

πŸ™ Acknowledgments

  • Bank Al-Maghrib - For providing financial and economic data
  • data.gov.ma - Morocco's national open data portal
  • World Bank - For development indicators and statistics
  • Casablanca Stock Exchange - For market data
  • Aladhan API - For prayer times services
  • MCP Project - For the Model Context Protocol framework

Built with ❀️ for Morocco's open data community

Morocco Open Data MCP Server v1.0.0
Live Deployment: https://morocco-opendata-mcp.kcb.ma
Source Code: https://github.com/kcbdev/morocco-open-data-mcp

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