Tool: get_document
Get a document from a Firestore database.
The following sample demonstrate how to use curl to invoke the get_document MCP tool.
| Curl Request |
|---|
curl --location 'https://firestore.googleapis.com/mcp' \ --header 'content-type: application/json' \ --header 'accept: application/json, text/event-stream' \ --data '{ "method": "tools/call", "params": { "name": "get_document", "arguments": { // provide these details according to the tool's MCP specification } }, "jsonrpc": "2.0", "id": 1 }' |
Input Schema
The request for Firestore.GetDocument.
GetDocumentRequest
| JSON representation |
|---|
{ "name": string, "mask": { object ( |
| Fields | |
|---|---|
name |
Required. The resource name of the Document to get. In the format: |
mask |
The fields to return. If not set, returns all fields. If the document has a field that is not present in this mask, that field will not be returned in the response. |
Union field consistency_selector. The consistency mode for this transaction. If not set, defaults to strong consistency. consistency_selector can be only one of the following: |
|
transaction |
Reads the document in a transaction. A base64-encoded string. |
readTime |
Reads the version of the document at the given time. This must be a microsecond precision timestamp within the past one hour, or if Point-in-Time Recovery is enabled, can additionally be a whole minute timestamp within the past 7 days. Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples: |
DocumentMask
| JSON representation |
|---|
{ "fieldPaths": [ string ] } |
| Fields | |
|---|---|
fieldPaths[] |
The list of field paths in the mask. See |
Timestamp
| JSON representation |
|---|
{ "seconds": string, "nanos": integer } |
| Fields | |
|---|---|
seconds |
Represents seconds of UTC time since Unix epoch 1970-01-01T00:00:00Z. Must be between -62135596800 and 253402300799 inclusive (which corresponds to 0001-01-01T00:00:00Z to 9999-12-31T23:59:59Z). |
nanos |
Non-negative fractions of a second at nanosecond resolution. This field is the nanosecond portion of the duration, not an alternative to seconds. Negative second values with fractions must still have non-negative nanos values that count forward in time. Must be between 0 and 999,999,999 inclusive. |
Output Schema
A Firestore document.
Must not exceed 1 MiB - 4 bytes.
Document
| JSON representation |
|---|
{
"name": string,
"fields": {
string: {
object ( |
| Fields | |
|---|---|
name |
The resource name of the document, for example |
fields |
The document's fields. The map keys represent field names. Field names matching the regular expression Field paths may be used in other contexts to refer to structured fields defined here. For A simple field name contains only characters A quoted field name starts and ends with An object containing a list of |
createTime |
Output only. The time at which the document was created. This value increases monotonically when a document is deleted then recreated. It can also be compared to values from other documents and the Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples: |
updateTime |
Output only. The time at which the document was last changed. This value is initially set to the Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples: |
FieldsEntry
| JSON representation |
|---|
{
"key": string,
"value": {
object ( |
| Fields | |
|---|---|
key |
|
value |
|
Value
| JSON representation |
|---|
{ // Union field |
| Fields | |
|---|---|
Union field value_type. Must have a value set. value_type can be only one of the following: |
|
nullValue |
A null value. |
booleanValue |
A boolean value. |
integerValue |
An integer value. |
doubleValue |
A double value. |
timestampValue |
A timestamp value. Precise only to microseconds. When stored, any additional precision is rounded down. Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples: |
stringValue |
A string value. The string, represented as UTF-8, must not exceed 1 MiB - 89 bytes. Only the first 1,500 bytes of the UTF-8 representation are considered by queries. |
bytesValue |
A bytes value. Must not exceed 1 MiB - 89 bytes. Only the first 1,500 bytes are considered by queries. A base64-encoded string. |
referenceValue |
A reference to a document. For example: |
geoPointValue |
A geo point value representing a point on the surface of Earth. |
arrayValue |
An array value. Cannot directly contain another array value, though can contain a map which contains another array. |
mapValue |
A map value. |
fieldReferenceValue |
Value which references a field. This is considered relative (vs absolute) since it only refers to a field and not a field within a particular document. Requires:
|
functionValue |
A value that represents an unevaluated expression. Requires:
|
pipelineValue |
A value that represents an unevaluated pipeline. Requires:
|
Timestamp
| JSON representation |
|---|
{ "seconds": string, "nanos": integer } |
| Fields | |
|---|---|
seconds |
Represents seconds of UTC time since Unix epoch 1970-01-01T00:00:00Z. Must be between -62135596800 and 253402300799 inclusive (which corresponds to 0001-01-01T00:00:00Z to 9999-12-31T23:59:59Z). |
nanos |
Non-negative fractions of a second at nanosecond resolution. This field is the nanosecond portion of the duration, not an alternative to seconds. Negative second values with fractions must still have non-negative nanos values that count forward in time. Must be between 0 and 999,999,999 inclusive. |
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]. |
ArrayValue
| JSON representation |
|---|
{
"values": [
{
object ( |
| Fields | |
|---|---|
values[] |
Values in the array. |
MapValue
| JSON representation |
|---|
{
"fields": {
string: {
object ( |
| Fields | |
|---|---|
fields |
The map's fields. The map keys represent field names. Field names matching the regular expression An object containing a list of |
FieldsEntry
| JSON representation |
|---|
{
"key": string,
"value": {
object ( |
| Fields | |
|---|---|
key |
|
value |
|
Function
| JSON representation |
|---|
{ "name": string, "args": [ { object ( |
| Fields | |
|---|---|
name |
Required. The name of the function to evaluate. Requires:
|
args[] |
Optional. Ordered list of arguments the given function expects. |
options |
Optional. Optional named arguments that certain functions may support. An object containing a list of |
OptionsEntry
| JSON representation |
|---|
{
"key": string,
"value": {
object ( |
| Fields | |
|---|---|
key |
|
value |
|
Pipeline
| JSON representation |
|---|
{
"stages": [
{
object ( |
| Fields | |
|---|---|
stages[] |
Required. Ordered list of stages to evaluate. |
Stage
| JSON representation |
|---|
{ "name": string, "args": [ { object ( |
| Fields | |
|---|---|
name |
Required. The name of the stage to evaluate. Requires:
|
args[] |
Optional. Ordered list of arguments the given stage expects. |
options |
Optional. Optional named arguments that certain functions may support. An object containing a list of |
OptionsEntry
| JSON representation |
|---|
{
"key": string,
"value": {
object ( |
| Fields | |
|---|---|
key |
|
value |
|
Tool Annotations
Destructive Hint: ❌ | Idempotent Hint: ❌ | Read Only Hint: ✅ | Open World Hint: ❌