Skip to main content
Glama

fcc-broadband-mcp-server

Server Details

FCC broadband availability, coverage analysis, and digital divide data for US geographies.

Status
Healthy
Last Tested
Transport
Streamable HTTP
URL
Repository
cyanheads/fcc-broadband-mcp-server
GitHub Stars
1

Glama MCP Gateway

Connect through Glama MCP Gateway for full control over tool access and complete visibility into every call.

MCP client
Glama
MCP server

Full call logging

Every tool call is logged with complete inputs and outputs, so you can debug issues and audit what your agents are doing.

Tool access control

Enable or disable individual tools per connector, so you decide what your agents can and cannot do.

Managed credentials

Glama handles OAuth flows, token storage, and automatic rotation, so credentials never expire on your clients.

Usage analytics

See which tools your agents call, how often, and when, so you can understand usage patterns and catch anomalies.

100% free. Your data is private.
Tool DescriptionsA

Average 4.4/5 across 9 of 9 tools scored. Lowest: 3.7/5.

Server CoherenceA
Disambiguation5/5

Each tool targets a distinct operation: geocoding, availability search, provider search, provider details, coverage summary, area comparison, underserved area identification, and listing data vintages/files. No two tools overlap in purpose.

Naming Consistency5/5

All tools follow a consistent 'fcc_verb_noun' pattern in snake_case (e.g., fcc_geocode_block, fcc_search_providers). The naming convention is uniform and predictable.

Tool Count5/5

With 9 tools, the server is well-scoped for its domain—covering geocoding, querying, comparison, and data listing without being overwhelming or sparse.

Completeness5/5

The toolset covers the full lifecycle of FCC broadband data interaction: geocode, search availability, search providers, get provider details, coverage summary, compare areas, find underserved, and list data file periods/downloads. No obvious gaps.

Available Tools

9 tools
fcc_compare_areasCompare Broadband Coverage Across AreasA
Read-onlyIdempotent
Inspect

Compares broadband coverage metrics across multiple geographies of the same type and returns a ranked table sorted by unserved or underserved population. Answers "which counties in this state have the worst broadband access?" and drives BEAD funding prioritization. Provide up to 50 geography IDs, or set compare_all_states=true for all 50 states + DC. Data is from FCC Form 477 (as of June 2021).

ParametersJSON Schema
NameRequiredDescriptionDefault
sort_byNo"unserved_pct" = share of population with no broadband (default). "unserved_pop" = raw headcount for BEAD funding. "coverage_pct" = share with any coverage. "competitive_pct" = share with 2+ providers.unserved_pct
speed_downNoDownload speed threshold in Mbps. 25 = FCC legacy standard. 100 = BEAD program standard.25
tech_filterNoTechnology filter. "acfosw" = any wired or fixed wireless. "f" = fiber only. "c" = cable only. "a" = DSL. "s" = satellite. "w" = fixed wireless.acfosw
geography_idsNoArray of FIPS GEOIDs to compare (up to 50). For all 50 states, omit and set compare_all_states=true.
geography_typeYesGeographic level to compare. Must be uniform across all geographies in the comparison.
compare_all_statesNoWhen true, compares all 50 states + DC. Overrides geography_ids. Requires geography_type="state".

Output Schema

ParametersJSON Schema
NameRequiredDescription
areasYesRanked comparison of geographies by the selected sort field.
sortByYesRanking field used.
techFilterYesTechnology filter applied.
totalAreasYesTotal number of areas compared.
dataVintageYesData vintage — Form 477 data as of June 2021.
geographyTypeYesGeography type compared.
speedDownMbpsYesSpeed threshold in Mbps.
Behavior4/5

Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?

Annotations already declare readOnlyHint and idempotentHint, so no side effects. The description adds valuable behavioral details: data source (FCC Form 477, June 2021), output format (ranked table sorted by unserved/underserved), and that compare_all_states overrides geography_ids. This provides good context beyond annotations.

Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.

Conciseness5/5

Is the description appropriately sized, front-loaded, and free of redundancy?

The description is three sentences long, front-loaded with the primary purpose, and includes essential details (data source, limits, use case) without extraneous information. Every sentence serves a purpose.

Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.

Completeness5/5

Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?

Given the tool's complexity (6 parameters, 1 required, 4 enums) and the presence of a complete output schema and annotations, the description covers all critical aspects: use case, data freshness, constraints (max 50 IDs), and a clear example. It is sufficiently complete for an agent to understand when and how to use it.

Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.

Parameters3/5

Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?

Schema coverage is 100%, with detailed descriptions for all 6 parameters including enums and defaults. The description adds contextual value by linking BEAD funding to sorting options, but does not significantly enhance understanding beyond what the schema already provides. Baseline score of 3 is appropriate.

Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.

Purpose5/5

Does the description clearly state what the tool does and how it differs from similar tools?

The description clearly states the tool compares broadband coverage metrics across multiple geographies and returns a ranked table, with example questions like 'which counties in this state have the worst broadband access?' This uniquely distinguishes it from siblings like fcc_find_underserved, which focuses on finding underserved areas rather than comparing.

Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.

Usage Guidelines4/5

Does the description explain when to use this tool, when not to, or what alternatives exist?

The description provides explicit context for when to use the tool: to compare geographies for BEAD funding prioritization, with clear limits (up to 50 IDs or compare_all_states=true). However, it does not mention when not to use it or list alternative tools, leaving some ambiguity for agents.

Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.

fcc_find_underservedFind Underserved AreasA
Read-onlyIdempotent
Inspect

Finds geographic areas with limited or no broadband coverage at a given speed threshold, ranked by unserved population. The core tool for BEAD program analysis and broadband equity research. Accepts a state abbreviation to narrow scope or runs nationwide. Defaults to rural areas where underservice is most concentrated. Data is from FCC Form 477 (as of June 2021).

ParametersJSON Schema
NameRequiredDescriptionDefault
limitNoMaximum number of areas to return, ranked by unserved population (descending).
stateNo2-letter state code (e.g., "WY", "MS") to limit scope. Omit for nationwide search — returns top areas only.
speed_downNoDownload speed threshold in Mbps for defining "underserved." 25 = FCC legacy standard. 100 = BEAD program standard.25
tech_filterNoTechnology filter. "acfosw" = any wired or fixed wireless. "f" = fiber only. "c" = cable only.acfosw
geography_typeNoGeographic granularity for results. "county" is most useful for policy analysis and BEAD eligibility. "cd" = congressional district. "place" = census-designated place. "cbsa" = metro area.county
min_unserved_popNoMinimum population with no coverage to include. Use to filter out very small areas (e.g., 500 filters areas with fewer than 500 unserved residents).
urban_rural_filterNoDefaults to rural ("R") — where underservice is most concentrated. Use "U" to find underserved urban areas (digital redlining research). Set to "all" for both.R

Output Schema

ParametersJSON Schema
NameRequiredDescription
areasYesRanked list of underserved areas.
noticeNoRecovery hint when no areas are found.
totalFoundYesTotal number of areas found before applying the limit filter.
dataVintageYesData vintage — Form 477 data as of June 2021.
geographyTypeYesGeography type returned.
speedDownMbpsYesSpeed threshold used in Mbps.
urbanRuralFilterYesUrban/rural filter applied.
Behavior3/5

Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?

Annotations already declare readOnlyHint and idempotentHint true. The description adds data source (FCC Form 477 as of June 2021) and default behavior, which is helpful but not extensive behavioral detail.

Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.

Conciseness5/5

Is the description appropriately sized, front-loaded, and free of redundancy?

Two concise sentences, front-loaded with purpose, no wasted words. Every sentence adds value.

Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.

Completeness5/5

Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?

With 100% schema coverage and an output schema, the description adds overarching purpose and data freshness. No gaps for effective use.

Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.

Parameters3/5

Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?

Schema coverage is 100%, so baseline is 3. The description reiterates state and urban_rural defaults already in schema, adding no new parameter-specific insight beyond what the schema provides.

Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.

Purpose4/5

Does the description clearly state what the tool does and how it differs from similar tools?

The description clearly states the tool finds underserved areas at a speed threshold, ranked by unserved population, and identifies it as core for BEAD analysis. It does not explicitly differentiate from sibling tools, but the purpose is unambiguous.

Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.

Usage Guidelines3/5

Does the description explain when to use this tool, when not to, or what alternatives exist?

The description mentions BEAD program analysis and equity research, and notes options for state or nationwide scope and rural default, but does not provide when-not-to-use or alternative tool recommendations against siblings.

Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.

fcc_geocode_blockGeocode Census BlockA
Read-onlyIdempotent
Inspect

Converts a latitude/longitude coordinate to a 15-digit census block FIPS code, plus county FIPS, county name, state FIPS, state code, and state name. This is the required prerequisite for fcc_search_availability since the broadband dataset is indexed by census block, not address. Uses the FCC public Geo API — no authentication required.

ParametersJSON Schema
NameRequiredDescriptionDefault
latitudeYesLatitude of the location in decimal degrees (e.g., 47.6062 for Seattle, WA). Must be within the continental US, Alaska, Hawaii, or US territories.
longitudeYesLongitude of the location in decimal degrees (e.g., -122.3321 for Seattle, WA). Negative for western hemisphere.

Output Schema

ParametersJSON Schema
NameRequiredDescription
blockFipsYes15-digit census block FIPS code (e.g., "530330081021016"). Pass this to fcc_search_availability to look up broadband providers.
stateCodeYes2-letter state abbreviation (e.g., "WA").
stateFipsYes2-digit state FIPS code (e.g., "53" for Washington).
stateNameYesFull state name (e.g., "Washington").
countyFipsYes5-digit county FIPS code (e.g., "53033" for King County, WA).
countyNameYesHuman-readable county name (e.g., "King").
Behavior4/5

Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?

Annotations already provide readOnlyHint, openWorldHint, and idempotentHint. The description adds context about using the FCC public Geo API with no authentication, which is consistent and helpful. No contradictions.

Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.

Conciseness5/5

Is the description appropriately sized, front-loaded, and free of redundancy?

Two sentences that are concise and front-loaded. The first sentence states the core functionality and outputs; the second provides critical usage context. Every word earns its place.

Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.

Completeness5/5

Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?

Given the existence of an output schema and high schema description coverage, the description is complete. It covers prerequisites, the API used, and authentication requirements, leaving no significant gaps for an agent to misinterpret.

Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.

Parameters3/5

Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?

Schema coverage is 100% with detailed descriptions for latitude and longitude (including ranges and sign conventions). The description doesn't add new parameter information beyond what the schema provides, so a baseline score of 3 is appropriate.

Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.

Purpose5/5

Does the description clearly state what the tool does and how it differs from similar tools?

The description clearly states the tool converts lat/lng to a 15-digit census block FIPS code plus other geographic identifiers. It uses a specific verb ('converts') and resource ('coordinate to census block'), and distinguishes itself from sibling tools by noting it's a prerequisite for fcc_search_availability.

Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.

Usage Guidelines4/5

Does the description explain when to use this tool, when not to, or what alternatives exist?

Explicitly states it is 'the required prerequisite for fcc_search_availability' and mentions 'no authentication required,' providing clear guidance on when to use it. However, it doesn't explicitly state when not to use it or mention alternatives.

Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.

fcc_get_coverage_summaryGet Broadband Coverage SummaryA
Read-onlyIdempotent
Inspect

Returns a broadband coverage summary for a geography — population with zero, one, two, or three-plus providers at a given speed threshold, split by urban/rural and tribal/non-tribal segments. The primary tool for digital divide and equity analysis. Supports state, county, congressional district, census place, CBSA (metro area), tribal area, and national level. Data is from FCC Form 477 (as of June 2021). Use 100 Mbps as the speed threshold for BEAD program policy analysis.

ParametersJSON Schema
NameRequiredDescriptionDefault
speed_downNoMinimum download speed threshold in Mbps. 25 = FCC legacy broadband definition. 100 = BEAD program standard (use this for current policy analysis). "0.2" = any service above 200 Kbps.25
tech_filterNoTechnology filter. "acfosw" = any wired or fixed wireless (recommended baseline). "f" = fiber only. "c" = cable only. "a" = ADSL/DSL only. "s" = satellite only. "w" = fixed wireless only. Mix letters for combinations, e.g., "fc" = fiber or cable.acfosw
geography_idNoFIPS GEOID for the geography. State: 2-digit (e.g., "06" for California). County: 5-digit (e.g., "06037" for LA County). Congressional district: 4-digit state+district (e.g., "0601"). CBSA: 5-digit code. Omit for nation-level queries.
tribal_filterNoFilter to tribal ("T") or non-tribal ("N") areas. Use "T" to assess Native American connectivity gaps.all
geography_typeYesGeographic aggregation level. "nation" = US-wide totals (geography_id not needed). "cd" = congressional district. "place" = census-designated place. "cbsa" = core-based statistical area (metro area). "tribal" = tribal land area.
urban_rural_filterNoFilter to urban ("U") or rural ("R") areas only, or "all" for both combined. Rural breakdown is key for BEAD program analysis.all

Output Schema

ParametersJSON Schema
NameRequiredDescription
breakdownYesPer-segment breakdown by urban/rural and tribal/non-tribal.
geographyYesThe queried geography.
populationYesPopulation counts by provider availability tier.
techFilterYesTechnology filter applied.
coveragePctYesPercentage of population with at least one provider at the given speed.
dataVintageYesData vintage — Form 477 data as of June 2021.
unservedPctYesPercentage with zero providers — FCC "unserved" definition.
speedDownMbpsYesDownload speed threshold used in Mbps.
competitivePctYesPercentage with two or more providers.
Behavior4/5

Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?

Annotations already declare readOnlyHint=true and idempotentHint=true. The description adds valuable behavioral context: data source (FCC Form 477, June 2021) and a specific usage recommendation. No destructive behavior indicated, consistent with annotations.

Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.

Conciseness5/5

Is the description appropriately sized, front-loaded, and free of redundancy?

The description is four sentences, front-loaded with the core purpose, then adds use case, supported geographies, data source, and a specific threshold recommendation. Every sentence adds value with no fluff.

Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.

Completeness5/5

Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?

Given the comprehensive schema (6 params with descriptions), annotations, and existence of an output schema, the description covers all needed context: purpose, geographies, data source, and policy relevance. No gaps remain for an agent to invoke the tool correctly.

Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.

Parameters3/5

Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?

Schema description coverage is 100%, so the schema already provides full parameter documentation. The description does not add additional meaning beyond what the schema offers, making a baseline score of 3 appropriate.

Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.

Purpose5/5

Does the description clearly state what the tool does and how it differs from similar tools?

The description states it 'returns a broadband coverage summary' with specific breakdowns (provider counts, urban/rural, tribal/non-tribal). It identifies itself as 'the primary tool for digital divide and equity analysis,' clearly distinguishing it from siblings like fcc_compare_areas or fcc_find_underserved.

Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.

Usage Guidelines4/5

Does the description explain when to use this tool, when not to, or what alternatives exist?

The description provides clear usage context: it's the primary tool for digital divide analysis and recommends using 100 Mbps for BEAD policy analysis. However, it does not explicitly state when not to use it or contrast with alternative tools.

Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.

fcc_get_providerGet Provider ProfileA
Read-onlyIdempotent
Inspect

Returns a national-level coverage profile for a specific holding company (by hoconum): states served, technologies deployed, and the number of locations covered at each download speed tier. Use fcc_search_providers to find valid hoconum values. Data is from FCC Form 477 (as of June 2021).

ParametersJSON Schema
NameRequiredDescriptionDefault
hoconumYesHolding company number from fcc_search_providers (e.g., "130152" for Comcast). Required identifier for the provider.

Output Schema

ParametersJSON Schema
NameRequiredDescription
hoconumYesHolding company number.
techCodesYesTechnology codes this provider deploys nationally.
techLabelsYesHuman-readable technology descriptions.
dataVintageYesData vintage — Form 477 data as of June 2021.
holdingCompanyNameYesHolding company name.
speedTierLocationsYesDownload speed tier location counts (national totals).
Behavior4/5

Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?

Annotations already declare readOnlyHint=true, idempotentHint=true, and openWorldHint=false, indicating safe, idempotent read operations. The description adds valuable context beyond annotations by noting the data source (FCC Form 477 as of June 2021), which helps an agent understand data freshness. No contradictions.

Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.

Conciseness5/5

Is the description appropriately sized, front-loaded, and free of redundancy?

The description is three sentences, front-loaded with the tool's purpose, followed by usage guidance and data source. Every sentence adds value without any redundancy or fluff.

Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.

Completeness5/5

Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?

For a tool with one required parameter and an existing output schema (indicated by context signals), the description fully covers purpose, parameter retrieval, and data provenance. It is self-contained and eliminates ambiguity for an AI agent.

Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.

Parameters4/5

Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?

Schema coverage is 100% and already describes the hoconum parameter, but the description adds semantic meaning by explaining it as a holding company number from fcc_search_providers and giving an example ('130152' for Comcast), providing further guidance beyond the schema.

Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.

Purpose5/5

Does the description clearly state what the tool does and how it differs from similar tools?

The description clearly states the tool returns a national-level coverage profile for a specific holding company, detailing states, technologies, and location counts per speed tier. It distinguishes itself from the sibling tool fcc_search_providers by directing users to that tool for finding valid hoconum values.

Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.

Usage Guidelines5/5

Does the description explain when to use this tool, when not to, or what alternatives exist?

The description explicitly says when to use this tool (to get a provider profile) and provides guidance on how to obtain the required hoconum parameter via fcc_search_providers, offering clear context and an alternative.

Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.

fcc_list_downloadsList BDC DownloadsA
Read-onlyIdempotent
Inspect

Lists downloadable BDC data files for a specific as-of date — fixed availability by state and provider, mobile coverage, and challenge data — with file metadata (provider, state, technology, record count). Download URLs are included for each file. Requires FCC BDC API credentials (FCC_BDC_USERNAME and FCC_BDC_HASH_VALUE). Use fcc_list_filing_periods first to determine valid as_of_date values (BDC dates start June 2022).

ParametersJSON Schema
NameRequiredDescriptionDefault
stateNoFilter to one state's files (2-letter abbreviation, e.g., "WA").
categoryNoFile category. "State" = per-state coverage files. "Provider" = per-provider files. "Summary" = aggregate coverage tables.
data_typeNo"availability" = ISP-reported coverage files (by state and provider). "challenge" = consumer and government dispute records.availability
as_of_dateYesBDC as-of date in YYYY-MM-DD format (e.g., "2024-06-30"). Get valid dates from fcc_list_filing_periods with include_bdc=true.
provider_nameNoPartial provider holding company name to filter results (case-insensitive).
technology_typeNoFilter to a specific technology type of coverage data.

Output Schema

ParametersJSON Schema
NameRequiredDescription
filesYesDownloadable BDC files matching the filters.
asOfDateYesThe queried as-of date.
dataTypeYesData type queried (availability or challenge).
totalFilesYesTotal number of files returned after filtering.
Behavior4/5

Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?

Annotations already mark the tool as readOnly and idempotent. The description adds that download URLs are included and that credentials are required, providing useful behavioral context beyond the annotations.

Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.

Conciseness5/5

Is the description appropriately sized, front-loaded, and free of redundancy?

The description is concise with two sentences. The first sentence clearly states the purpose and content, and the second adds essential usage guidance. No unnecessary words.

Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.

Completeness4/5

Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?

Given the output schema exists (not shown but noted), the description sufficiently covers what the tool does, prerequisites, and constraints. It mentions dependency on another tool and required credentials, making it complete for an agent.

Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.

Parameters4/5

Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?

Schema description coverage is 100%, so baseline is 3. The description adds value by explaining the tool's content (e.g., 'fixed availability by state and provider, mobile coverage, and challenge data') and noting file metadata (provider, state, technology, record count), which complements the schema definitions.

Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.

Purpose5/5

Does the description clearly state what the tool does and how it differs from similar tools?

The description clearly states the tool 'Lists downloadable BDC data files for a specific as-of date' and specifies the types of data (by state and provider, mobile coverage, challenge data) and included metadata (provider, state, technology, record count). It distinguishes itself from sibling tools like fcc_compare_areas or fcc_search_availability by being focused on listing downloads.

Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.

Usage Guidelines4/5

Does the description explain when to use this tool, when not to, or what alternatives exist?

The description explicitly advises to use fcc_list_filing_periods first to determine valid as_of_date values, and mentions required credentials (FCC_BDC_USERNAME and FCC_BDC_HASH_VALUE). It does not explicitly state when not to use the tool, but the context is clear.

Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.

fcc_list_filing_periodsList Filing PeriodsA
Read-onlyIdempotent
Inspect

Returns available data vintages: Form 477 filing periods (hardcoded Jun 2015 – Jun 2021, always available) and BDC as-of dates from the authenticated API (Jun 2022 onward, requires credentials). Call this before fcc_list_downloads to determine valid as_of_date values. Note: there is a data gap between June 2021 (last Form 477) and June 2022 (first BDC filing period).

ParametersJSON Schema
NameRequiredDescriptionDefault
include_bdcNoWhen true, also fetches BDC as-of dates from the authenticated API (requires FCC_BDC_USERNAME and FCC_BDC_HASH_VALUE). When false (default), returns only hardcoded Form 477 periods.

Output Schema

ParametersJSON Schema
NameRequiredDescription
periodsYesAvailable filing periods sorted newest first.
bdcCountYesNumber of BDC periods returned (0 when credentials not configured or include_bdc=false).
dataNoteYesNote on data availability and the Form 477 vs. BDC gap.
form477CountYesNumber of Form 477 periods returned (always available).
hasBdcCredentialsYesWhether BDC API credentials are configured in this deployment.
Behavior5/5

Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?

The description adds behavioral context beyond annotations: Form 477 periods are hardcoded and always available, BDC requires authenticated API credentials, and there is a data gap. These details are consistent with readOnlyHint and idempotentHint.

Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.

Conciseness5/5

Is the description appropriately sized, front-loaded, and free of redundancy?

The description is concise (three sentences), front-loaded with the main purpose, and each sentence adds necessary information without redundancy.

Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.

Completeness5/5

Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?

Given the tool has an output schema, the description appropriately covers purpose, usage order, data gap, and credential requirements. It is complete for a list tool with one parameter.

Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.

Parameters4/5

Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?

The schema covers all parameters, but the description adds value by explaining that include_bdc=true triggers API authentication and returns BDC dates, while false returns only hardcoded Form 477 periods. This clarifies the parameter's effect beyond the schema.

Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.

Purpose5/5

Does the description clearly state what the tool does and how it differs from similar tools?

The description clearly states the tool returns available data vintages for Form 477 and BDC filing periods, specifies the action (list), and distinguishes from sibling tool fcc_list_downloads by noting it should be called first to determine valid as_of_date values.

Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.

Usage Guidelines4/5

Does the description explain when to use this tool, when not to, or what alternatives exist?

The description explicitly advises calling this before fcc_list_downloads, explains the two data sources and the data gap, and notes credential requirements for BDC. It lacks an explicit statement of when not to use, but the context is clear.

Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.

fcc_search_availabilitySearch Broadband AvailabilityA
Read-onlyIdempotent
Inspect

Queries broadband providers and advertised speeds at a census block from FCC Form 477 data (as of June 2021). Answers "which ISPs serve this location and what speeds do they offer?" — the core tool for address-level broadband lookup. Requires a 15-digit census block FIPS code; use fcc_geocode_block to convert coordinates first. Data reflects ISP-reported availability at the block level, which may overstate actual coverage for some addresses.

ParametersJSON Schema
NameRequiredDescriptionDefault
consumerNoFilter to consumer service (true) or business service (false). Omit to return both consumer and business offerings.
block_fipsYes15-digit census block FIPS code (e.g., "530330081021016"). Obtain from fcc_geocode_block using address coordinates.
tech_filterNoTechnology codes to filter. 50=Fiber to premises, 40–43=Cable modem, 10–12=DSL variants, 60=Satellite, 70=Fixed wireless. Omit to return all technologies.
min_speed_downNoMinimum advertised download speed in Mbps to include in results. Omit to return all providers regardless of speed.

Output Schema

ParametersJSON Schema
NameRequiredDescription
blockFipsYesThe queried census block FIPS code.
providersYesISP offerings reported for this census block.
dataVintageYesData vintage — all Form 477 data on FCC Open Data is as of June 2021. For newer BDC data, use fcc_list_downloads.
totalProvidersYesTotal number of distinct holding companies offering service at this block.
Behavior5/5

Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?

Beyond annotations (readOnlyHint, idempotentHint), the description adds that data is from June 2021, ISP-reported at the block level, and may overstate actual coverage. No contradiction with annotations.

Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.

Conciseness5/5

Is the description appropriately sized, front-loaded, and free of redundancy?

Three sentences with no redundancy. The first sentence immediately states the tool's function, the second frames the use case, and the third provides critical context and prerequisites. Every sentence adds value.

Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.

Completeness5/5

Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?

Given the complexity (4 parameters, output schema exists), the description covers the purpose, prerequisite, data source and limitation, and parameter meanings. It does not need to explain return values because the output schema handles that.

Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.

Parameters4/5

Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?

Schema coverage is 100%, but the description adds meaningful context: it explains the consumer/business filter, tech code mapping (e.g., 50=Fiber), and the purpose of min_speed_down. This enriches understanding beyond the schema's descriptions.

Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.

Purpose5/5

Does the description clearly state what the tool does and how it differs from similar tools?

The description states it queries broadband providers and advertised speeds at a census block, with a clear question it answers ('which ISPs serve this location?'). It distinguishes itself from sibling tools like fcc_geocode_block (a prerequisite) and implies it is the core tool for address-level lookup.

Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.

Usage Guidelines4/5

Does the description explain when to use this tool, when not to, or what alternatives exist?

The description explicitly says when to use (address-level broadband lookup) and names a prerequisite tool (fcc_geocode_block). It doesn't list alternatives among siblings, but the context of sibling tool names and the specific use case provide enough guidance. The data caveat also helps set expectations.

Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.

fcc_search_providersSearch Broadband ProvidersA
Read-onlyIdempotent
Inspect

Searches for ISPs by holding company name, filtered by state and technology type. Returns a deduplicated list of matching providers with hoconum identifiers for follow-up calls to fcc_get_provider. Answers "which ISPs serve Washington with fiber?" and "find all Comcast entities." Geographic filtering is state-level; sub-state granularity requires cross-referencing block data. Data is from FCC Form 477 (as of June 2021).

ParametersJSON Schema
NameRequiredDescriptionDefault
limitNoMaximum number of distinct providers to return.
stateNo2-letter state abbreviation (e.g., "WA") to limit results to providers serving that state.
name_searchNoPartial holding company name to search (case-insensitive). e.g., "Comcast", "T-Mobile", "Frontier". Omit to list all providers in a state.
tech_filterNoTechnology codes to filter. 50=Fiber, 40–43=Cable, 10–12=DSL, 60=Satellite, 70=Fixed wireless. Omit for all technologies.

Output Schema

ParametersJSON Schema
NameRequiredDescription
noticeNoRecovery hint when results are empty — suggests how to broaden the search.
providersYesMatching providers, deduplicated by holding company.
totalFoundYesNumber of distinct providers returned.
dataVintageYesData vintage — Form 477 data as of June 2021.
Behavior5/5

Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?

Annotations declare readOnly and idempotent. Description adds that results are deduplicated, include identifiers, and data is from June 2021. No contradictions.

Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.

Conciseness5/5

Is the description appropriately sized, front-loaded, and free of redundancy?

Four sentences, front-loaded with core function, examples second, limitations third. No fluff.

Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.

Completeness5/5

Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?

For a search tool with 4 params and output schema, it covers purpose, parameters, return format, limitations, and data source. Adequate for agent selection and invocation.

Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.

Parameters4/5

Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?

Schema coverage is 100% so baseline 3. Description adds examples for name_search, maps tech_filter codes to technology types, and explains limit max. Provides extra context beyond schema.

Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.

Purpose5/5

Does the description clearly state what the tool does and how it differs from similar tools?

The description clearly states the action ('searches for ISPs'), the resource ('by holding company name'), and what it returns (deduplicated list with hoconum identifiers). It distinguishes from siblings by specifying follow-up with fcc_get_provider and gives example queries.

Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.

Usage Guidelines5/5

Does the description explain when to use this tool, when not to, or what alternatives exist?

It provides explicit example questions, explains when to use (search by name/state/tech), and notes limitations (state-level only, need block data for sub-state). It also mentions the data source and date, aiding in deciding currentness.

Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.

Discussions

No comments yet. Be the first to start the discussion!

Try in Browser

Your Connectors

Sign in to create a connector for this server.