noaa-tidesandcurrents-mcp
This is an MCP (Model Context Protocol) server that provides tools for interacting with the NOAA Tides and Currents API.
RyanCardin15
Tools
get_water_levels
Get water level data for a station
get_tide_predictions
Get tide prediction data
get_currents
Get currents data for a station
get_current_predictions
Get current predictions
get_meteorological_data
Get meteorological data
get_stations
Get list of stations
get_station_details
Get detailed information about a station
README
<a href="https://glama.ai/mcp/servers/ro2rz2c734"> <img width="380" height="200" src="https://glama.ai/mcp/servers/ro2rz2c734/badge" />
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 IDdate(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 fordatum(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 IDbegin_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 IDdate(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 numberunits(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 IDdate(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 numberinterval(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 IDproduct(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 IDunits(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 calculationslongitude(number, optional) - Longitude for location-specific calculationsformat(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 calculationslongitude(number, optional) - Longitude for location-specific calculationsformat(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 calculationslongitude(number) - Longitude for location-specific calculationsformat(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 calculationslongitude(number) - Longitude for location-specific calculationsformat(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 calculationslongitude(number) - Longitude for location-specific calculationsformat(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 calculationslongitude(number) - Longitude for location-specific calculationscount(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
Recommended Servers
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.
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.
Apple MCP Server
Enables interaction with Apple apps like Messages, Notes, and Contacts through the MCP protocol to send messages, search, and open app content using natural language.
Playwright MCP Server
Provides a server utilizing Model Context Protocol to enable human-like browser automation with Playwright, allowing control over browser actions such as navigation, element interaction, and scrolling.
dbt Semantic Layer MCP Server
A server that enables querying the dbt Semantic Layer through natural language conversations with Claude Desktop and other AI assistants, allowing users to discover metrics, create queries, analyze data, and visualize results.
mixpanel
Connect to your Mixpanel data. Query events, retention, and funnel data from Mixpanel analytics.
Sequential Thinking MCP Server
This server facilitates structured problem-solving by breaking down complex issues into sequential steps, supporting revisions, and enabling multiple solution paths through full MCP integration.
mcp-pinterest
A Pinterest Model Context Protocol (MCP) server for image search and information retrieval
MCP Server Trello
Facilitates interaction with Trello boards via the Trello API, offering features like rate limiting, type safety, input validation, and error handling for seamless management of cards, lists, and board activities.
MCP PubMed Search
Server to search PubMed (PubMed is a free, online database that allows users to search for biomedical and life sciences literature). I have created on a day MCP came out but was on vacation, I saw someone post similar server in your DB, but figured to post mine.