Skip to content

aliafsahnoudeh/wildfire-mcp-server

Repository files navigation

Wildfire MCP Server

A Model Context Protocol (MCP) server for detecting, monitoring, and analyzing potential wildfires globally using multiple data sources including NASA FIRMS, OpenWeatherMap, and Google Earth Engine.

Overview

This MCP server provides AI assistants with tools to detect and analyze wildfire activity anywhere in the world by integrating real-time satellite data, weather forecasts, air pollution metrics, and geographical information. It's designed to help identify potential wildfires and assess their environmental impact.

Features

  • Fire Detection: Query NASA FIRMS (Fire Information for Resource Management System) for active fire hotspots
  • Weather Forecasting: Get 5-day weather forecasts for specific locations
  • Air Pollution Monitoring: Access current and historical air pollution data
  • Reverse Geocoding: Convert coordinates to human-readable addresses
  • Fire Fuel Assessment: Determine if a location contains potential wildfire fuel based on land cover data
  • Customizable Filtering: Filter fires by radiative power, brightness temperature, and geographic boundaries

Prerequisites

Configure API keys (if required):

  • NASA FIRMS Map Key
  • OpenWeatherMap API Key
  • Google Earth Engine credentials (if applicable)

Available Tools

get_potential_wildfires

Get potential wildfires for a specific date using NASA FIRMS data.

Parameters:

  • date (str, optional): Date in YYYY-MM-DD format. Defaults to current date.
  • frp (float): Fire Radiative Power threshold (default: 1)
  • bright_ti4 (float): Brightness temperature threshold (default: 50)
  • in_iran (bool): If True, filters fires to only show those within Iran's borders (useful for Iran-specific monitoring)
  • bounding_box (BoundingBox, optional): Custom bounding box to limit search area to any geographic region

get_address

Get the address for given coordinates.

Parameters:

  • latitude (float): Latitude of the location
  • longitude (float): Longitude of the location

get_weather_forecast

Get 5-day weather forecast with 3-hour intervals.

Parameters:

  • latitude (float): Latitude of the location
  • longitude (float): Longitude of the location

get_current_air_pollution_data

Fetch current air pollution data.

Parameters:

  • latitude (float): Latitude of the location
  • longitude (float): Longitude of the location

get_historical_air_pollution_data

Fetch historical air pollution data for a date range.

Parameters:

  • latitude (float): Latitude of the location
  • longitude (float): Longitude of the location
  • start_date (str): Start of period (YYYY-MM-DD or YYYY-MM-DD HH:MM:SS)
  • end_date (str): End of period (YYYY-MM-DD or YYYY-MM-DD HH:MM:SS)

is_fire_fuel

Check if a location contains potential wildfire fuel.

Parameters:

  • latitude (float): Latitude of the location
  • longitude (float): Longitude of the location

Returns: Boolean indicating if location is in a potential wildfire fuel area

Testing

Using MCP Inspector

npx @modelcontextprotocol/inspector python wildfire_mcp_server.py

The timeout for the client needs to be increased since some data fetching operations can take a while. This can be done either by setting the config in the UI or by setting the following environment variables:

export MCP_SERVER_REQUEST_TIMEOUT=9000000
export MCP_REQUEST_MAX_TOTAL_TIMEOUT=9000000
export MCP_REQUEST_TIMEOUT_RESET_ON_PROGRESS=true

Good date to test: 2025-11-21 (known active fire day)

Running Test Scripts

# Test individual components
uv run scripts/test_nasa_firms.py
uv run scripts/test_main_functionality.py
uv run scripts/test_overpass.py

Architecture

The project is organized into several layers:

  • wildfire_mcp_server.py: Main server entry point with MCP tool definitions
  • src/agents/: High-level agent classes that orchestrate domain services
    • LikelyFireAgent: Fire detection and filtering
    • FireFuelAgent: Land cover and fuel assessment
    • AddressAgent: Reverse geocoding
    • WeatherForecastAgent: Weather data retrieval
    • AirPollutionAgent: Air quality data
  • src/domains/: Domain-specific integrations
    • nasa_firms/: NASA FIRMS fire data API
    • open_weather_map/: Weather and air pollution APIs
    • google_earth_engine/: Land cover data
    • overpass/: OpenStreetMap data
    • planetary_computer/: Microsoft Planetary Computer integration

Data Sources

  • NASA FIRMS: Active fire data from MODIS and VIIRS satellites
  • OpenWeatherMap: Weather forecasts and air pollution metrics
  • Google Earth Engine: Land cover classification
  • OpenStreetMap (Overpass): Geographic and administrative boundaries

License

This project is licensed under a custom Evaluation and Non-Production License. See the LICENSE file for details.

Note: Production use requires explicit written approval from the copyright holder.

Contributing

Contributions are welcome for evaluation and improvement purposes. Please ensure any pull requests maintain the evaluation-only nature of this license.

Disclaimer

This tool is designed for wildfire monitoring and research purposes. Fire detection data should be verified with official sources before taking any action. The accuracy of fire detection depends on satellite data availability and environmental conditions.

Support

For issues, questions, or production licensing inquiries, please open an issue on the repository or contact the maintainers directly.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages