summaryrefslogtreecommitdiff
path: root/indoteknik_api/controllers/controller.py
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2023-01-10 10:09:18 +0700
committerstephanchrst <stephanchrst@gmail.com>2023-01-10 10:09:18 +0700
commite4abbde470d917d04256c9804b80d82194d73b51 (patch)
tree5f3ec2b28c7197d339b58d13a93967fa4a498a53 /indoteknik_api/controllers/controller.py
parentf0f31234dfaa22850ebb502211a4488b4981f17c (diff)
parent9eeee43ec3cb57d02a2dcddf03768a2a8f3ea3d8 (diff)
Merge branch 'release' of bitbucket.org:altafixco/indoteknik-addons into release
Diffstat (limited to 'indoteknik_api/controllers/controller.py')
-rw-r--r--indoteknik_api/controllers/controller.py16
1 files changed, 16 insertions, 0 deletions
diff --git a/indoteknik_api/controllers/controller.py b/indoteknik_api/controllers/controller.py
index 10cd76a1..73c8829d 100644
--- a/indoteknik_api/controllers/controller.py
+++ b/indoteknik_api/controllers/controller.py
@@ -8,11 +8,14 @@ from odoo.http import request
from odoo.tools.config import config
from pytz import timezone
import logging
+import jwt
_logger = logging.getLogger(__name__)
class Controller(http.Controller):
+ jwt_secret_key = "NTNv7j0TuYARvmNMmWXo6fKvM4o6nvaUi9ryX38ZHL1bkrnD1ObOQ8JAUmHCBq7Iy7otZcyAagBLHVKvvYaIpmMuxmARQ97jUVG16Jkpkp1wXOPsrF9zwew6TpczyHkHgX5EuLg2MeBuiTqJACs1J0apruOOJCggOtkjB4c"
+
def authenticate(self):
wsgienv = request.httprequest.environ
try:
@@ -76,6 +79,19 @@ class Controller(http.Controller):
order = kw.get('order', '')
return request.env[model].search(query, limit=int(limit), offset=int(offset), order=order)
+
+ def create_user_token(self, user):
+ return jwt.encode({'id': user.id}, self.jwt_secret_key)
+
+ def verify_user_token(self, user_id):
+ try:
+ token = request.httprequest.environ['HTTP_TOKEN']
+ user_token = jwt.decode(token, self.jwt_secret_key, algorithms=['HS256'])
+ if int(user_id) != user_token['id']:
+ return False
+ return True
+ except:
+ return False
@http.route('/api/token', auth='public', methods=['GET', 'OPTIONS'])
def get_api_token(self, **kw):