Getting this Error-AppwriteException: Invalid document structure: Missing required attribute "image"
- 0
- Web
When i am trying to create post i get this error. My image is being uploaded to storage in Appwrite but my post is not being created. please help asap.
What's the code and database structure?
it is showing error for this code area-const newPost = await databases.createDocument( appwriteConfig.databaseId, appwriteConfig.postCollectionId, ID.unique(), { creator: post.userId, caption: post.caption, imageUrl: fileUrl, imageId:uploadedFile.$id, location: post.location, tags: tags }
You have an attribute who is image instead of imageUrl and you're not specifying it. So that should be the solution:
appwriteConfig.databaseId,
appwriteConfig.postCollectionId,
ID.unique(),
{
creator: post.userId,
caption: post.caption,
image: fileUrl, //This is what changed
imageId:uploadedFile.$id,
location: post.location,
tags: tags
}
Also, a small suggestion: i'ts not needed to save the entire image url if you have the fileID since you can recreate the URL by having the image ID
after change this is what shown in console
Looks like it's not an URL?
You could try to do console.log and see if it's or not an url here:
console.log(fileUrl);
appwriteConfig.databaseId,
appwriteConfig.postCollectionId,
ID.unique(),
{
creator: post.userId,
caption: post.caption,
image: fileUrl, //This is what changed
imageId:uploadedFile.$id,
location: post.location,
tags: tags
}
Recommended threads
- Middleware
how to make middleware in nextjs appwrite with client side auth?
- Error 400: redirect_uri_mismatch
Hi team, Google OAuth was working fine with our Appwrite Cloud setup until yesterday. We did not change any configuration in Appwrite, Google Cloud, or our cod...
- Bulk delete failed with 401
- I created a transaction to bulk delete rows in a table has `done` equal `true` follow documentation. But when run, it returns 401 unauthorized error as screen...