katjes733/weather-mcp-server
If you are the rightful owner of weather-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
The Weather MCP Server is a project that leverages the Model Context Protocol (MCP) and Bun to provide weather reporting tools using LLMs.
Weather MCP Server
This is a project utilizing the Model Context Protocol (MCP) and Bun to provide a collection of tools for weather reporting with LLMs.
Background
It demonstrates how to set up a basic MCP server that can handle tool requests and execute them. It supports current and future weather forecasts (hourly and daily) given a zip code. Multiple tools work in tandem and the LLM is orchestrating the usage of the tools based on their configuration. This implementation also provides a simple framework to add additional tools in a consolidated and structured way. For more information, see the New Tools section in Development.
Prerequisites
- Bun must be installed.
- Claude Desktop should be installed.
Setup Project
-
Clone the repository.
-
Run:
bun install
-
Create a
.env
file in the root based on/env/sample.env
. Provide values as necessary and described.NOTE: This is mostly relevant if you wish to run the server in development mode via
bun run start
. -
(Optional) Run the following to verify integrity of the project:
bun run verify
Build
-
Run:
bun run build
This will bundle the entry build/main.js
, which can then be consumed.
Setup Claude Desktop
This section is influenced by this general guide with specifics for this use case.
-
Start Claude Desktop and open Settings (not Account setting).
-
Click on
Developer
in the left-hand bar of the Settings pane, and then click onEdit Config
. -
Edit the file
claude_desktop_config.json
and add the following:{ "mcpServers": { "weather-mcp-server": { "command": "bun", "args": ["run", "<path_to_project>/build/main.js"], "env": { "APP_NAME": "weather-mcp-server", "APP_EMAIL": "<app-email>" } } } }
- Replace
<path_to_project>
with the path to your project; e.g.:/Users/username/Documents/projects/create-mcp-server-app-bun
- Replace
<app-email>
with an email that will be used to identify some API requests; e.g.:my@email.com
- Replace
-
Restart Claude Desktop; this is important as Claude Desktop will otherwise not apply changes to
claude_desktop_config.json
. -
On the main screen, click the
Search and Tools
button and then on your MCP server name. Ensure that it is enabled.
Usage
Here are some hints on how to interact with Claude and this MCP Server.
- You may start by simply asking Claude to get the current weather for your zip code: e.g.
current weather for 90210
, which outputs the corresponding result. You may observe that Claude uses multiple tools sequentially, dynamically and independently to provide the desired result. - You may also ask Claude to for the forecast for the any of the next days:
what's the weather this weekend?
. This will trigger a follow-up request (unless there is a previous zip code in the context from a previous question) to provide the desired zip code. Once provided, the response will contain the corresponding result.- Notice how Claude automatically reuses the result from previous tool calls, if applicable, to answer this question.
Development
New Tools
New tools may be added by ensuring each new tool module in ./src/tools
extends AbstractTool
and implements ITool
and provides an explicit constructor (for test coverage):
...
export class NewTool extends AbstractTool implements ITool {
// Explicit constructor definition to ensure test coverage in Bun tracks constructor.
constructor(fetch: typeof globalThis.fetch = globalThis.fetch) {
super(fetch);
}
...
Additionally, the following methods must be implemented (see their corresponding JSDoc
for details.):
getName
getDescription
getInputSchema
validateWithDefaults
processToolWorkflow
Use existing tool(s) as guide for the implementation and don't forget to implement a corresponding test.
There is no further configuration required to register any additional tool; they are automatically included upon restart of the MCP server.
Test Coverage
It may be useful to analyze test coverage gaps using lcov
reports, to gain better visibility into covered lines and functions.
NOTES:
- Constructors for classes should be defined in the respective class, as Bun only tracks a classes functions (including constructors). This is problematic when you inherit from an abstract class with its own constructor, which in turn is not tracked. Thus, simply define the Abstract constructor in the class and call
super
. - Having some imports (e.g.
import dedent from "dedent";
) at the top of a module may cause Bun to not correctly track that line as covered. Simply move it behind other imports, and it will correctly track.
Prerequisites (Development)
-
Install
lcov
:brew install lcov
-
Install VSCode extension
ryanluker.vscode-coverage-gutters
(already defined in ).
Running Test Coverage
-
For most cases, it will suffice to run:
bun run test:coverage
NOTE: If the coverage is less than 100, but no
Uncovered Line #s
are reported, you may need to investigate further by following the next steps and revisiting the Notes above. -
For advanced cases, run:
bun run test:coverage:lcov
It produces the
lcov
that is used by VSCode extensionryanluker.vscode-coverage-gutters
to visualize covered lines in the editor. -
If you prefer to have an HTML report, run in your terminal:
genhtml --function-coverage --branch-coverage --output-directory coverage-report coverage/lcov.info
It produces an HTML that you can inspect in your preferred browser.