Skip to content

Clean and simple jwt provider for Odoo 14

Notifications You must be signed in to change notification settings

MatteoNet/jwt_provider2

 
 

Repository files navigation

JWT Provider v2

This module is a completely rework of the original jwt_provider, with a nice and cleaner codebase for developers to easily implement into their app.

Please note that this version is only compatible with odoo 14 (and above, maybe).


Quick link: Documentation


What's included?

  • Basic JWT auth that you can extend or write your own
  • Middleware mechanism - keep your controller logic nice and clean
# middleware
from odoo.addons.jwt_provider2.JwtRequest import JwtRequest, jwt_request
from odoo.addons.jwt_provider2.middleware.MiddlewareException import MiddlewareException

def require_api_key(req: JwtRequest, *kargs, **kwargs):
    api_key = req.headers.get('X-Api-Key')
    if api_key != 'secret':
        raise MiddlewareException('Invalid Api Key', 400, 'invalid_api_key')

# alias middleware
jwt_request.register_middleware('api_key', require_api_key)


# controller
from odoo import http
from odoo.addons.jwt_provider2.JwtRequest import jwt_request

class MyController(http.Controller):
    @http.route('/api/hello-world', type='json')
    @jwt_request.middlewares('api_key', 'middleware_first', '...')
    def hello(self, *kargs, **kwargs):
        return jwt_request.response({ 'message': 'hello world!' })

About

Clean and simple jwt provider for Odoo 14

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 99.9%
  • CSS 0.1%