MCP Tools Reference: drivemcp.googleapis.com

Herramienta: create_file

Llama a esta herramienta para crear o subir un archivo a Google Drive.

Si subes un archivo, el contenido debe estar codificado en base64 en el campo content, independientemente del tipo MIME del archivo que se suba.

Muestra un solo objeto File cuando se crea correctamente.

Los siguientes tipos MIME propios de Google Drive se pueden crear sin proporcionar contenido:

  • application/vnd.google-apps.document
  • application/vnd.google-apps.spreadsheet
  • application/vnd.google-apps.presentation

De forma predeterminada, se realizarán las siguientes conversiones para los siguientes tipos MIME:

  • text/plain a application/vnd.google-apps.document
  • text/csv a application/vnd.google-apps.spreadsheet

Para inhabilitar las conversiones de tipos MIME propios, establece disable_conversion_to_google_type como verdadero.

Las carpetas se pueden crear configurando el tipo MIME como application/vnd.google-apps.folder.

En el siguiente ejemplo, se muestra cómo usar curl para invocar la herramienta MCP create_file.

Solicitud curl
curl --location 'https://drivemcp.googleapis.com/mcp' \
--header 'content-type: application/json' \
--header 'accept: application/json, text/event-stream' \
--data '{
  "method": "tools/call",
  "params": {
    "name": "create_file",
    "arguments": {
      // provide these details according to the tool MCP specification
    }
  },
  "jsonrpc": "2.0",
  "id": 1
}'
                

Esquema de entrada

Solicitud para subir un archivo.

CreateFileRequest

Representación JSON
{
  "title": string,
  "mimeType": string,
  "content": string,
  "parentId": string,
  "disableConversionToGoogleType": boolean
}
Campos
title

string

Es el título del archivo.

mimeType

string

Es el tipo MIME del archivo que se subirá.

content

string

Es el contenido del archivo codificado como base64. El campo de contenido siempre debe estar codificado en base64, independientemente del tipo MIME del archivo.

parentId

string

Es el ID superior del archivo.

disableConversionToGoogleType

boolean

Si es verdadero, el archivo no se convertirá a un tipo de Google. No tiene efecto para los tipos MIME que no tienen un equivalente de Google.

Esquema de salida

Un recurso de archivo.

Archivo

Representación JSON
{
  "id": string,
  "title": string,
  "parentId": string,

  "mimeType": string

  "fileSize": string

  "description": string

  "fileExtension": string

  "contentSnippet": string

  "viewUrl": string

  "sharedWithMeTime": string

  "createdTime": string

  "modifiedTime": string

  "viewedByMeTime": string

  "owner": string
}
Campos
id

string

Es el ID del archivo que se recuperó.

title

string

Es el título del archivo.

parentId

string

Es el ID (opcional) del superior del archivo.

Campo de unión _mime_type.

_mime_type puede ser una de las siguientes opciones:

mimeType

string

Es el tipo MIME del archivo.

Campo de unión _file_size.

_file_size puede ser una de las siguientes opciones:

fileSize

string (int64 format)

Es el tamaño en bytes del archivo.

Campo de unión _description.

_description puede ser una de las siguientes opciones:

description

string

Es la descripción del archivo.

Campo de unión _file_extension.

_file_extension puede ser una de las siguientes opciones:

fileExtension

string

Es la extensión de archivo original del archivo. Solo se propaga para los archivos con contenido almacenado en Drive.

Campo de unión _content_snippet.

_content_snippet puede ser una de las siguientes opciones:

contentSnippet

string

Es un fragmento generado sobre el contenido del archivo.

Campo de unión _view_url.

_view_url puede ser una de las siguientes opciones:

viewUrl

string

Es la URL para ver el archivo.

Campo de unión _shared_with_me_time.

_shared_with_me_time puede ser una de las siguientes opciones:

sharedWithMeTime

string (Timestamp format)

Es la hora en la que se compartió el archivo con el solicitante.

Usa el formato RFC 3339, en el que el resultado generado siempre usará la normalización Z y los dígitos fraccionarios 0, 3, 6 o 9. También se aceptan otras compensaciones que no sean “Z”. Ejemplos: "2014-10-02T15:01:23Z", "2014-10-02T15:01:23.045123456Z" o "2014-10-02T15:01:23+05:30".

Campo de unión _created_time.

_created_time puede ser una de las siguientes opciones:

createdTime

string (Timestamp format)

Es la hora en la que se creó el archivo.

Usa el formato RFC 3339, en el que el resultado generado siempre usará la normalización Z y los dígitos fraccionarios 0, 3, 6 o 9. También se aceptan otras compensaciones que no sean “Z”. Ejemplos: "2014-10-02T15:01:23Z", "2014-10-02T15:01:23.045123456Z" o "2014-10-02T15:01:23+05:30".

Campo de unión _modified_time.

_modified_time puede ser una de las siguientes opciones:

modifiedTime

string (Timestamp format)

Es la hora más reciente en la que se modificó el archivo.

Usa el formato RFC 3339, en el que el resultado generado siempre usará la normalización Z y los dígitos fraccionarios 0, 3, 6 o 9. También se aceptan otras compensaciones que no sean “Z”. Ejemplos: "2014-10-02T15:01:23Z", "2014-10-02T15:01:23.045123456Z" o "2014-10-02T15:01:23+05:30".

Campo de unión _viewed_by_me_time.

_viewed_by_me_time puede ser una de las siguientes opciones:

viewedByMeTime

string (Timestamp format)

Es la hora más reciente en la que el solicitante vio el archivo.

Usa el formato RFC 3339, en el que el resultado generado siempre usará la normalización Z y los dígitos fraccionarios 0, 3, 6 o 9. También se aceptan otras compensaciones que no sean “Z”. Ejemplos: "2014-10-02T15:01:23Z", "2014-10-02T15:01:23.045123456Z" o "2014-10-02T15:01:23+05:30".

Campo de unión _owner.

_owner puede ser una de las siguientes opciones:

owner

string

Es la dirección de correo electrónico del propietario del archivo.

Marca de tiempo

Representación JSON
{
  "seconds": string,
  "nanos": integer
}
Campos
seconds

string (int64 format)

Representa los segundos de la hora UTC desde la época de Unix 1970-01-01T00:00:00Z. Debe estar entre -62135596800 y 253402300799 inclusive (que corresponde a 0001-01-01T00:00:00Z a 9999-12-31T23:59:59Z).

nanos

integer

Fracciones no negativas de un segundo a una resolución de nanosegundos. Este campo es la parte de nanosegundos de la duración, no una alternativa a los segundos. Los valores de segundos negativos con fracciones deben tener valores nanos no negativos que se cuentan hacia adelante en el tiempo. Debe estar entre 0 y 999,999,999 inclusive.

Anotaciones de herramientas

Sugerencia destructiva: ❌ | Sugerencia idempotente: ❌ | Sugerencia de solo lectura: ❌ | Sugerencia de mundo abierto: ✅