2018-01-16 06:58:15 +01:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
import pprint
|
|
|
|
import logging
|
|
|
|
from werkzeug import urls, utils
|
|
|
|
|
2018-01-16 11:34:37 +01:00
|
|
|
from flectra import http
|
|
|
|
from flectra.http import request
|
2018-04-05 10:25:40 +02:00
|
|
|
from flectra.exceptions import ValidationError
|
2018-01-16 06:58:15 +01:00
|
|
|
|
|
|
|
_logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
class AuthorizeController(http.Controller):
|
|
|
|
_return_url = '/payment/authorize/return/'
|
|
|
|
_cancel_url = '/payment/authorize/cancel/'
|
|
|
|
|
|
|
|
@http.route([
|
|
|
|
'/payment/authorize/return/',
|
|
|
|
'/payment/authorize/cancel/',
|
|
|
|
], type='http', auth='public', csrf=False)
|
|
|
|
def authorize_form_feedback(self, **post):
|
|
|
|
_logger.info('Authorize: entering form_feedback with post data %s', pprint.pformat(post))
|
|
|
|
return_url = '/'
|
|
|
|
if post:
|
|
|
|
request.env['payment.transaction'].sudo().form_feedback(post, 'authorize')
|
|
|
|
return_url = post.pop('return_url', '/')
|
|
|
|
base_url = request.env['ir.config_parameter'].sudo().get_param('web.base.url')
|
|
|
|
# Authorize.Net is expecting a response to the POST sent by their server.
|
|
|
|
# This response is in the form of a URL that Authorize.Net will pass on to the
|
|
|
|
# client's browser to redirect them to the desired location need javascript.
|
|
|
|
return request.render('payment_authorize.payment_authorize_redirect', {
|
|
|
|
'return_url': urls.url_join(base_url, return_url)
|
|
|
|
})
|
|
|
|
|
|
|
|
@http.route(['/payment/authorize/s2s/create_json'], type='json', auth='public')
|
|
|
|
def authorize_s2s_create_json(self, **kwargs):
|
|
|
|
acquirer_id = int(kwargs.get('acquirer_id'))
|
|
|
|
acquirer = request.env['payment.acquirer'].browse(acquirer_id)
|
2018-04-05 10:25:40 +02:00
|
|
|
if not kwargs.get('partner_id'):
|
|
|
|
kwargs = dict(kwargs, partner_id=request.env.user.partner_id.id)
|
2018-01-16 06:58:15 +01:00
|
|
|
return acquirer.s2s_process(kwargs).id
|
|
|
|
|
|
|
|
@http.route(['/payment/authorize/s2s/create_json_3ds'], type='json', auth='public', csrf=False)
|
|
|
|
def authorize_s2s_create_json_3ds(self, verify_validity=False, **kwargs):
|
2018-04-05 10:25:40 +02:00
|
|
|
token = False
|
|
|
|
acquirer = request.env['payment.acquirer'].browse(int(kwargs.get('acquirer_id')))
|
|
|
|
|
|
|
|
try:
|
|
|
|
if not kwargs.get('partner_id'):
|
|
|
|
kwargs = dict(kwargs, partner_id=request.env.user.partner_id.id)
|
|
|
|
token = acquirer.s2s_process(kwargs)
|
|
|
|
except ValidationError as e:
|
|
|
|
message = e.args[0]
|
|
|
|
if isinstance(message, dict) and 'missing_fields' in message:
|
|
|
|
msg = _("The transaction cannot be processed because some contact details are missing or invalid: ")
|
|
|
|
message = msg + ', '.join(message['missing_fields']) + '. '
|
|
|
|
if request.env.user._is_public():
|
|
|
|
message += _("Please sign in to complete your profile.")
|
|
|
|
# update message if portal mode = b2b
|
|
|
|
if request.env['ir.config_parameter'].sudo().get_param('auth_signup.allow_uninvited', 'False').lower() == 'false':
|
|
|
|
message += _("If you don't have any account, please ask your salesperson to update your profile. ")
|
|
|
|
else:
|
|
|
|
message += _("Please complete your profile. ")
|
|
|
|
|
|
|
|
return {
|
|
|
|
'error': message
|
|
|
|
}
|
2018-01-16 06:58:15 +01:00
|
|
|
|
|
|
|
if not token:
|
|
|
|
res = {
|
|
|
|
'result': False,
|
|
|
|
}
|
|
|
|
return res
|
|
|
|
|
|
|
|
res = {
|
|
|
|
'result': True,
|
|
|
|
'id': token.id,
|
|
|
|
'short_name': token.short_name,
|
|
|
|
'3d_secure': False,
|
|
|
|
'verified': False,
|
|
|
|
}
|
|
|
|
|
|
|
|
if verify_validity != False:
|
|
|
|
token.validate()
|
|
|
|
res['verified'] = token.verified
|
|
|
|
|
|
|
|
return res
|
|
|
|
|
|
|
|
@http.route(['/payment/authorize/s2s/create'], type='http', auth='public')
|
|
|
|
def authorize_s2s_create(self, **post):
|
|
|
|
acquirer_id = int(post.get('acquirer_id'))
|
|
|
|
acquirer = request.env['payment.acquirer'].browse(acquirer_id)
|
|
|
|
acquirer.s2s_process(post)
|
|
|
|
return utils.redirect(post.get('return_url', '/'))
|