[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
- Appwrite migration stuck on pending
Migration an existing self hosted 1.9.0 to a new VPS tuning self hosted 1.9.0.. import data recognises the api url, project id and api and then when I create, i...
- Appwrite self host version mismatch
Cloud is on 1.9.5 but Docker Hub only has 1.9.0. Migration fails with 404 general_route_not_found. When will 1.9.5 be published to Docker Hub?
- Unable to connect over this domain.. _AP...
I stood up a fresh VPS and deployed Appwrite 1.9.0 using CLI. Now when I try to access Appwrite using servers IP address I get an Unable to connect over this do...