Hello everyone,
I ran into quite a bit of confusion when trying to migrate a Function from Databases.createDocument() to the new Tables / Rows API and wanted to share this as feedback, because I think the docs are currently misleading.
Context:
Appwrite Cloud
Node.js Functions
node-appwrite SDK
Function runtime is ESM ("type": "module")
What the docs say: In several places, the documentation shows examples like:
import { Client, TablesDB, ID } from 'node-appwrite';
const tablesDB = new TablesDB(client); await tablesDB.createRow({ ... });
or (CommonJS):
const sdk = require('node-appwrite'); const tablesDB = new sdk.TablesDB(client);
This strongly suggests that:
TablesDB exists in the Node SDK
Tables / Rows are available in Appwrite Cloud
What actually happens: When inspecting the installed SDK at runtime:
Object.keys(await import('node-appwrite'))
the exports are:
Client Databases ID Permission Query Storage Users Teams Functions ...
There is no Tables and no TablesDB at all.
As a result:
TablesDB is not a constructor
Tables is not a constructor
createRow() is impossible
The only working API is still Databases.createDocument()
This caused a lot of back-and-forth debugging around:
ESM vs CommonJS
default vs named exports
dynamic imports
SDK versions
When in reality, the root cause was simply: Tables are not available in the Cloud SDK/runtime yet
Why this is confusing:
The docs don’t clearly state that Tables are not available in Cloud
The Node examples don’t mention version or deployment constraints
It’s not obvious that Databases is still the only valid API in Cloud Functions
Thanks a lot for the great work overall!
Recommended threads
- I can't UNPAUSE my project with the free...
I received an email notifying me that my project had been paused due to inactivity, and the email included a link to "Restore project." However, that button red...
- How to bypass the rate limit on the back...
Once a month my app has a ton of usage and I always run into the Too many requests 429 error. I am trying to optimize the queues and jobs to manage that, but a...
- 401 - Project not accessible in this reg...
Hi Appwrite team, I’m experiencing a Cloud Console issue with my NYC region project. Problem: - Some Console pages return: “401 - Project is not accessible ...