Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
ca583c7
[ADD] Add oauth_provider module
Nov 16, 2016
e66a38e
OCA Transbot updated translations from Transifex
oca-transbot May 2, 2017
0ccb04d
[FIX] oauth_provider: Fix tests when using last oauthlib version
Oct 21, 2017
0a32c70
[ADD] icon.png
OCA-git-bot Apr 3, 2019
77c9926
typo
ccomb Oct 31, 2019
216e98f
[MIG] oauth_provider: Migration to 12.0
hbrunn Jul 27, 2022
7004b75
[ADD] auth method oauth_provider
hbrunn Aug 18, 2022
edc55fd
[MIG] oauth_provider: @api.multi
remytms Jan 26, 2023
aaf9b94
[FIX] oauth_provider: dependencies of a compute method
remytms Jan 26, 2023
093a283
[MIG] oauth_provider: change usage of sudo
remytms Jan 26, 2023
62c2590
[MIG] oauth_provider: view_type
remytms Jan 26, 2023
762177e
[MIG] oauth_provider: black, prettier, isort
remytms Jan 26, 2023
41a8bd3
[MIG] oauth_provider: split readme
remytms Jan 26, 2023
491b20c
[MIG] oauth_provider: update manifest
remytms Jan 26, 2023
3208bce
[MIG] oauth_provider: make module installable
remytms Jan 31, 2023
62da886
[MIG] oauth_provider: change datetime call
remytms Feb 2, 2023
ae91247
[FIX] oauth_provider: error using module with safe_eval
remytms Feb 2, 2023
04ecb3f
[FIX] oauth_provider: validator
remytms Feb 2, 2023
08efbf6
[FIX] oauth_provider: dependencies
remytms Feb 2, 2023
477151b
[MIG] oauth_provider: Migration to 16.0
remytms Jan 22, 2025
f8d0d40
[FIX] oauth_provider: controllers errors
remytms Feb 5, 2025
389cac4
[FIX] oauth_provider: views
remytms Feb 5, 2025
7ea159e
[IMP] add migration script
huguesdk Mar 28, 2025
b2c0a93
[FIX] oauth_provider: wrong import in controller
remytms May 8, 2025
e4b266f
[FIX] oauth_provider: client_id missing in request.client
remytms May 8, 2025
e17534b
[IMP] oauth_provider: pre-commit execution
augusto-weiss Aug 6, 2025
c7984ea
[MIG] oauth_provider: Migration to 18.0
augusto-weiss Aug 6, 2025
6be3321
[IMP] oauth_provider: get access_token from headers, remove werkzeug.…
Sep 17, 2025
49364ee
[FIX] oauth_provider: _auth_method_oauth_provider
Sep 24, 2025
48d285f
[IMP] oauth_provider: pre-commit execution
augusto-weiss Oct 24, 2025
d2ca0ef
[MIG] oauth_provider: Migration to 19.0
augusto-weiss Oct 24, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
175 changes: 175 additions & 0 deletions oauth_provider/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,175 @@
==============
OAuth Provider
==============

..
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:aa4309bd3541d2e392e872caef424619e80e84eaeefc61d1d631850118d6483a
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
:target: https://odoo-community.org/page/development-status
:alt: Beta
.. |badge2| image:: https://img.shields.io/badge/licence-AGPL--3-blue.png
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fserver--auth-lightgray.png?logo=github
:target: https://github.com/OCA/server-auth/tree/19.0/oauth_provider
:alt: OCA/server-auth
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/server-auth-16-0/server-auth-16-0-oauth_provider
Copy link

Copilot AI Oct 24, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The Weblate translation URL references version 16-0 and should be updated to 19-0 to match the migration target version.

Suggested change
:target: https://translation.odoo-community.org/projects/server-auth-16-0/server-auth-16-0-oauth_provider
:target: https://translation.odoo-community.org/projects/server-auth-19-0/server-auth-19-0-oauth_provider

Copilot uses AI. Check for mistakes.
:alt: Translate me on Weblate
.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png
:target: https://runboat.odoo-community.org/builds?repo=OCA/server-auth&target_branch=19.0
:alt: Try me on Runboat

|badge1| |badge2| |badge3| |badge4| |badge5|

This module allows you to turn Odoo into an OAuth 2 provider.

It's meant to provide the basic authentication feature, and some data
access routes.
But you are encouraged to create custom routes, in other modules, to
give structured data for any specific need.


**Table of contents**

.. contents::
:local:

Installation
============

To install this module, you need to:

#. Install the oauthlib python module
#. Install the module like any other in Odoo
#. For the token retrieval to work on a multi-database instance, you should add this module in the server_wide_modules list

Configuration
=============

This module requires you to configure two things :

#. The scopes are used to define restricted data access
#. The clients are used to declare applications that will be allowed to request tokens and data

To configure scopes, you need to:

#. Go to Settings > Users > OAuth Provider Scopes
#. Create some scopes:

- The scope name and description will be displayed to the user on the authorization page.
- The code is the value provided by the OAuth clients to request access to the scope.
- The model defines which model the scope is linked to (access to user data, partners, sales orders, etc.).
- The filter allows you to determine which records will be accessible through this scope. No filter means all records of the model are accessible.
- The field names allows you to define which fields will be provided to the clients. An empty list only returns the id of accessible records.

To configure clients, you need to:

#. Go to Settings > Users > OAuth Provider Clients
#. Create at least one client:

- The name will be displayed to the user on the authorization page.
- The client identifier is the value provided by the OAuth clients to request authorizations/tokens.
- The application type adapts the process to four pre-defined profiles:

- Web Application : Authorization Code Grant
- Mobile Application : Implicit Grant
- Legacy Application : Resource Owner Password Credentials Grant
- Backend Application : User Credentials Grant (not implemented yet)

- The skip authorization checkbox allows the client to skip the authorization page, and directly deliver a token without prompting the user (useful when the application is trusted).
- The allowed scopes list defines which data will be accessible by this client applicaton.
- The allowed redirect URIs must match the URI sent by the client, to avoid redirecting users to an unauthorized service. The first value in the list is the default redirect URI.

For example, to configure an Odoo's *auth_oauth* module compatible client, you will enter these values :

- Name : Anything you want
- Client identifier : The identifier you want to give to this client
- Application Type : Mobile Application (Odoo uses the implicit grant mode, which corresponds to the mobile application profile)
- Allowed Scopes : Nothing required, but allowing access to current user's email and name is used by Odoo to fill user's information on signup
- Allowed Redirect URIs : http://odoo.example.com/auth_oauth/signin

Usage
=====

This module will allow OAuth clients to use your Odoo instance as an OAuth provider.

Once configured, you must give these information to your client application :

#. Client identifier : Identifies the application (to be able to check allowed scopes and redirect URIs)
#. Allowed scopes : The codes of scopes allowed for this client
#. URLs for the requests :

- Authorization request : http://odoo.example.com/oauth2/authorize
- Token request : http://odoo.example.com/oauth2/token
- Token information request : http://odoo.example.com/oauth2/tokeninfo
Parameters : access_token
- User information request : http://odoo.example.com/oauth2/userinfo
Parameters : access_token
- Any other model information request (depending on the scopes) : http://odoo.example.com/oauth2/otherinfo
Parameters : access_token and model

For example, to configure the *auth_oauth* Odoo module as a client, you will enter these values :

- Provider name : Anything you want
- Client ID : The identifier of the client configured in your Odoo Provider instance
- Body : Text displayed on Odoo's login page link
- Authentication URL : http://odoo.example.com/oauth2/authorize
- Scope : A space separated list of scope codes allowed to the client in your Odoo Provider instance
- Validation URL : http://odoo.example.com/oauth2/tokeninfo
- Data URL : http://odoo.example.com/oauth2/userinfo

Known issues / Roadmap
======================

* Implement the backend application profile (client credentials grant type)
* Add checkboxes on the authorization page to allow the user to disable
some scopes for a token ? (I don't know if this is allowed in the
OAuth protocol)


Bug Tracker
===========

Bugs are tracked on `GitHub Issues <https://github.com/OCA/server-auth/issues>`_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us to smash it by providing a detailed and welcomed
`feedback <https://github.com/OCA/server-auth/issues/new?body=module:%20oauth_provider%0Aversion:%2016.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.

Do not contact contributors directly about support or help with technical issues.

Credits
=======

Authors
~~~~~~~

* SYLEAM

Contributors
~~~~~~~~~~~~

* Sylvain Garancher <[email protected]>

Maintainers
~~~~~~~~~~~

This module is maintained by the OCA.

.. image:: https://odoo-community.org/logo.png
:alt: Odoo Community Association
:target: https://odoo-community.org

OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.

This module is part of the `OCA/server-auth <https://github.com/OCA/server-auth/tree/19.0/oauth_provider>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
24 changes: 24 additions & 0 deletions oauth_provider/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
# Copyright 2016 SYLEAM
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).

from . import controllers
from . import models

import uuid


def pre_init_hook(env):
"""Initialize oauth_identifier on res.users

The standard initialization puts the same value for every existing record,
which is invalid for this field.
This is done in the pre_init_hook to be able to add the unique constrait
on the first run, when installing the module.
"""
env.cr.execute("ALTER TABLE res_users ADD COLUMN oauth_identifier varchar")
env.cr.execute("SELECT id FROM res_users")
for user_id in env.cr.fetchall():
env.cr.execute(
"UPDATE res_users SET oauth_identifier = %s WHERE id = %s",
(str(uuid.uuid4()), user_id),
)
28 changes: 28 additions & 0 deletions oauth_provider/__manifest__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
# Copyright 2016 SYLEAM
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).

{
"name": "OAuth Provider",
"summary": "Allows to use Odoo as an OAuth2 provider",
"version": "19.0.1.0.0",
"category": "Authentication",
"website": "https://github.com/OCA/server-auth",
"author": "SYLEAM, Odoo Community Association (OCA)",
"license": "AGPL-3",
"installable": True,
"external_dependencies": {
"python": ["oauthlib"],
},
"depends": [
"base",
"web",
],
"data": [
"security/oauth_provider_security.xml",
"security/ir.model.access.csv",
"views/oauth_provider_client.xml",
"views/oauth_provider_scope.xml",
"templates/authorization.xml",
],
"pre_init_hook": "pre_init_hook",
}
4 changes: 4 additions & 0 deletions oauth_provider/controllers/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
# Copyright 2016 SYLEAM
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).

from . import main
Loading