summaryrefslogtreecommitdiff
path: root/addons/payment_ingenico/controllers
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/payment_ingenico/controllers
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/payment_ingenico/controllers')
-rw-r--r--addons/payment_ingenico/controllers/__init__.py3
-rw-r--r--addons/payment_ingenico/controllers/main.py126
2 files changed, 129 insertions, 0 deletions
diff --git a/addons/payment_ingenico/controllers/__init__.py b/addons/payment_ingenico/controllers/__init__.py
new file mode 100644
index 00000000..65a8c120
--- /dev/null
+++ b/addons/payment_ingenico/controllers/__init__.py
@@ -0,0 +1,3 @@
+# -*- coding: utf-8 -*-
+
+from . import main
diff --git a/addons/payment_ingenico/controllers/main.py b/addons/payment_ingenico/controllers/main.py
new file mode 100644
index 00000000..66b91793
--- /dev/null
+++ b/addons/payment_ingenico/controllers/main.py
@@ -0,0 +1,126 @@
+# -*- coding: utf-8 -*-
+import logging
+import pprint
+import werkzeug
+from werkzeug.urls import url_unquote_plus
+
+from odoo import http
+from odoo.http import request
+from odoo.addons.payment.models.payment_acquirer import ValidationError
+from odoo.addons.payment.controllers.portal import PaymentProcessing
+
+_logger = logging.getLogger(__name__)
+
+
+class OgoneController(http.Controller):
+ _accept_url = '/payment/ogone/test/accept'
+ _decline_url = '/payment/ogone/test/decline'
+ _exception_url = '/payment/ogone/test/exception'
+ _cancel_url = '/payment/ogone/test/cancel'
+
+ @http.route([
+ '/payment/ogone/accept', '/payment/ogone/test/accept',
+ '/payment/ogone/decline', '/payment/ogone/test/decline',
+ '/payment/ogone/exception', '/payment/ogone/test/exception',
+ '/payment/ogone/cancel', '/payment/ogone/test/cancel',
+ ], type='http', auth='public', csrf=False)
+ def ogone_form_feedback(self, **post):
+ """ Handle both redirection from Ingenico (GET) and s2s notification (POST/GET) """
+ _logger.info('Ogone: entering form_feedback with post data %s', pprint.pformat(post)) # debug
+ request.env['payment.transaction'].sudo().form_feedback(post, 'ogone')
+ return werkzeug.utils.redirect("/payment/process")
+
+ @http.route(['/payment/ogone/s2s/create_json'], type='json', auth='public', csrf=False)
+ def ogone_s2s_create_json(self, **kwargs):
+ if not kwargs.get('partner_id'):
+ kwargs = dict(kwargs, partner_id=request.env.user.partner_id.id)
+ new_id = request.env['payment.acquirer'].browse(int(kwargs.get('acquirer_id'))).s2s_process(kwargs)
+ return new_id.id
+
+ @http.route(['/payment/ogone/s2s/create_json_3ds'], type='json', auth='public', csrf=False)
+ def ogone_s2s_create_json_3ds(self, verify_validity=False, **kwargs):
+ if not kwargs.get('partner_id'):
+ kwargs = dict(kwargs, partner_id=request.env.user.partner_id.id)
+ token = False
+ error = None
+
+ try:
+ token = request.env['payment.acquirer'].browse(int(kwargs.get('acquirer_id'))).s2s_process(kwargs)
+ except Exception as e:
+ error = str(e)
+
+ if not token:
+ res = {
+ 'result': False,
+ 'error': error,
+ }
+ return res
+
+ res = {
+ 'result': True,
+ 'id': token.id,
+ 'short_name': token.short_name,
+ '3d_secure': False,
+ 'verified': False,
+ }
+
+ if verify_validity != False:
+ baseurl = request.env['ir.config_parameter'].sudo().get_param('web.base.url')
+ params = {
+ 'accept_url': baseurl + '/payment/ogone/validate/accept',
+ 'decline_url': baseurl + '/payment/ogone/validate/decline',
+ 'exception_url': baseurl + '/payment/ogone/validate/exception',
+ 'return_url': kwargs.get('return_url', baseurl)
+ }
+ tx = token.validate(**params)
+ res['verified'] = token.verified
+
+ if tx and tx.html_3ds:
+ res['3d_secure'] = tx.html_3ds
+
+ return res
+
+ @http.route(['/payment/ogone/s2s/create'], type='http', auth='public', methods=["POST"], csrf=False)
+ def ogone_s2s_create(self, **post):
+ error = ''
+ acq = request.env['payment.acquirer'].browse(int(post.get('acquirer_id')))
+ try:
+ token = acq.s2s_process(post)
+ except Exception as e:
+ # synthax error: 'CHECK ERROR: |Not a valid date\n\n50001111: None'
+ token = False
+ error = str(e).splitlines()[0].split('|')[-1] or ''
+
+ if token and post.get('verify_validity'):
+ baseurl = request.env['ir.config_parameter'].sudo().get_param('web.base.url')
+ params = {
+ 'accept_url': baseurl + '/payment/ogone/validate/accept',
+ 'decline_url': baseurl + '/payment/ogone/validate/decline',
+ 'exception_url': baseurl + '/payment/ogone/validate/exception',
+ 'return_url': post.get('return_url', baseurl)
+ }
+ tx = token.validate(**params)
+ if tx and tx.html_3ds:
+ return tx.html_3ds
+ # add the payment transaction into the session to let the page /payment/process to handle it
+ PaymentProcessing.add_payment_transaction(tx)
+ return werkzeug.utils.redirect("/payment/process")
+
+ @http.route([
+ '/payment/ogone/validate/accept',
+ '/payment/ogone/validate/decline',
+ '/payment/ogone/validate/exception',
+ ], type='http', auth='public')
+ def ogone_validation_form_feedback(self, **post):
+ """ Feedback from 3d secure for a bank card validation """
+ request.env['payment.transaction'].sudo().form_feedback(post, 'ogone')
+ return werkzeug.utils.redirect("/payment/process")
+
+ @http.route(['/payment/ogone/s2s/feedback'], auth='public', csrf=False)
+ def feedback(self, **kwargs):
+ try:
+ tx = request.env['payment.transaction'].sudo()._ogone_form_get_tx_from_data(kwargs)
+ tx._ogone_s2s_validate_tree(kwargs)
+ except ValidationError:
+ return 'ko'
+ return 'ok'