[500 - internal server]: Missing "update" permission for role "team:abc/owner".
- 0
- Self Hosted
- Teams
Web SDK is throwing 500 - internal server on permission missing.
Scenario: A non-owner user is trying to update the Team name.
Here is the traceback:
#0 /usr/src/code/app/controllers/api/teams.php(273): Utopia\Database\Database->updateDocument(Object(Utopia\Database\Document), 'abc...', Object(Utopia\Database\Document))
#1 /usr/src/code/vendor/utopia-php/database/src/Database/Database.php(495): {closure}()
#2 /usr/src/code/app/controllers/api/teams.php(274): Utopia\Database\Database->withRequestTimestamp(NULL, Object(Closure))
#3 /usr/src/code/vendor/utopia-php/framework/src/App.php(508): {closure}('abc...', 'ABC', NULL, Object(Appwrite\Utopia\Response), Object(Utopia\Database\Database), Object(Appwrite\Event\Event))
#4 /usr/src/code/vendor/utopia-php/framework/src/App.php(673): Utopia\App->execute(Object(Utopia\Route), Object(Appwrite\Utopia\Request), Object(Appwrite\Utopia\Response))
#5 /usr/src/code/app/http.php(258): Utopia\App->run(Object(Appwrite\Utopia\Request), Object(Appwrite\Utopia\Response))
#6 {main}
According to the Documentation, the following error should be triggered:
401 Unauthorized Missing or incorrect authentication credentials can happen when the API key or user permission is not sufficient.
403 Forbidden The request is understood, but it has been refused, or access is not allowed. An accompanying error message will explain why. Make sure to register your app in your project's dashboard platform list.
Can you share
- Version of Appwrite
- Your code
- You've marked your question as
serversis it servers or client side SDK?
v1.4.1 It's a self-hosted instance I'm using web client sdk
Can you share the code?
As for changing the team name, if you doing so with the web SDK it won't work as only owner level memebers are allowed to do so.
Other option would be to use the server side teams SDK through a cloud function.
Yes, the error is expected. But here I'm getting 500 - INTERNAL SERVER ERROR. It should be 401 or 403
I'm using this piece of code
const promise = teams.updateName('[TEAM_ID]', '[NAME]');
To update the team's name.
It works fine when the user is the owner of the team. However, when a non-owner user is trying to do update the team name it is throwing 500 error code instead of 401 or 403
Agreed. Would you please create a GitHub issue so we don't forget about this?
Sure!
Recommended threads
- Github connection error - Self Hosted Ap...
I am trying to connect my github account to deploy a project to sites, but Connect to Gtihub button is disabled. I have configured all Env variables needed for...
- "Domain verification failed"
"Domain verification failed" I was install Appwrite in my VDS server. I using Coolify for install Appwrite. After install complete, i want add my domain, and i ...
- Appwrite Sites triggers builds for all p...
I connected my Appwrite Sites to my Git app on my self hosted Appwrite server, but even though I only connected it to main branch, it creates a build every sing...