45 lines
1.6 KiB
Python
45 lines
1.6 KiB
Python
|
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||
|
|
||
|
from werkzeug.urls import iri_to_uri
|
||
|
|
||
|
from odoo import api, fields, models
|
||
|
from odoo.http import request
|
||
|
|
||
|
|
||
|
class PaymentProvider(models.Model):
|
||
|
_inherit = "payment.provider"
|
||
|
|
||
|
website_id = fields.Many2one(
|
||
|
"website",
|
||
|
check_company=True,
|
||
|
ondelete="restrict",
|
||
|
)
|
||
|
|
||
|
@api.model
|
||
|
def _get_compatible_providers(self, *args, website_id=None, **kwargs):
|
||
|
""" Override of `payment` to only return providers matching website-specific criteria.
|
||
|
|
||
|
In addition to the base criteria, the website must either not be set or be the same as the
|
||
|
one provided in the kwargs.
|
||
|
|
||
|
:param int website_id: The provided website, as a `website` id.
|
||
|
:return: The compatible providers.
|
||
|
:rtype: payment.provider
|
||
|
"""
|
||
|
providers = super()._get_compatible_providers(*args, website_id=website_id, **kwargs)
|
||
|
if website_id:
|
||
|
providers = providers.filtered(
|
||
|
lambda p: not p.website_id or p.website_id.id == website_id
|
||
|
)
|
||
|
return providers
|
||
|
|
||
|
def get_base_url(self):
|
||
|
# Give priority to url_root to handle multi-website cases
|
||
|
if request and request.httprequest.url_root:
|
||
|
# Some domain names can use non-Latin script or alphabet or the Latin
|
||
|
# alphabet-based characters with diacritics or ligatures. They are
|
||
|
# stored as ASCII strings using Punycode transcription in the DNS
|
||
|
# system and need to be converted to send to external APIs.
|
||
|
return iri_to_uri(request.httprequest.url_root)
|
||
|
return super().get_base_url()
|