Tool: resolve_names
Resolves a batch list of specific location queries (landmark names or exact addresses) into canonical Google Maps Place IDs.
Input Requirements (CRITICAL):
queries(array of objects - MANDATORY): A list of location queries to resolve. You may specify up to 20 queries.- Each query object must have:
text(string - MANDATORY): The text query representing a specific place name or address to resolve.- Examples:
'Googleplex, Mountain View, CA','1600 Amphitheatre Pkwy, Mountain View, CA','Eiffel Tower, Paris'.
- Examples:
- Each query object must have:
location_bias(object - OPTIONAL): Use this to prioritize results near a specific geographic area.- Format:
{"viewport": {"low": {"latitude": [value], "longitude": [value]}, "high": {"latitude": [value], "longitude": [value]}}}
- Format:
region_code(string - OPTIONAL): The Unicode CLDR region code (two-letter country code, e.g.,US,CA) of the user to bias the results.
Instructions for Tool Call:
- Specificity (CRITICAL): Queries must represent a specific place name or address. General searches like
'restaurants'or chain names like'Starbucks'are not supported. - Do NOT call this tool if the downstream tools you plan to invoke already accept raw address or place name strings directly.
Error Handling (CRITICAL):
- This is a batch processing tool. A request might return "mixed results" (e.g. some queries resolve successfully while others fail).
- The output list of
resultsis guaranteed to map 1:1 with the inputqueriesindices. A failed query will result in an emptyResultmessage (noentityis set) at its corresponding index in theresultslist. - You MUST check the
failed_requestsmap field in the response to identify which specific query index failed. The key offailed_requestsrepresents the 0-based index of the failed query in the request. Do not assume the entire batch call failed because of a partial failure.
The following sample demonstrates how to use curl to invoke the resolve_names MCP tool.
| Curl Request |
|---|
curl --location 'https://mapstools.googleapis.com/mcp' \ --header 'content-type: application/json' \ --header 'accept: application/json, text/event-stream' \ --data '{ "method": "tools/call", "params": { "name": "resolve_names", "arguments": { // provide these details according to the tool's MCP specification } }, "jsonrpc": "2.0", "id": 1 }' |
Input Schema
Request message for ResolveNames.
ResolveNamesRequest
| JSON representation |
|---|
{ "queries": [ { object ( |
| Fields | |
|---|---|
queries[] |
Required. A list of location queries to be resolved. You may specify up to 20 queries. |
locationBias |
Optional. An optional region to bias the resolution results. If specified, the resolution results will be biased towards the entities that are closer to this region. Including If both |
regionCode |
Optional. An optional region code to bias the resolution results. If specified, the resolution results will be biased towards the entities that are in or near the specified region. This should be a CLDR region code. For example, "US" or "CA". Including If both |
LocationQuery
| JSON representation |
|---|
{ "text": string } |
| Fields | |
|---|---|
text |
Required. The text query to resolve to a specific geospatial entity on Google Maps, such as a place or an address. The more specific the query, the more accurate the resolution. For example, "San Francisco", "Googleplex, Mountain View, CA", "1600 Amphitheatre Parkway, Mountain View, CA", or "Eiffel Tower, Paris". Queries must be a specific address or place name. General locations like a chain name (e.g. Starbucks) or a search query like "restaurants" are not supported. |
LocationBias
| JSON representation |
|---|
{ // Union field |
| Fields | |
|---|---|
Union field type. The type of the location bias. type can be only one of the following: |
|
viewport |
A viewport defined by a bounding box. |
Viewport
| JSON representation |
|---|
{ "low": { object ( |
| Fields | |
|---|---|
low |
Required. The low point of the viewport. |
high |
Required. The high point of the viewport. |
LatLng
| JSON representation |
|---|
{ "latitude": number, "longitude": number } |
| Fields | |
|---|---|
latitude |
The latitude in degrees. It must be in the range [-90.0, +90.0]. |
longitude |
The longitude in degrees. It must be in the range [-180.0, +180.0]. |
Output Schema
Response message for ResolveNames.
ResolveNamesResponse
| JSON representation |
|---|
{ "results": [ { object ( |
| Fields | |
|---|---|
results[] |
Output only. The list of resolved entities from the location queries. Guaranteed to map 1:1 with the request |
failedRequests |
Output only. A map communicating partial failures. The key is the index of the failed request in the An object containing a list of |
Result
| JSON representation |
|---|
{ "entity": { object ( |
| Fields | |
|---|---|
entity |
Output only. The resolved entity from the location query. |
confidence |
Output only. The level of confidence for the resolution. |
Entity
| JSON representation |
|---|
{ // Union field |
| Fields | |
|---|---|
Union field entity. The resolved entity type. entity can be only one of the following: |
|
place |
The resource name of the resolved place. |
FailedRequestsEntry
| JSON representation |
|---|
{
"key": integer,
"value": {
object ( |
| Fields | |
|---|---|
key |
|
value |
|
Status
| JSON representation |
|---|
{ "code": integer, "message": string, "details": [ { "@type": string, field1: ..., ... } ] } |
| Fields | |
|---|---|
code |
The status code, which should be an enum value of |
message |
A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the |
details[] |
A list of messages that carry the error details. There is a common set of message types for APIs to use. An object containing fields of an arbitrary type. An additional field |
Any
| JSON representation |
|---|
{ "typeUrl": string, "value": string } |
| Fields | |
|---|---|
typeUrl |
Identifies the type of the serialized Protobuf message with a URI reference consisting of a prefix ending in a slash and the fully-qualified type name. Example: type.googleapis.com/google.protobuf.StringValue This string must contain at least one The prefix is arbitrary and Protobuf implementations are expected to simply strip off everything up to and including the last All type URL strings must be legal URI references with the additional restriction (for the text format) that the content of the reference must consist only of alphanumeric characters, percent-encoded escapes, and characters in the following set (not including the outer backticks): In the original design of |
value |
Holds a Protobuf serialization of the type described by type_url. A base64-encoded string. |
Confidence
The level of confidence for the resolution.
| Enums | |
|---|---|
CONFIDENCE_UNSPECIFIED |
Default value. This value is unused. |
MEDIUM |
Medium confidence indicates that the resolution is likely correct but there may be other candidates. |
HIGH |
High confidence indicates that the resolution is correct and represents a specific geospatial entity (e.g., a specific place). |
Tool Annotations
Destructive Hint: ❌ | Idempotent Hint: ❌ | Read Only Hint: ✅ | Open World Hint: ❌