 
            
            
            
            
        NOAA Tides and Currents MCP Server
This is an MCP (Model Context Protocol) server that provides tools for interacting with the NOAA Tides and Currents API using the FastMCP framework.
Features
- Water Level data retrieval (real-time and historical)
- Tide Predictions (high/low or interval-based)
- Currents data (real-time and historical)
- Current predictions
- Station metadata retrieval
- Wind, air temperature, water temperature, and other meteorological data
- Moon phase information (past, present, and future)
- Sun rise/set and position data (past, present, and future)
Prerequisites
- Node.js (v18 or higher)
- npm or yarn
Setup
Installing via Smithery
To install NOAA Tides and Currents for Claude Desktop automatically via Smithery:
npx -y @smithery/cli install @RyanCardin15/tidesandcurrents --client claude
Manual Installation
- Clone this repository
- Install dependencies
npm install
- Create a .envfile based on the.env.examplefile:
# Server Configuration
PORT=3000
# Transport type (stdio or sse)
TRANSPORT_TYPE=stdio
# NOAA API application name for identification (recommended)
APPLICATION_NAME=YourAppName
- Build the TypeScript code
npm run build
- Start the server
npm start
Usage
This MCP server can be used with any MCP host such as Claude Desktop, which allows you to use the NOAA Tides and Currents API through the MCP protocol.
You can also test it directly using the fastmcp command-line tool:
npx fastmcp dev dist/index.js
Or, you can use the MCP Inspector:
npx fastmcp inspect dist/index.js
Available Tools
Water Levels
- 
get_water_levels- Get water level data for a station- Parameters:
- 
station(string) - Station ID
- 
date(string, optional) - Date to retrieve data for ("today", "latest", "recent", or specific date)
- 
begin_date(string, optional) - Start date (YYYYMMDD or MM/DD/YYYY)
- 
end_date(string, optional) - End date (YYYYMMDD or MM/DD/YYYY)
- 
range(number, optional) - Number of hours to retrieve data for
- 
datum(string, optional) - Datum to use (MLLW, MSL, etc.)
- 
units(string, optional) - Units to use ("english" or "metric")
- 
time_zone(string, optional) - Time zone (gmt, lst, lst_ldt)
- 
format(string, optional) - Output format (json, xml, csv)
 
- 
 
- Parameters:
Tide Predictions
- 
get_tide_predictions- Get tide prediction data- Parameters:
- 
station(string) - Station ID
- 
begin_date(string) - Start date (YYYYMMDD or MM/DD/YYYY)
- 
end_date(string) - End date (YYYYMMDD or MM/DD/YYYY)
- 
datum(string, optional) - Datum to use (MLLW, MSL, etc.)
- 
units(string, optional) - Units to use ("english" or "metric")
- 
time_zone(string, optional) - Time zone (gmt, lst, lst_ldt)
- 
interval(string, optional) - Interval (hilo, hl, h, or a number for minutes)
- 
format(string, optional) - Output format (json, xml, csv)
 
- 
 
- Parameters:
Currents
- 
get_currents- Get currents data for a station- Parameters:
- 
station(string) - Station ID
- 
date(string, optional) - Date to retrieve data for ("today", "latest", "recent", or specific date)
- 
begin_date(string, optional) - Start date (YYYYMMDD or MM/DD/YYYY)
- 
end_date(string, optional) - End date (YYYYMMDD or MM/DD/YYYY)
- 
bin(number, optional) - Bin number
- 
units(string, optional) - Units to use ("english" or "metric")
- 
time_zone(string, optional) - Time zone (gmt, lst, lst_ldt)
- 
format(string, optional) - Output format (json, xml, csv)
 
- 
 
- Parameters:
Current Predictions
- 
get_current_predictions- Get current predictions- Parameters:
- 
station(string) - Station ID
- 
date(string, optional) - Date to retrieve data for ("today", "latest", "recent", or specific date)
- 
begin_date(string, optional) - Start date (YYYYMMDD or MM/DD/YYYY)
- 
end_date(string, optional) - End date (YYYYMMDD or MM/DD/YYYY)
- 
bin(number, optional) - Bin number
- 
interval(string, optional) - Interval (MAX_SLACK or a number for minutes)
- 
vel_type(string, optional) - Velocity type (speed_dir or default)
- 
units(string, optional) - Units to use ("english" or "metric")
- 
time_zone(string, optional) - Time zone (gmt, lst, lst_ldt)
- 
format(string, optional) - Output format (json, xml, csv)
 
- 
 
- Parameters:
Meteorological Data
- 
get_meteorological_data- Get meteorological data- Parameters:
- 
station(string) - Station ID
- 
product(string) - Product (air_temperature, wind, etc.)
- 
date(string, optional) - Date to retrieve data for ("today", "latest", "recent", or specific date)
- 
begin_date(string, optional) - Start date (YYYYMMDD or MM/DD/YYYY)
- 
end_date(string, optional) - End date (YYYYMMDD or MM/DD/YYYY)
- 
units(string, optional) - Units to use ("english" or "metric")
- 
time_zone(string, optional) - Time zone (gmt, lst, lst_ldt)
- 
format(string, optional) - Output format (json, xml, csv)
 
- 
 
- Parameters:
Station Information
- 
get_stations- Get list of stations- Parameters:
- 
type(string, optional) - Station type (waterlevels, currents, etc.)
- 
units(string, optional) - Units to use ("english" or "metric")
- 
format(string, optional) - Output format (json, xml)
 
- 
 
- Parameters:
- 
get_station_details- Get detailed information about a station- Parameters:
- 
station(string) - Station ID
- 
units(string, optional) - Units to use ("english" or "metric")
- 
format(string, optional) - Output format (json, xml)
 
- 
 
- Parameters:
Moon Phase Information
- 
get_moon_phase- Get moon phase information for a specific date- Parameters:
- 
date(string, optional) - Date to get moon phase for (YYYY-MM-DD format). Defaults to current date.
- 
latitude(number, optional) - Latitude for location-specific calculations
- 
longitude(number, optional) - Longitude for location-specific calculations
- 
format(string, optional) - Output format (json or text)
 
- 
 
- Parameters:
- 
get_moon_phases_range- Get moon phase information for a date range- Parameters:
- 
start_date(string) - Start date (YYYY-MM-DD format)
- 
end_date(string) - End date (YYYY-MM-DD format)
- 
latitude(number, optional) - Latitude for location-specific calculations
- 
longitude(number, optional) - Longitude for location-specific calculations
- 
format(string, optional) - Output format (json or text)
 
- 
 
- Parameters:
- 
get_next_moon_phase- Get the next occurrence(s) of a specific moon phase- Parameters:
- 
phase(string) - Moon phase to find (New Moon, First Quarter, Full Moon, Last Quarter)
- 
date(string, optional) - Starting date (YYYY-MM-DD format). Defaults to current date.
- 
count(number, optional) - Number of occurrences to return. Defaults to 1.
- 
format(string, optional) - Output format (json or text)
 
- 
 
- Parameters:
Sun Rise/Set Information
- 
get_sun_times- Get sun rise/set and other sun event times for a specific date and location- Parameters:
- 
date(string, optional) - Date to get sun times for (YYYY-MM-DD format). Defaults to current date.
- 
latitude(number) - Latitude for location-specific calculations
- 
longitude(number) - Longitude for location-specific calculations
- 
format(string, optional) - Output format (json or text)
- 
timezone(string, optional) - Timezone for the results. Defaults to UTC.
 
- 
 
- Parameters:
- 
get_sun_times_range- Get sun rise/set and other sun event times for a date range and location- Parameters:
- 
start_date(string) - Start date (YYYY-MM-DD format)
- 
end_date(string) - End date (YYYY-MM-DD format)
- 
latitude(number) - Latitude for location-specific calculations
- 
longitude(number) - Longitude for location-specific calculations
- 
format(string, optional) - Output format (json or text)
- 
timezone(string, optional) - Timezone for the results. Defaults to UTC.
 
- 
 
- Parameters:
- 
get_sun_position- Get sun position information for a specific date, time, and location- Parameters:
- 
date(string, optional) - Date to get sun position for (YYYY-MM-DD format). Defaults to current date.
- 
time(string, optional) - Time to get sun position for (HH:MM:SS format). Defaults to current time.
- 
latitude(number) - Latitude for location-specific calculations
- 
longitude(number) - Longitude for location-specific calculations
- 
format(string, optional) - Output format (json or text)
 
- 
 
- Parameters:
- 
get_next_sun_event- Get the next occurrence(s) of a specific sun event- Parameters:
- 
event(string) - Sun event to find (sunrise, sunset, dawn, dusk, solarNoon, etc.)
- 
date(string, optional) - Starting date (YYYY-MM-DD format). Defaults to current date.
- 
latitude(number) - Latitude for location-specific calculations
- 
longitude(number) - Longitude for location-specific calculations
- 
count(number, optional) - Number of occurrences to return. Defaults to 1.
- 
format(string, optional) - Output format (json or text)
- 
timezone(string, optional) - Timezone for the results. Defaults to UTC.
 
- 
 
- Parameters:
API Documentation
NOAA Tides and Currents API documentation can be found at:
- CO-OPS Data API: https://api.tidesandcurrents.noaa.gov/api/prod/
- CO-OPS Metadata API: https://api.tidesandcurrents.noaa.gov/mdapi/prod/
- CO-OPS Derived Product API: https://api.tidesandcurrents.noaa.gov/dpapi/prod/
About FastMCP
FastMCP is a TypeScript framework for building MCP servers capable of handling client sessions. It provides:
- Simple Tool, Resource, Prompt definition
- Sessions
- Image content
- Logging
- Error handling
- SSE
- Progress notifications
- Typed server events
- And more
Learn more at: https://github.com/punkpeye/fastmcp
License
MIT
相关推荐
I craft unique cereal names, stories, and ridiculously cute Cereal Baby images.
I find academic articles and books for research and literature reviews.
Evaluator for marketplace product descriptions, checks for relevancy and keyword stuffing.
Confidential guide on numerology and astrology, based of GG33 Public information
Emulating Dr. Jordan B. Peterson's style in providing life advice and insights.
Advanced software engineer GPT that excels through nailing the basics.
Your go-to expert in the Rust ecosystem, specializing in precise code interpretation, up-to-date crate version checking, and in-depth source code analysis. I offer accurate, context-aware insights for all your Rust programming questions.
Converts Figma frames into front-end code for various mobile frameworks.
Descubra la colección más completa y actualizada de servidores MCP en el mercado. Este repositorio sirve como un centro centralizado, que ofrece un extenso catálogo de servidores MCP de código abierto y propietarios, completos con características, enlaces de documentación y colaboradores.
La aplicación AI de escritorio todo en uno y Docker con trapo incorporado, agentes de IA, creador de agentes sin código, compatibilidad de MCP y más.
Manipulación basada en Micrypthon I2C del expansor GPIO de la serie MCP, derivada de AdaFruit_MCP230xx
Plataforma de automatización de flujo de trabajo de código justo con capacidades de IA nativas. Combine el edificio visual con código personalizado, auto-anfitrión o nube, más de 400 integraciones.
🧑🚀 全世界最好的 llM 资料总结(数据处理、模型训练、模型部署、 O1 模型、 MCP 、小语言模型、视觉语言模型) | Resumen de los mejores recursos del mundo.
Espejo dehttps: //github.com/agentience/practices_mcp_server
Una lista curada de servidores de protocolo de contexto del modelo (MCP)
Reviews
 
                                    user_nkpNXALK
NOAA is an outstanding application by RyanCardin15, perfect for weather enthusiasts and professionals alike. It's well-designed and incredibly user-friendly. The GitHub link provides comprehensive information and easy access for installation and updates. Highly recommended for anyone interested in accurate and reliable weather data! Check it out here: https://github.com/RyanCardin15/NOAA
 
     
                                                             
                                                             
                                                             
                                                             
                                                             
                                                             
                                                             
                                                             
                                                            