mirror of https://github.com/muk-it/muk_base
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
68 lines
2.9 KiB
68 lines
2.9 KiB
###################################################################################
|
|
#
|
|
# 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)
|
|
|
|
|