
Hi, I got this error on Appwrite Function, but can't found any solution on google:
module.exports = async (req, res) => {
const database = new sdk.Databases(client);
const currentOrder = JSON.parse(req.variables.APPWRITE_FUNCTION_EVENT_DATA);
const res1 = await database.updateDocument(
currentOrder.$databaseId,
currentOrder.$collectionId,
currentOrder.$id,
currentOrder,
[
sdk.Permission.read(
sdk.Role.user(req.variables.APPWRITE_FUNCTION_USER_ID)
),
sdk.Permission.update(sdk.Role.team("admin")),
]
);
}

Hi there 👋 allow me to look into this and get back to you

hope to see your response soon 😄

So collectionId should not be in currentOrder, only in parameter should be fine

But when I console.log(currentOrder.$collectionId), it show correct collection id

Please help me @joeyouss

Hi @huylv , just DMed you

still need help 😦

Hey there 👋 Problem here seems to be that event give you whole order document, but updateDocument
doesn't like that you provide all those attributes in the document. In the end, update endpoint only needs stuff that you want to update.
Soo solution here should be to pass new currentOrder
as third parameter, and make it only have data that you want to update.
Tho I think this should work - this might be bug with payload of specific event. Ill take a look to double check.

Indeed, I am getting same error when trying to reproduce. This code fails:
editHabitName: async (habit: Habit, newName: string) => {
habit.name = newName;
return await databases.updateDocument<Habit>('main', 'habits', habit.$id, habit);
},
This code works:
editHabitName: async (habitId: string, name: string) => {
return await databases.updateDocument<Habit>('main', 'habits', habitId, {
name
});
},
When doing updateDocument
, make sure to pass data
object that only has stuff you want to change. In my scenario, the name
attribute.

@Meldiron Thanks, I have done it. Just pass empty object to the third parameter and only update the permission. Appwrite is really awesome, but error logs from appwrite's functions are not good. Hope you guys improve it 😄

Eyyy glad you solved it ✨
cc @VincentGe regarding dev-experience with errors

[SOLVED] Invalid document structure: Unknown attribute: "$collectionId"

Ooof this is a hard one. 👀 We can probably write these better for the update/create endpoints though.

Related issue: https://github.com/appwrite/appwrite/issues/4802
Recommended threads
- Web SDK chunk upload to Storage without ...
As discussed in this older thread (https://discord.com/channels/564160730845151244/1216821517749321808), the Read permission for Any needs to be enabled in orde...
- Issue while signing up.
Hey, I’m running into an issue right after the setup. I followed the setup instructions and ran `docker compose up -d`, and while the local server seems to be r...
- Cannot resolve server
Greetings! Is this a known issue at this time? Cloudflare reports likewise. Please advise, thank you!
