Skip to Content
Menu
You need to be registered to interact with the community.
This question has been flagged
1 Odgovori
658 Prikazi

Dear Community,

We’re currently implementing Odoo on Odoo.sh for a client, with the goal of enhancing certain data flows using AI agents. For this we need API keys, and I’d like to clarify the best practices around managing them across environments.

I’m already familiar with the stages, branches, and build logic of Odoo.sh. In production and staging, I created a dedicated user and generated an API key, which works fine.

My main question is about the testing environment. Since Odoo.sh rebuilds the environment from scratch, what is the recommended approach to ensure stable API access?

  • Should I use the testing branch to test API connections, or is there a better workflow?
  • If API access is possible in testing, which user account should be used: the default admin or a separate dedicated account?

Any advice or best practices from your experience would be greatly appreciated.

Thank you in advance!

Avatar
Opusti
Best Answer

Hi,


When using Odoo.sh, API keys are tied to user accounts, not the instance itself. This means that whenever a testing environment is rebuilt, any manually created keys will be lost unless you migrate them. For that reason, it’s important to plan how API users and keys are managed across production, staging, and testing.


The best practice is to create a dedicated technical user for API access instead of using the default admin account. This makes it easier to control permissions, audit usage, and revoke or rotate keys when needed. Ideally, you should maintain separate API users for production and for testing/staging, so production data is never exposed during development.


In Odoo.sh testing environments, it’s not reliable to create keys manually since they won’t persist after rebuilds. Instead, keys should either be injected through environment variables or automatically provisioned using a bootstrap script or module that creates the API user and key during deployment. This ensures your developers always have consistent test credentials without manual setup.


Finally, the staging branch is the most suitable place for realistic API testing, because it contains a persistent copy of the production database. The testing branch, being short-lived, should only be used with injected or automatically created test credentials. This approach keeps production keys safe while still enabling stable API access for testing and development.



Hope it helps

Avatar
Opusti
Related Posts Odgovori Prikazi Aktivnost
1
okt. 25
3507
2
mar. 25
7506
1
avg. 23
2537
0
nov. 21
3584
1
okt. 25
443