finn-tannlege
Server Details
Norwegian dental clinic directory (A2A marketplace). Search ~6,900 clinics by county, specialty, Helfo agreement and emergency availability. 5 tools: tannlege_search, tannlege_info, tannlege_stats, tannlege_akutt, tannlege_kjeder.
- Status
- Healthy
- Last Tested
- Transport
- Streamable HTTP
- URL
Glama MCP Gateway
Connect through Glama MCP Gateway for full control over tool access and complete visibility into every call.
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.
Tool Definition Quality
Average 4.2/5 across 5 of 5 tools scored.
Each tool has a distinct purpose: emergency lookup, profile retrieval, chain listing, directory search, and statistics. No overlap or ambiguity.
All tools share the 'tannlege_' prefix, creating a consistent pattern. The suffixes vary (noun, adjective, verb) but are predictable and clear.
Five tools cover the core functionalities of a dental clinic directory without being excessive or insufficient.
The set covers search, detailed profile, emergency info, chain overview, and statistics — comprehensive for a read-only directory.
Available Tools
5 toolstannlege_akuttFind emergency-duty dental clinics in NorwayARead-onlyIdempotentInspect
Find Norwegian dental clinics that offer emergency-duty (akuttvakt) — i.e. treatment outside normal working hours. Optionally filter by county (fylke). Also returns advice about the municipal dental emergency service (kommunal tannlegevakt). Example: 'finn akutt tannlege i Oslo'.
| Name | Required | Description | Default |
|---|---|---|---|
| fylke | No | Limit to clinics in this county. Examples: 'Oslo', 'Vestland' |
Tool Definition Quality
Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?
Annotations already indicate readOnlyHint=true, idempotentHint=true, and destructiveHint=false, so the tool is safe and read-only. The description adds that it returns advice about the municipal dental emergency service, but does not disclose further behavioral traits beyond what annotations provide.
Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.
Is the description appropriately sized, front-loaded, and free of redundancy?
The description is concise, with two sentences and an example, front-loading key information. No wasted words.
Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.
Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?
Given the simple tool with one optional parameter, no output schema, and comprehensive annotations, the description fully covers what the tool does and how to use it, including the extra advice it returns.
Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.
Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?
Schema description coverage is 100%, so the description adds minimal value. It mentions 'optionally filter by county' and provides an example, but the schema already includes a detailed description with examples.
Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.
Does the description clearly state what the tool does and how it differs from similar tools?
The description clearly states the tool finds Norwegian dental clinics offering emergency-duty (akuttvakt) outside normal hours, with an optional county filter. It distinguishes from sibling tools like tannlege_info or tannlege_search by focusing specifically on emergency duty.
Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.
Does the description explain when to use this tool, when not to, or what alternatives exist?
The description explains when to use the tool (to find emergency dental clinics) and mentions optional county filtering. It does not explicitly list alternatives or when not to use, but the context and sibling tool names make the appropriate usage clear.
Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.
tannlege_infoGet full details for a dental clinicARead-onlyIdempotentInspect
Fetch complete profile for a single Norwegian dental clinic by organisation number (org_nr) or internal UUID. Returns name, address, phone, website, Helfo status, emergency duty, specialities, chain affiliation, specialists list, treatments, opening hours, payment options, and profile URL. Example: org_nr '912345678' or id 'uuid-here'.
| Name | Required | Description | Default |
|---|---|---|---|
| id | No | Clinic UUID (alternative to org_nr) | |
| org_nr | No | 9-digit Norwegian organisation number. Example: '912345678' |
Tool Definition Quality
Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?
Annotations already declare readOnlyHint, idempotentHint, and no destruction. The description adds context by listing the returned fields (e.g., name, address, Helfo status) but does not disclose additional behavioral traits like authentication or error handling. Given good annotation coverage, this is acceptable.
Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.
Is the description appropriately sized, front-loaded, and free of redundancy?
The description is two sentences: the first states purpose and input, the second enumerates output fields. It is concise, front-loaded, and avoids unnecessary words.
Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.
Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?
With no output schema, the description thoroughly enumerates the return fields (name, address, phone, etc.). It covers input options, output contents, and provides an example, making it complete for this tool's complexity.
Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.
Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?
Both parameters are fully described in the schema (100% coverage). The description provides examples ('org_nr '912345678' or id 'uuid-here''), adding slight value but not exceeding the baseline for high-coverage schemas.
Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.
Does the description clearly state what the tool does and how it differs from similar tools?
The description clearly states the tool fetches a complete profile for a single Norwegian dental clinic by organisation number or UUID. It distinguishes itself from sibling tools (e.g., search, emergency, chains) by focusing on a single entity's full detail retrieval.
Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.
Does the description explain when to use this tool, when not to, or what alternatives exist?
While the description implicitly indicates when to use this tool (when you have an identifier and need full details), it does not explicitly compare to sibling tools or state when not to use it. Usage guidance is adequate but not standout.
Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.
tannlege_kjederList Norwegian dental chainsARead-onlyIdempotentInspect
List all Norwegian dental chains (kjeder) registered on finn-tannlege.com, including the number of clinic locations per chain. Examples of chains: 'Tannhelse Øst', 'Colosseum Tannlege', 'Nordic Dental'. Example question: 'hvilke tannlegekjeder finnes i Norge?'.
| Name | Required | Description | Default |
|---|---|---|---|
No parameters | |||
Tool Definition Quality
Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?
Annotations already indicate read-only and idempotent behavior; description adds that it returns count of locations, complementing without contradiction.
Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.
Is the description appropriately sized, front-loaded, and free of redundancy?
Two sentences plus examples, front-loaded with purpose, no wasted words.
Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.
Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?
For a zero-parameter list tool with good annotations, the description fully explains what is returned (chains and counts) with examples, making it complete.
Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.
Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?
No parameters exist; description does not need to compensate, but schema coverage is 100% by default.
Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.
Does the description clearly state what the tool does and how it differs from similar tools?
The description clearly states the tool lists all Norwegian dental chains with clinic location counts, provides examples, and distinguishes from siblings like search or stats.
Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.
Does the description explain when to use this tool, when not to, or what alternatives exist?
The description implies usage for listing chains but does not explicitly state when not to use it or provide alternatives, though siblings are listed in context.
Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.
tannlege_searchSearch Norwegian dental clinicsARead-onlyIdempotentInspect
Search the finn-tannlege.com directory of Norwegian dental clinics. Supports free-text search, county (fylke) filter, specialty filter, Helfo direct-billing filter, and emergency-duty (akuttvakt) filter. Returns clinic name, address, contact info, Helfo status, and profile URL. Example: 'finn kjeveortoped i Bergen med Helfo-avtale'.
| Name | Required | Description | Default |
|---|---|---|---|
| akutt | No | If true, only return clinics with emergency-duty (akuttvakt) | |
| fylke | No | Norwegian county (fylke). Examples: 'Oslo', 'Vestland', 'Rogaland' | |
| helfo | No | If true, only return clinics with Helfo direct-billing agreement | |
| limit | No | Max results (default 10, max 25) | |
| query | No | Free-text search (name or city). Examples: 'Oslo tannklinikk', 'kjeveortoped Bergen' | |
| spesialitet | No | Specialty slug. Examples: 'kjeveortopedi', 'endodonti', 'periodonti' |
Tool Definition Quality
Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?
Annotations already cover safety (read-only, idempotent). The description adds that it returns specific fields (name, address, etc.) and supports multiple filters. It does not detail pagination or sorting, but the core behavior is clear.
Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.
Is the description appropriately sized, front-loaded, and free of redundancy?
Three sentences: purpose, features, output + example. No fluff, information dense and front-loaded. Every sentence adds value.
Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.
Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?
With no output schema, the description explains return fields. It covers all filters and gives an example. Could mention default ordering or result set limits (already in schema), but overall adequate for a search tool.
Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.
Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?
Schema coverage is 100%, so each parameter has a description. The tool description summarizes filters and shows an example, but does not add new per-parameter meaning beyond the schema. Baseline of 3 is appropriate.
Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.
Does the description clearly state what the tool does and how it differs from similar tools?
The description clearly states the tool searches a specific directory of Norwegian dental clinics, listing supported filters and return fields. It distinguishes from sibling tools (e.g., emergency, info, chains, stats) by focusing on multi-attribute search.
Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.
Does the description explain when to use this tool, when not to, or what alternatives exist?
The description implies use for searching clinics by various filters but does not explicitly compare to sibling tools or provide when-to-use/not guidance. The example hints at typical usage, but no direct alternatives are mentioned.
Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.
tannlege_statsNorwegian dental market statisticsARead-onlyIdempotentInspect
Fetch aggregated statistics for the Norwegian dental market from finn-tannlege.com. Returns total clinic count, per-county breakdown (per fylke), Helfo count, chain-member count, emergency-duty (akuttvakt) count, and specialist-clinic count. Example question: 'how many dental clinics are there in Norway?'.
| Name | Required | Description | Default |
|---|---|---|---|
No parameters | |||
Tool Definition Quality
Does the description disclose side effects, auth requirements, rate limits, or destructive behavior?
Annotations already indicate readOnlyHint=true, destructiveHint=false, and idempotentHint=true. The description adds value by specifying the exact counts returned and the data source, which goes beyond the annotations' safety profile.
Agents need to know what a tool does to the world before calling it. Descriptions should go beyond structured annotations to explain consequences.
Is the description appropriately sized, front-loaded, and free of redundancy?
The description is concise: two sentences plus an example question. It front-loads the main action ('Fetch aggregated statistics') and includes all necessary details without extra fluff.
Shorter descriptions cost fewer tokens and are easier for agents to parse. Every sentence should earn its place.
Given the tool's complexity, does the description cover enough for an agent to succeed on first attempt?
Despite having no output schema, the description lists all return fields (total clinic count, per-county breakdown, Helfo count, etc.), providing complete context. The tool is simple and the description fully covers its behavior.
Complex tools with many parameters or behaviors need more documentation. Simple tools need less. This dimension scales expectations accordingly.
Does the description clarify parameter syntax, constraints, interactions, or defaults beyond what the schema provides?
There are no parameters in the input schema, and schema description coverage is 100%. The description does not need to add parameter details. Baseline 4 for zero parameters is appropriate.
Input schemas describe structure but not intent. Descriptions should explain non-obvious parameter relationships and valid value ranges.
Does the description clearly state what the tool does and how it differs from similar tools?
The description clearly states the tool fetches aggregated statistics for the Norwegian dental market, lists specific data points returned (total clinic count, per-county breakdown, etc.), and provides an example question. It distinguishes itself from siblings like tannlege_akutt or tannlege_search, which focus on individual clinics or emergency info.
Agents choose between tools based on descriptions. A clear purpose with a specific verb and resource helps agents select the right tool.
Does the description explain when to use this tool, when not to, or what alternatives exist?
The description includes an example question ('how many dental clinics are there in Norway?') that implies appropriate usage for aggregate stats. It does not explicitly state when not to use it, but the context from sibling tool names and the description itself provides adequate guidance.
Agents often have multiple tools that could apply. Explicit usage guidance like "use X instead of Y when Z" prevents misuse.
Claim this connector by publishing a /.well-known/glama.json file on your server's domain with the following structure:
{
"$schema": "https://glama.ai/mcp/schemas/connector.json",
"maintainers": [{ "email": "your-email@example.com" }]
}The email address must match the email associated with your Glama account. Once published, Glama will automatically detect and verify the file within a few minutes.
Control your server's listing on Glama, including description and metadata
Access analytics and receive server usage reports
Get monitoring and health status updates for your server
Feature your server to boost visibility and reach more users
For users:
Full audit trail – every tool call is logged with inputs and outputs for compliance and debugging
Granular tool control – enable or disable individual tools per connector to limit what your AI agents can do
Centralized credential management – store and rotate API keys and OAuth tokens in one place
Change alerts – get notified when a connector changes its schema, adds or removes tools, or updates tool definitions, so nothing breaks silently
For server owners:
Proven adoption – public usage metrics on your listing show real-world traction and build trust with prospective users
Tool-level analytics – see which tools are being used most, helping you prioritize development and documentation
Direct user feedback – users can report issues and suggest improvements through the listing, giving you a channel you would not have otherwise
The connector status is unhealthy when Glama is unable to successfully connect to the server. This can happen for several reasons:
The server is experiencing an outage
The URL of the server is wrong
Credentials required to access the server are missing or invalid
If you are the owner of this MCP connector and would like to make modifications to the listing, including providing test credentials for accessing the server, please contact support@glama.ai.
Discussions
No comments yet. Be the first to start the discussion!