Browse Source

[FIX] privacy_consent: ensure there's always a request user

As the controller is `auth="none"`, sometimes there's no user. This wasn't a problem on v12 where `sudo()` applied `SUPERUSER_ID` by default (below, line 35). In v13 we need to add it manually to avoid some situations where `self.env.uid == False`.

@Tecnativa
pull/56/head
Jairo Llopis 4 years ago
committed by Valtteri Lattu
parent
commit
4a5ba7cddc
  1. 6
      privacy_consent/controllers/main.py

6
privacy_consent/controllers/main.py

@ -5,6 +5,7 @@ from datetime import datetime
from werkzeug.exceptions import NotFound from werkzeug.exceptions import NotFound
from odoo import SUPERUSER_ID
from odoo.http import Controller, request, route from odoo.http import Controller, request, route
from odoo.addons.web.controllers.main import ensure_db from odoo.addons.web.controllers.main import ensure_db
@ -24,8 +25,9 @@ class ConsentController(Controller):
# If there's a website, we need a user to render the template # If there's a website, we need a user to render the template
request.uid = request.website.user_id.id request.uid = request.website.user_id.id
except AttributeError: except AttributeError:
# If there's no website, the default is OK
pass
# If there's no website, be root if there's no UID
if not request.uid:
request.uid = SUPERUSER_ID
consent = ( consent = (
request.env["privacy.consent"] request.env["privacy.consent"]
.with_context(subject_answering=True) .with_context(subject_answering=True)

Loading…
Cancel
Save