2013-12-02 15:03:42 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
try:
|
|
|
|
import simplejson as json
|
|
|
|
except ImportError:
|
|
|
|
import json
|
|
|
|
import logging
|
|
|
|
import pprint
|
2014-01-24 14:59:23 +00:00
|
|
|
import werkzeug
|
|
|
|
|
2014-01-29 17:15:20 +00:00
|
|
|
from openerp import http, SUPERUSER_ID
|
|
|
|
from openerp.http import request
|
2013-12-02 15:03:42 +00:00
|
|
|
|
|
|
|
_logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
class AdyenController(http.Controller):
|
|
|
|
_return_url = '/payment/adyen/return/'
|
|
|
|
|
2014-01-20 15:37:33 +00:00
|
|
|
@http.route([
|
2013-12-02 15:03:42 +00:00
|
|
|
'/payment/adyen/return/',
|
2014-01-29 17:15:20 +00:00
|
|
|
], type='http', auth='none')
|
2014-01-08 14:23:15 +00:00
|
|
|
def adyen_return(self, pspReference, **post):
|
|
|
|
""" Paypal IPN."""
|
|
|
|
post["pspReference"] = pspReference
|
2013-12-02 15:03:42 +00:00
|
|
|
_logger.info('Beginning Adyen form_feedback with post data %s', pprint.pformat(post)) # debug
|
2014-01-29 17:15:20 +00:00
|
|
|
request.registry['payment.transaction'].form_feedback(request.cr, SUPERUSER_ID, post, 'adyen', context=request.context)
|
2013-12-02 15:03:42 +00:00
|
|
|
return_url = post.pop('return_url', '')
|
|
|
|
if not return_url:
|
|
|
|
custom = json.loads(post.pop('merchantReturnData', '{}'))
|
|
|
|
return_url = custom.pop('return_url', '/')
|
2014-01-24 14:59:23 +00:00
|
|
|
return werkzeug.utils.redirect(return_url)
|