Allows to use Odoo as an OAuth2 provider
Project description
OAuth Provider
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.
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 requesthttp://odoo.example.com/oauth2/tokeninfo
Parameters : access_token
- User information requesthttp://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. In case of trouble, please check there if your issue has already been reported. If you spotted it first, help us smashing it by providing a detailed and welcomed feedback.
Credits
Images
Odoo Community Association: Icon.
Contributors
Sylvain Garancher <sylvain.garancher@syleam.fr>
Maintainer
This module is maintained by the OCA.
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.
To contribute to this module, please visit https://odoo-community.org.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
File details
Details for the file odoo9_addon_oauth_provider-9.0.1.0.0-py2-none-any.whl
.
File metadata
- Download URL: odoo9_addon_oauth_provider-9.0.1.0.0-py2-none-any.whl
- Upload date:
- Size: 43.7 kB
- Tags: Python 2
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0a8358a9d1bcd070e6f40fa277f5429115436c6b75be04932b9866708aa025c0 |
|
MD5 | f5ed7aedf1b4b0f64eed0133a5c7b9d4 |
|
BLAKE2b-256 | f7730d66999738848da8575dec288e41f17de66ca4beb33a30e81ce67b954efe |