################################################################################### # # Copyright (C) 2017 MuK IT GmbH # # Odoo Proprietary License v1.0 # # This software and associated files (the "Software") may only be used # (executed, modified, executed after modifications) if you have # purchased a valid license from the authors, typically via Odoo Apps, # or if you have received a written agreement from the authors of the # Software (see the COPYRIGHT file). # # You may develop Odoo modules that use the Software as a library # (typically by depending on it, importing it and using its resources), # but without copying any source code or material from the Software. # You may distribute those modules under the license of your choice, # provided that this license is compatible with the terms of the Odoo # Proprietary License (For example: LGPL, MIT, or proprietary licenses # similar to this one). # # It is forbidden to publish, distribute, sublicense, or sell copies of # the Software or modified copies of the Software. # # The above copyright notice and this permission notice must be included # in all copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS # OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL # THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER # DEALINGS IN THE SOFTWARE. # ################################################################################### import os import time import hmac import hashlib import logging from odoo.tests import common, HOST, PORT _path = os.path.dirname(os.path.dirname(__file__)) _logger = logging.getLogger(__name__) class HttpCase(common.HttpCase): def csrf_token(self, time_limit=3600): token = self.session.sid max_ts = '' if not time_limit else int(time.time() + time_limit) msg = '%s%s' % (token, max_ts) secret = self.env['ir.config_parameter'].sudo().get_param('database.secret') assert secret, "CSRF protection requires a configured database secret" hm = hmac.new(secret.encode('ascii'), msg.encode('utf-8'), hashlib.sha1).hexdigest() return '%so%s' % (hm, max_ts) def url_open(self, url, data=None, timeout=10, csrf=False): if url.startswith('/'): url = "http://%s:%s%s" % (HOST, PORT, url) if data: if csrf: data.update({'csrf_token': self.csrf_token()}) return self.opener.post(url, data=data, timeout=timeout) return self.opener.get(url, timeout=timeout)