Coda Folders API

Organize and retrieve folders that contain Coda docs within a workspace.

OpenAPI Specification

coda-openapi.json Raw ↑
{"openapi":"3.0.0","info":{"version":"1.5.0","title":"Coda API","license":{"name":"Coda Developer Terms","url":"https://coda.io/trust/developer"},"description":"# Introduction\n\nThe Coda API is a RESTful API that lets you programmatically interact with Coda docs:\n\n * List and search Coda docs\n * Create new docs and copy existing ones\n * Share and publish docs\n * Discover pages, tables, formulas, and controls\n * Read, insert, upsert, update, and delete rows\n\nIf you plan to integrate Coda with an AI tool, you may also want to consider using the\n[Coda MCP server](https://coda.io/resources/guides/getting_started_with_coda_mcp). It's optimized for LLM usage\npatterns and often exposes more granular methods for accessing and modifying data.\n\n# Getting Started\n\nOur [Getting Started Guide](https://coda.io/@oleg/getting-started-guide-coda-api) helps you learn the\nbasic of working with the API and shows a few ways you can use it. Check it out, and learn how to:\n\n- Read data from Coda tables and write back to them\n- Build a one-way sync from one Coda doc to another\n- Automate reminders\n- Sync your Google Calendar to Coda\n\n# Changes to the API\n\nAs we update and release newer versions of the API, we reserve the right to remove\nolder APIs and functionality with a 3-month deprecation notice. We will post about such changes as well as announce\nnew features in the [Developers Central](https://community.coda.io/c/developers-central) section of our Community,\nand update the [API updates](https://coda.io/api-updates) doc.\n\n# Using the API\n\nCoda's REST API is designed to be straightforward to use. You can use the language and platform of your choice to\nmake requests. To get a feel for the API, you can also use a tool like [Postman](https://www.getpostman.com/) or\n[Insomnia](https://insomnia.rest/).\n\n## API Endpoint\n\nThis API uses a base path of `https://coda.io/apis/v1`.\n\n## Resource IDs and Links\n\nEach resource instance retrieved via the API has the following fields:\n\n  - `id`: The resource's immutable ID, which can be used to refer to it within its context\n  - `type`: The type of resource, useful for identifying it in a heterogenous collection of results\n  - `href`: A fully qualified URI that can be used to refer to and get the latest details on the resource\n\nMost resources can be queried by their name or ID. We recommend sticking with IDs where possible, as names are\nfragile and prone to being changed by your doc's users.\n\n### List Endpoints\n\nEndpoints supporting listing of resources have the following fields:\n\n  - `items`: An array containing the listed resources, limited by the `limit` or `pageToken` query parameters\n  - `nextPageLink`: If more results are available, an API link to the next page of results\n  - `nextPageToken`: If more results are available, a page token that can be passed into the `pageToken` query parameter\n\n**The maximum page size may change at any time, and may be different for different endpoints.** Please do not rely on it\nfor any behavior of your application. If you pass a `limit` parameter that is larger than our maximum allowed limit,\nwe will only return as many results as our maximum limit. You should look for the presence of the `nextPageToken` on the\nresponse to see if there are more results available, rather than relying on a result set that matches your provided limit.\n\nTo fetch a subsequent page of results, pass the `pageToken` parameter. Set this parameter to the value given to you as the `nextPageToken`\nin a page response. If no value is provided, there are no more results available. You only need to pass the `pageToken` to get\nthe next page of results, you don't need to pass any of the parameters from your original request, as they are all\nimplied by the `pageToken`. Any other parameters provided alongside a `pageToken` will be ignored.\n\n### Doc IDs\n\nWhile most object IDs will have to be discovered via the API, you may find yourself frequently wanting to get the\nID of a specific Coda doc.\n\nHere's a handy tool that will extract it for you. (See if you can find the pattern!)\n\n<form>\n  <fieldset style=\"margin: 0px 25px 25px 25px; display: inline;\">\n    <legend>Doc ID Extractor</legend>\n    <input type=\"text\" id=\"de_docUrl\" placeholder=\"Paste in a Coda doc URL\"\n           style=\"width: 250px; padding: 8px; margin-right: 20px;\" />\n    <span>\n      Your doc ID is:&nbsp;&nbsp;&nbsp;\n      <input id=\"de_docId\" readonly=\"true\"\n             style=\"width: 150px; padding: 8px; font-family: monospace; border: 1px dashed gray;\" />\n  </fieldset>\n</form>\n\n## Rate Limiting\n\nThe Coda API sets a reasonable limit on the number of requests that can be made per minute. Once this limit is\nreached, calls to the API will start returning errors with an HTTP status code of 429.\n\nThese are the current rate limits. They are subject to change at any time without notice. For robustness,\nall API scripts should check for HTTP 429 Too Many Requests errors and back off and retry the request.\nLimits apply per-user across all endpoints that share the same limit and across all docs.\n\nReading data (with the exceptions below): {{READ_RATE_LIMIT}}\n<br/>\nWriting data (POST/PUT/PATCH): {{WRITE_RATE_LIMIT}}\n<br/>\nWriting doc content data (POST/PUT/PATCH): {{WRITE_DOC_CONTENT_RATE_LIMIT}}\n<br/>\nListing docs: {{LIST_DOCS_RATE_LIMIT}}\n<br/>\nReading analytics: {{ANALYTICS_RATE_LIMIT}}\n\n## Consistency\n\nWhile edits made in Coda are shared with other collaborators in real-time, it can take a few seconds for them to\nbecome available via the API. You may also notice that changes made via the API, such as updating a row, are not\nimmediate. These endpoints all return an HTTP 202 status code, instead of a standard 200, indicating that the\nedit has been accepted and queued for processing. This generally takes a few seconds, and the edit may fail if\ninvalid. Each such edit will return a `requestId` in the response, and you can pass this `requestId` to the\n[`#getMutationStatus`](#operation/getMutationStatus) endpoint to find out if it has been applied.\n\nSimilarly, when you get doc data from the API (rows, pages, columns, etc), the data you receive comes from\nthe most recent \"snapshot\" of the doc, which might be slightly stale relative to the data you observe in\nyour browser. If you want to ensure that the data you receive is up to date and are ok getting an error if not,\nyou can pass this header in your request: `X-Coda-Doc-Version: latest`. If the API's view of the doc is\nnot up to date, the API will return an HTTP 400 response.\n\n## Volatile Formulas\n\nCoda exposes a number of \"volatile\" formulas, as as `Today()`, `Now()`, and `User()`. When used in a live Coda\ndoc, these formulas affect what's visible in realtime, tailored to the current user.\n\nSuch formulas behave differently with the API. Time-based values may only be current to the last edit made to the\ndoc. User-based values may be blank or invalid.\n\n## Free and Paid Workspaces\n\nWe make the Coda API available to all of our users free of charge, in both free and paid workspaces. However, API\nusage is subject to the role of the user associated with the API token in the workspace applicable to each API\nrequest. What this means is:\n\n- For the [`#createDoc`](#operation/createDoc) endpoint specifically, the owner of the API token must be a Doc\n  Maker (or Admin) in the workspace. If the \"Any member can create docs\" option in enabled in the workspace\n  settings, they can be an Editor and will get auto-promoted to Doc Maker upon using this endpoint. Lastly, if in\n  addition, the API key owner matches the \"Auto-join email domains\" setting, they will be auto-added to the\n  workspace and promoted to Doc Maker upon using this endpoint\n\nThis behavior applies to the API as well as any integrations that may use it, such as Zapier.\n\n## Examples\n\nTo help you get started, this documentation provides code examples in Python, Unix shell, and Google Apps Script.\nThese examples are based on a simple doc that looks something like this:\n\n![](https://cdn.coda.io/external/img/api_example_doc.png)\n\n### Python examples\n\nThese examples use Python 3.6+. If you don't already have the `requests` module, use `pip` or `easy_install` to\nget it.\n\n### Shell examples\n\nThe shell examples are intended to be run in a Unix shell. If you're on Windows, you will need to install\n[WSL](https://docs.microsoft.com/en-us/windows/wsl/install-win10).\n\nThese examples use the standard cURL utility to pull from the API, and then process it with `jq` to extract and\nformat example output. If you don't already have it, you can either [install it](https://stedolan.github.io/jq/)\nor run the command without it to see the raw JSON output.\n\n### Google Apps Script examples\n\n![](https://cdn.coda.io/external/img/api_gas.png)\n\n[Google Apps Script](https://script.google.com/) makes it easy to write code in a JavaScript-like syntax and\neasily access many Google products with built-in libraries. You can set up your scripts to run periodically,\nwhich makes it a good environment for writing tools without maintaining your own server.\n\nCoda provides a library for Google Apps Script. To use it, go into `Resources -> Libraries...` and enter the\nfollowing library ID: `15IQuWOk8MqT50FDWomh57UqWGH23gjsWVWYFms3ton6L-UHmefYHS9Vl`. If you want to see the\nlibrary's source code, it's available\n[here](https://script.google.com/d/15IQuWOk8MqT50FDWomh57UqWGH23gjsWVWYFms3ton6L-UHmefYHS9Vl/edit).\n\nGoogle provides autocomplete for API functions as well as generated docs. You can access these docs via the\nLibraries dialog by clicking on the library name. Required parameters that would be included in the URL path are\npositional arguments in each of these functions, followed by the request body, if applicable. All remaining\nparameters can be specified in the options object.\n\n## OpenAPI/Swagger Spec\n\nIn an effort to standardize our API and make it accessible, we offer an OpenAPI 3.0 specification:\n\n- [OpenAPI 3.0 spec - YAML](https://coda.io/apis/v1/openapi.yaml)\n- [OpenAPI 3.0 spec - JSON](https://coda.io/apis/v1/openapi.json)\n\n#### Postman collection\n\nTo get started with prototyping the API quickly in Postman, you can use one of links above to import the Coda API\ninto a collection. You'll then need to set the [appropriate header](#section/Authentication) and environment\nvariables.\n\n## Client libraries\n\nWe do not currently support client libraries apart from Google Apps Script. To work with the Coda API, you can\neither use standard network libraries for your language, or use the appropriate Swagger Generator tool to\nauto-generate Coda API client libraries for your language of choice. We do not provide any guarantees that these\nautogenerated libraries are compatible with our API (e.g., some libraries may not work with Bearer\nauthentication).\n\n### OpenAPI 3.0\n\n[Swagger Generator 3](https://generator3.swagger.io/) (that link takes you to the docs for the generator API) can\ngenerate client libraries for [these languages](https://generator3.swagger.io/v2/clients). It's relatively new\nand thus only has support for a limited set of languages at this time.\n\n### Third-party client libraries\n\nSome members of our amazing community have written libraries to work with our API. These aren't officially\nsupported by Coda, but are listed here for convenience. (Please let us know if you've written a library and would\nlike to have it included here.)\n\n- [PHP](https://github.com/danielstieber/CodaPHP) by Daniel Stieber\n- [Node-RED](https://github.com/serene-water/node-red-contrib-coda-io) by Mori Sugimoto\n- [NodeJS](https://www.npmjs.com/package/coda-js) by Parker McMullin\n- [Ruby](https://rubygems.org/gems/coda_docs/) by Carlos Muñoz at Getro\n- [Python](https://github.com/Blasterai/codaio) by Mikhail Beliansky\n- [Go](https://github.com/artsafin/coda-schema-generator) by Artur Safin\n","termsOfService":"https://coda.io/trust/tos","contact":{"name":"API Support","url":"https://coda.io","email":"[email protected]"},"x-logo":{"url":"https://cdn.coda.io/external/img/apilogo.png","backgroundColor":"transparent","altText":"Coda API","href":"#"}},"servers":[{"url":"https://coda.io/apis/v1","description":"Coda API (v1)"}],"tags":[{"name":"Account","description":"At this time, the API exposes some limited information about your account. However, `/whoami` is a good endpoint to hit to verify that you're hitting the API correctly and that your token is working as expected.\n"},{"name":"Analytics","description":"This API offers analytics data for your docs and Packs over time."},{"name":"Automations","description":"This API allows you to trigger automations."},{"name":"Columns","description":"While columns in Coda have user-friendly names, they also have immutable IDs that are used when reading and writing rows. These endpoints let you query the columns in a table and get basic information about them.\n"},{"name":"Controls","description":"Controls provide a user-friendly way to input a value that can affect other parts of the doc. This API lets you list controls and get their current values.\n"},{"name":"Docs","description":"Coda docs are foundational, top-level collaborative projects that contain pages. The API lets you list and search your docs to obtain basic metadata like titles and ownership information.\n"},{"name":"Folders","description":"Folders help you organize your docs within workspaces. This API lets you list, create, update, and delete folders.\n"},{"name":"Formulas","description":"Formulas can be great for performing one-off computations, or used with tables and other formulas to compute a single value. With this API, you can discover formulas in a doc and obtain computed results.\n"},{"name":"Miscellaneous","description":"These endpoints wouldn't fit anywhere else, but you may find them useful when working with Coda.\n"},{"name":"Packs","description":"This API allows you to manage Packs that you have developed as well as list publicly available Coda packs.\n"},{"name":"Pages","description":"Pages in Coda offer canvases containing rich text, tables, controls, and other objects. At this time, this API lets you list and access pages in a doc.\n"},{"name":"Permissions","description":"This API lets you manage sharing and permissions for your docs."},{"name":"Publishing","description":"Coda docs can be published publicly and associated with categories to help the world discover them. This API lets you manage the publishing settings of your docs.\n"},{"name":"Rows","description":"You'll likely use this part of the API the most. These endpoints let you retrieve row data from tables in Coda as well as create, upsert, update, and delete them. Most of these endpoints work for both base tables and views, but for inserting/upsering rows, you must use a base table.\n"},{"name":"Tables and Views","description":"If you're here, you know the power of tables in Coda. This API lets you list the tables and views in a Coda doc and obtain basic schema information.\n"},{"name":"Workspaces","description":"This API allows you to manage your workspace's membership and get analytics on membership over time.\n"}],"x-tagGroups":[{"name":"Folders","tags":["Folders"]},{"name":"Docs","tags":["Docs","Permissions","Publishing"]},{"name":"Doc Structure","tags":["Pages","Automations"]},{"name":"Tables and Views","tags":["Tables","Columns","Rows"]},{"name":"Formulas & Controls","tags":["Formulas","Controls"]},{"name":"Miscellaneous","tags":["Account","Analytics","Miscellaneous"]}],"paths":{"/categories":{"get":{"summary":"Get doc categories","description":"Gets all available doc categories.","operationId":"listCategories","tags":["Publishing"],"responses":{"200":{"description":"List of doc categories","content":{"application/json":{"schema":{"$ref":"#/components/schemas/DocCategoryList"}}}},"401":{"$ref":"#/components/responses/UnauthorizedError"},"404":{"$ref":"#/components/responses/NotFoundError"},"429":{"$ref":"#/components/responses/TooManyRequestsError"}},"x-codeSamples":[{"label":"Python 3.13","lang":"python","source":"import requests\n\nheaders = {'Authorization': 'Bearer <your API token>'}\nuri = f'https://coda.io/apis/v1/categories'\nres = requests.get(uri, headers=headers).json()\n\nprint(f'Category count: {res[\"categories\"].length}')\n# => Category count: 10\n"},{"label":"Shell","lang":"shell","source":"curl -s -H 'Authorization: Bearer <your API token>' \\\n  'https://coda.io/apis/v1/categories' |\n  jq .categories.name\n# => \"10\"\n"},{"label":"Google Apps Script","lang":"javascript","source":"// Import the CodaAPI library via Resource->Libraries...:\n// 15IQuWOk8MqT50FDWomh57UqWGH23gjsWVWYFms3ton6L-UHmefYHS9Vl\nCodaAPI.authenticate('<your API token>');\nvar categories = CodaAPI.listCategories();\nLogger.log('Category count: ' + categories.categories.length);\n// => Category count: 10\n"}]}},"/docs":{"get":{"summary":"List available docs","description":"Returns a list of Coda docs accessible by the user, and which they have opened at least once. These are returned in the same order as on the docs page: reverse chronological by the latest event relevant to the user (last viewed, edited, or shared).\n","operationId":"listDocs","tags":["Docs"],"parameters":[{"name":"isOwner","in":"query","description":"Show only docs owned by the user.","schema":{"type":"boolean"}},{"name":"isPublished","in":"query","description":"Show only published docs.","schema":{"type":"boolean"}},{"$ref":"#/components/parameters/query"},{"name":"sourceDoc","in":"query","description":"Show only docs copied from the specified doc ID.","schema":{"type":"string"}},{"name":"isStarred","in":"query","description":"If true, returns docs that are starred. If false, returns docs that are not starred.","schema":{"type":"boolean"}},{"name":"inGallery","in":"query","description":"Show only docs visible within the gallery.","schema":{"type":"boolean"}},{"name":"workspaceId","in":"query","description":"Show only docs belonging to the given workspace.","schema":{"type":"string"}},{"name":"folderId","in":"query","description":"Show only docs belonging to the given folder.","schema":{"type":"string"}},{"$ref":"#/components/parameters/limit"},{"$ref":"#/components/parameters/pageToken"}],"responses":{"200":{"description":"List of Coda docs matching the query.","content":{"application/json":{"schema":{"$ref":"#/components/schemas/DocList"}}}},"401":{"$ref":"#/components/responses/UnauthorizedError"},"403":{"$ref":"#/components/responses/ForbiddenError"},"404":{"$ref":"#/components/responses/NotFoundError"},"429":{"$ref":"#/components/responses/TooManyRequestsError"}},"x-codeSamples":[{"label":"Python 3.13","lang":"python","source":"import requests\n\nheaders = {'Authorization': 'Bearer <your API token>'}\nuri = 'https://coda.io/apis/v1/docs'\nparams = {\n  'isOwner': True,\n  'query': 'New',\n}\nres = requests.get(uri, headers=headers, params=params).json()\n\nprint(f'First doc is: {res[\"items\"][0][\"name\"]}')\n# => First doc is: New Document\n"},{"label":"Shell","lang":"shell","source":"curl -s -H 'Authorization: Bearer <your API token>' \\\n  'https://coda.io/apis/v1/docs' |\n  jq .items[0].name\n# => \"New Document\"\n"},{"label":"Google Apps Script","lang":"javascript","source":"// Import the CodaAPI library via Resource->Libraries...:\n// 15IQuWOk8MqT50FDWomh57UqWGH23gjsWVWYFms3ton6L-UHmefYHS9Vl\nCodaAPI.authenticate('<your API token>');\nvar docs = CodaAPI.listDocs().items;\nLogger.log('First doc is ' + docs[0].name);\n// => First doc is: New Document\n"}]},"post":{"summary":"Create doc","description":"Creates a new Coda doc, optionally copying an existing doc. Note that creating a doc requires you to be a Doc Maker in the applicable workspace (or be auto-promoted to one).\n","operationId":"createDoc","tags":["Docs"],"requestBody":{"description":"Parameters for creating the doc.","required":true,"content":{"application/json":{"schema":{"$ref":"#/components/schemas/DocCreate"}}}},"responses":{"201":{"description":"Info about the created doc.","content":{"application/json":{"schema":{"$ref":"#/components/schemas/DocumentCreationResult"}}}},"400":{"$ref":"#/components/responses/BadRequestError"},"401":{"$ref":"#/components/responses/UnauthorizedError"},"403":{"$ref":"#/components/responses/ForbiddenError"},"429":{"$ref":"#/components/responses/TooManyRequestsError"}},"x-codeSamples":[{"label":"Python 3.13","lang":"python","source":"import requests\n\nheaders = {'Authorization': 'Bearer <your API token>'}\nuri = f'https://coda.io/apis/v1/docs'\npayload = {\n  'title': 'Project Tracker',\n}\nreq = requests.post(uri, headers=headers, json=payload)\nreq.raise_for_status() # Throw if there was an error.\nres = req.json()\n\nprint(f'New doc created with name \"{res[\"name\"]}\"')\n# => New doc created with name \"Project Tracker\"\n"},{"label":"Shell","lang":"shell","source":"curl -s -H 'Authorization: Bearer <your API token>' -X POST -H \"Content-Type: application/json\" \\\n  -d '{\"title\": \"Project Tracker\"}' \\\n  'https://coda.io/apis/v1/docs' |\n  jq .name\n# => \"Project Tracker\"\n"},{"label":"Google Apps Script","lang":"javascript","source":"// Import the CodaAPI library via Resource->Libraries...:\n// 15IQuWOk8MqT50FDWomh57UqWGH23gjsWVWYFms3ton6L-UHmefYHS9Vl\nCodaAPI.authenticate('<your API token>');\nvar res = CodaAPI.createDoc({title: 'Project Tracker'});\nLogger.log('New doc created with name ' + res.name);\n// => First doc in the results is: New Document\n"}]}},"/docs/{docId}":{"get":{"summary":"Get info about a doc","description":"Returns metadata for the specified doc.","operationId":"getDoc","tags":["Docs"],"parameters":[{"$ref":"#/components/parameters/docId"}],"responses":{"200":{"description":"Basic Coda doc metadata.","content":{"application/json":{"schema":{"$ref":"#/components/schemas/Doc"}}}},"401":{"$ref":"#/components/responses/UnauthorizedError"},"403":{"$ref":"#/components/responses/ForbiddenError"},"404":{"$ref":"#/components/responses/NotFoundError"},"429":{"$ref":"#/components/responses/TooManyRequestsError"}},"x-codeSamples":[{"label":"Python 3.13","lang":"python","source":"import requests\n\nheaders = {'Authorization': 'Bearer <your API token>'}\nuri = f'https://coda.io/apis/v1/docs/<doc ID>'\nres = requests.get(uri, headers=headers).json()\n\nprint(f'The name of the doc is {res[\"name\"]}')\n# => The name of the doc is New Document\n"},{"label":"Shell","lang":"shell","source":"curl -s -H 'Authorization: Bearer <your API token>' \\\n  'https://coda.io/apis/v1/docs/<doc ID>' |\n  jq .name\n# => \"New Document\"\n"},{"label":"Google Apps Script","lang":"javascript","source":"// Import the CodaAPI library via Resource->Libraries...:\n// 15IQuWOk8MqT50FDWomh57UqWGH23gjsWVWYFms3ton6L-UHmefYHS9Vl\nCodaAPI.authenticate('<your API token>');\nvar docInfo = CodaAPI.getDoc('<doc ID>');\nLogger.log('The name of the doc is ' + docInfo.name);\n// => The name of the doc is New Document\n"}]},"delete":{"summary":"Delete doc","description":"Deletes a doc.","operationId":"deleteDoc","tags":["Docs"],"parameters":[{"$ref":"#/components/parameters/docId"}],"responses":{"202":{"description":"A result indicating that the doc was deleted.","content":{"application/json":{"schema":{"$ref":"#/components/schemas/DocDelete"}}}},"401":{"$ref":"#/components/responses/UnauthorizedError"},"403":{"$ref":"#/components/responses/ForbiddenError"},"404":{"$ref":"#/components/responses/NotFoundError"},"429":{"$ref":"#/components/responses/TooManyRequestsError"}},"x-codeSamples":[{"label":"Python 3.13","lang":"python","source":"import requests\n\nheaders = {'Authorization': 'Bearer <your API token>'}\nuri = f'https://coda.io/apis/v1/docs/<doc ID>'\nres = requests.delete(uri, headers=headers).json()\n"},{"label":"Shell","lang":"shell","source":"curl -s -X DELETE -H 'Authorization: Bearer <your API token>' \\\n  'https://coda.io/apis/v1/docs/<doc ID>' |\n"},{"label":"Google Apps Script","lang":"javascript","source":"// Import the CodaAPI library via Resource->Libraries...:\n// 15IQuWOk8MqT50FDWomh57UqWGH23gjsWVWYFms3ton6L-UHmefYHS9Vl\nCodaAPI.authenticate('<your API token>');\nvar docInfo = CodaAPI.deleteDoc('<doc ID>');\n// => The given doc is now deleted\n"}]},"patch":{"summary":"Update doc","description":"Updates metadata for a doc. Note that updating a doc title requires you to be a Doc Maker in the applicable workspace.","operationId":"updateDoc","tags":["Docs"],"parameters":[{"$ref":"#/components/parameters/docId"}],"requestBody":{"description":"Parameters for updating the doc.","required":true,"content":{"application/json":{"schema":{"$ref":"#/components/schemas/DocUpdate"}}}},"responses":{"200":{"description":"Basic Coda doc metadata.","content":{"application/json":{"schema":{"$ref":"#/components/schemas/DocUpdateResult"}}}},"400":{"$ref":"#/components/responses/BadRequestError"},"401":{"$ref":"#/components/responses/UnauthorizedError"},"403":{"$ref":"#/components/responses/ForbiddenError"},"404":{"$ref":"#/components/responses/NotFoundError"},"429":{"$ref":"#/components/responses/TooManyRequestsError"}},"x-codeSamples":[{"label":"Python 3.13","lang":"python","source":"import requests\n\nheaders = {'Authorization': 'Bearer <your API token>'}\nuri = f'https://coda.io/apis/v1/docs/<doc ID>'\npayload = {\n  'title': 'New Doc Title',\n}\nreq = requests.patch(uri, headers=headers, json=payload)\n"},{"label":"Shell","lang":"shell","source":"curl -s -H 'Authorization: Bearer <your API token>' -X PATCH -H \"Content-Type: application/json\" \\\n  -d '{\"title\": \"New Doc Title\"}' \\\n  'https://coda.io/apis/v1/docs/<doc ID>'\n"},{"label":"Google Apps Script","lang":"javascript","source":"// Import the CodaAPI library via Resource->Libraries...:\n// 15IQuWOk8MqT50FDWomh57UqWGH23gjsWVWYFms3ton6L-UHmefYHS9Vl\nCodaAPI.authenticate('<your API token>');\nCodaAPI.updateDoc(<doc ID>, {title: \"New Doc Title\"});\n"}]}},"/docs/{docId}/acl/metadata":{"get":{"summary":"Get sharing metadata","description":"Returns metadata associated with sharing for this Coda doc.","operationId":"getSharingMetadata","tags":["Permissions"],"parameters":[{"$ref":"#/components/parameters/docId"}],"responses":{"200":{"description":"Metadata associated with sharing permissions for a doc.","content":{"application/json":{"schema":{"$ref":"#/components/schemas/AclMetadata"}}}},"401":{"$ref":"#/components/responses/UnauthorizedError"},"403":{"$ref":"#/components/responses/ForbiddenError"},"404":{"$ref":"#/components/responses/NotFoundError"},"429":{"$ref":"#/components/responses/TooManyRequestsError"}},"x-codeSamples":[{"label":"Python 3.13","lang":"python","source":"import requests\n\nheaders = {'Authorization': 'Bearer <your API token>'}\nuri = f'https://coda.io/apis/v1/docs/<doc ID>/acl/metadata'\nres = requests.get(uri, headers=headers).json()\n\nprint(f'Can I share this doc with others? {res[\"canShare\"]}')\n# => Can I share this doc with others? true\n"},{"label":"Shell","lang":"shell","source":"curl -s -H 'Authorization: Bearer <your API token>' \\\n  'https://coda.io/apis/v1/docs/<doc ID>/acl/metadata' |\n  jq .canShare\n# => \"true\"\n"},{"label":"Google Apps Script","lang":"javascript","source":"// Import the CodaAPI library via Resource->Libraries...:\n// 15IQuWOk8MqT50FDWomh57UqWGH23gjsWVWYFms3ton6L-UHmefYHS9Vl\nCodaAPI.authenticate('<your API token>');\nvar docSharingMetadata = CodaAPI.getSharingMetadata('<doc ID>');\nLogger.log('Can I share this doc with others? ' + docSharingMetadata.canShare);\n// => Can I share this doc with others? true\n"}]}},"/docs/{docId}/acl/permissions":{"get":{"summary":"List permissions","description":"Returns a list of permissions for this Coda doc.","operationId":"getPermissions","tags":["Permissions"],"parameters":[{"$ref":"#/components/parameters/docId"},{"$ref":"#/components/parameters/limit"},{"$ref":"#/components/parameters/pageToken"}],"responses":{"200":{"description":"List of permissions for a doc.","content":{"application/json":{"schema":{"$ref":"#/components/schemas/Acl"}}}},"401":{"$ref":"#/components/responses/UnauthorizedError"},"403":{"$ref":"#/components/responses/ForbiddenError"},"404":{"$ref":"#/components/responses/NotFoundError"},"429":{"$ref":"#/components/responses/TooManyRequestsError"}},"x-codeSamples":[{"label":"Python 3.13","lang":"python","source":"import requests\n\nheaders = {'Authorization': 'Bearer <your API token>'}\nuri = f'https://coda.io/apis/v1/docs/<doc ID>/acl/permissions'\nres = requests.get(uri, headers=headers).json()\n\nprint(f'First user with access is {res[\"items\"][0][\"principal\"][\"email\"]}')\n# => First user with access is [email protected]\n"},{"label":"Shell","lang":"shell","source":"curl -s -H 'Authorization: Bearer <your API token>' \\\n  'https://coda.io/apis/v1/docs/<doc ID>/acl/permissions' |\n  jq '.items[].principal.email'\n# => \"[email protected]\", \"[email protected]\"\n"},{"label":"Google Apps Script","lang":"javascript","source":"// Import the CodaAPI library via Resource->Libraries...:\n// 15IQuWOk8MqT50FDWomh57UqWGH23gjsWVWYFms3ton6L-UHmefYHS9Vl\nCodaAPI.authenticate('<your API token>');\nvar docPermissions = CodaAPI.getPermissions('<doc ID>');\nLogger.log('First user with access is ' + docPermissions[0].principal.email);\n// => First user with access is [email protected]\n"}]},"post":{"summary":"Add permission","description":"Adds a new permission to the doc.\n","operationId":"addPermission","tags":["Permissions"],"parameters":[{"$ref":"#/components/parameters/docId"}],"requestBody":{"description":"Parameters for adding the new permission.","required":true,"content":{"application/json":{"schema":{"$ref":"#/components/schemas/AddPermissionRequest"}}}},"responses":{"200":{"description":"Confirmation that the request was applied.","content":{"application/json":{"schema":{"$ref":"#/components/schemas/AddPermissionResult"}}}},"400":{"$ref":"#/components/responses/BadRequestError"},"401":{"$ref":"#/components/responses/UnauthorizedError"},"403":{"$ref":"#/components/responses/ForbiddenError"},"404":{"$ref":"#/components/responses/NotFoundError"},"429":{"$ref":"#/components/responses/TooManyRequestsError"}},"x-codeSamples":[{"label":"Python 3.13","lang":"python","source":"import requests\n\nheaders = {'Authorization': 'Bearer <your API token>'}\nuri = f'https://coda.io/apis/v1/docs/<doc ID>/acl/permissions'\npayload = {\n  'access': 'write',\n  'principal': {\n    'type': 'email',\n    'email': '[email protected]'\n  },\n}\nres = requests.post(uri, headers=headers, json=payload)\n\n# => Grant '[email protected]' write access to the doc and send a share notification email\n"},{"label":"Shell","lang":"shell","source":"curl -s -H 'Authorization: Bearer <your API token>' -X POST \\\n  'https://coda.io/apis/v1/docs/<doc ID>/acl/permissions' \\\n  -d '{\"access\": \"write\", \"principal\": {\"type\": \"email\", \"email\": \"[email protected]\"}}'\n# => Grant '[email protected]' write access to the doc and send a share notification email\n"},{"label":"Google Apps Script","lang":"javascript","source":"// Import the CodaAPI library via Resource->Libraries...:\n// 15IQuWOk8MqT50FDWomh57UqWGH23gjsWVWYFms3ton6L-UHmefYHS9Vl\nCodaAPI.authenticate('<your API token>');\nvar docPermissions = CodaAPI.addPermission(\n  '<doc ID>',\n  {access: 'write', principal: {type: 'email', email: '[email protected]'}}\n);\n// => Grant '[email protected]' write access to the doc and send a share notification email\n"}]}},"/docs/{docId}/acl/permissions/{permissionId}":{"delete":{"summary":"Delete permission","description":"Deletes an existing permission.\n","operationId":"deletePermission","tags":["Permissions"],"parameters":[{"$ref":"#/components/parameters/docId"},{"$ref":"#/components/parameters/permissionId"}],"responses":{"200":{"description":"Confirmation that the request was applied.","content":{"application/json":{"schema":{"$ref":"#/components/schemas/DeletePermissionResult"}}}},"400":{"$ref":"#/components/responses/BadRequestError"},"401":{"$ref":"#/components/responses/UnauthorizedError"},"403":{"$ref":"#/components/responses/ForbiddenError"},"404":{"$ref":"#/components/responses/NotFoundError"},"429":{"$ref":"#/components/responses/TooManyRequestsError"}},"x-codeSamples":[{"label":"Python 3.13","lang":"python","source":"import requests\n\nheaders = {'Authorization': 'Bearer <your API token>'}\nuri = f'https://coda.io/apis/v1/docs/<doc ID>/acl/permissions/<permission ID>'\nres = requests.delete(uri, headers=headers, json=payload)\n\n# => Revoke access to the doc\n"},{"label":"Shell","lang":"shell","source":"curl -s -H 'Authorization: Bearer <your API token>' -X DELETE \

# --- truncated at 32 KB (441 KB total) ---
# Full source: https://raw.githubusercontent.com/api-evangelist/coda/refs/heads/main/openapi/coda-openapi.json