nass-mcp-server
This MCP server is a tool for retrieving agricultural production data via the USDA NASS API. It allows users to obtain datasets based on specific commodities, locations, and times, as well as count the number of records. Access to the data can be obtained by requesting an API key.
GitHub Stars
3
User Rating
Not Rated
Favorites
0
Views
32
Forks
0
Issues
2
MCP Server for USDA NASS API
The USDA National Agricultural Statistics Service API, known as Quick Stats, contains survey and census data on United States agricultural production.
NASS API access
Request an API key here.
Tools
get_full_dataset(query: Query) -> str
Get all available data for a given commodity, location, and time.
Arguments:
query(Query): Dictionary with three keys,"commodity","location", and"time", each with a dictionary of parameter and value pairs.
Returns:
str: Full response text as a string
get_db_record_count(query: Query) -> str
Get the number, or count, of database records of a given commodity for a location and time.
Arguments:
query(Query): Dictionary with three keys,"commodity","location", and"time", each with a dictionary of parameter and value pairs.
Returns:
str: String of JSON data with one key,"count", and a value of the number of records.
get_param_values(query: ParameterQuery) -> str
Get all possible values of a query parameter by its name.
Arguments:
parameter(ParameterQuery): Dictionary with one key,"param", and a value of the parameter name to get the values for.
Returns:
str: String of JSON data with the parameter names and all their possible values as a list.
Getting started
I highly recommend using uv for package and virtual environment management.
Docker
The Dockerfile is setup to run the MCP server with default settings. Using make, you can build an image and run a container:
build: build the image fromDockerfilerun: run the MCP server with default settings (e.g.localhost,8000:8000)
The short way
Setup command
If you have make, uv, and are on macOS/Linux, running make setup should be all you need to get started with the project.
The long way
Installation
Activate your virtual environment and:
pip install -r requirements.txt
.env
Copy the .env.example to a .env file. Replace the value of NASS_API_KEY with your NASS API key.
Configuration
There are several configuration options for changing functionality of the MCP server.
The following configurations are available as environment variables:
| Option | Values | Default | Description |
|---|---|---|---|
| NASS_API_KEY | string |
Your NASS API key | |
| NASS_MCP_HOST | string |
0.0.0.0 |
The host to run the MCP server on |
| NASS_MCP_PORT | integer |
8000 |
The port to run the MCP server on |
| NASS_MCP_FORMAT | CSV or JSON or XML |
CSV |
The format to return the data in from the NASS API /api_GET endpoint |
| NASS_ENV | production |
A flag for telling the MCP server to skip local dev steps (e.g. load_dotenv) |
The following configurations are available as command line arguments
| Option | Values | Default | Description |
|---|---|---|---|
-t --transport |
streamable-http or stdio |
streamable-http |
Transport protocol for the MCP server |
The Prospectio MCP API is a FastAPI-based application designed for lead prospecting, implementing the Model Context Protocol (MCP). It adheres to Clean Architecture principles, ensuring a clear separation of concerns across domain, application, and infrastructure layers. The project focuses on core business entities and logic, along with use cases and API routes, facilitating integration with external services.
The mcp-client-for-ollama is a simple yet powerful Python client designed for interacting with Model Context Protocol (MCP) servers using Ollama. This client enables local large language models (LLMs) to utilize tools effectively. It primarily facilitates communication with APIs, streamlining workflows and enhancing the capabilities of LLMs.