Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
A
Adyen Magento2
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Shared Libs
Adyen Magento2
Commits
0a20e07d
Commit
0a20e07d
authored
Jul 28, 2016
by
Rik ter Beek
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
#67 Adyen Boleto is now using the Facade implementation
parent
eff192e4
Changes
17
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
17 changed files
with
353 additions
and
408 deletions
+353
-408
Block/Checkout/Success.php
Block/Checkout/Success.php
+1
-1
Gateway/Http/Client/TransactionAuthorization.php
Gateway/Http/Client/TransactionAuthorization.php
+1
-2
Gateway/Request/BoletoAuthorizationDataBuilder.php
Gateway/Request/BoletoAuthorizationDataBuilder.php
+87
-0
Gateway/Request/OneclickAuthorizationDataBuilder.php
Gateway/Request/OneclickAuthorizationDataBuilder.php
+6
-1
Gateway/Request/SepaAuthorizationDataBuilder.php
Gateway/Request/SepaAuthorizationDataBuilder.php
+1
-1
Gateway/Response/PaymentAuthorisationDetailsHandler.php
Gateway/Response/PaymentAuthorisationDetailsHandler.php
+1
-0
Gateway/Validator/GeneralResponseValidator.php
Gateway/Validator/GeneralResponseValidator.php
+31
-15
Model/AdyenGenericConfigProvider.php
Model/AdyenGenericConfigProvider.php
+0
-1
Model/Api/PaymentRequest.php
Model/Api/PaymentRequest.php
+1
-29
Model/Method/Boleto.php
Model/Method/Boleto.php
+0
-318
Model/Ui/AdyenBoletoConfigProvider.php
Model/Ui/AdyenBoletoConfigProvider.php
+38
-27
Model/Ui/AdyenCcConfigProvider.php
Model/Ui/AdyenCcConfigProvider.php
+1
-2
Observer/AdyenBoletoDataAssignObserver.php
Observer/AdyenBoletoDataAssignObserver.php
+73
-0
etc/config.xml
etc/config.xml
+11
-1
etc/di.xml
etc/di.xml
+97
-9
etc/events.xml
etc/events.xml
+3
-0
etc/frontend/di.xml
etc/frontend/di.xml
+1
-1
No files found.
Block/Checkout/Success.php
View file @
0a20e07d
...
...
@@ -88,7 +88,7 @@ class Success extends \Magento\Framework\View\Element\Template
public
function
isBoletoPayment
()
{
if
(
$this
->
getOrder
()
->
getPayment
()
&&
$this
->
getOrder
()
->
getPayment
()
->
getMethod
()
==
\Adyen\Payment\Model\
Method\Boleto
::
METHOD_
CODE
)
{
$this
->
getOrder
()
->
getPayment
()
->
getMethod
()
==
\Adyen\Payment\Model\
Ui\AdyenBoletoConfigProvider
::
CODE
)
{
return
true
;
}
return
false
;
...
...
Gateway/Http/Client/TransactionAuthorization.php
View file @
0a20e07d
...
...
@@ -96,9 +96,8 @@ class TransactionAuthorization implements ClientInterface
try
{
$response
=
$service
->
authorise
(
$request
);
}
catch
(
\Adyen\AdyenException
$e
)
{
$response
=
null
;
$response
[
'error'
]
=
$e
->
getMessage
()
;
}
return
$response
;
}
}
Gateway/Request/BoletoAuthorizationDataBuilder.php
0 → 100644
View file @
0a20e07d
<?php
/**
* ######
* ######
* ############ ####( ###### #####. ###### ############ ############
* ############# #####( ###### #####. ###### ############# #############
* ###### #####( ###### #####. ###### ##### ###### ##### ######
* ###### ###### #####( ###### #####. ###### ##### ##### ##### ######
* ###### ###### #####( ###### #####. ###### ##### ##### ######
* ############# ############# ############# ############# ##### ######
* ############ ############ ############# ############ ##### ######
* ######
* #############
* ############
*
* Adyen Payment module (https://www.adyen.com/)
*
* Copyright (c) 2015 Adyen BV (https://www.adyen.com/)
* See LICENSE.txt for license details.
*
* Author: Adyen <magento@adyen.com>
*/
namespace
Adyen\Payment\Gateway\Request
;
use
Magento\Payment\Gateway\Request\BuilderInterface
;
class
BoletoAuthorizationDataBuilder
implements
BuilderInterface
{
/**
* @var \Adyen\Payment\Helper\Data
*/
private
$adyenHelper
;
/**
* CaptureDataBuilder constructor.
*
* @param \Adyen\Payment\Helper\Data $adyenHelper
*/
public
function
__construct
(
\Adyen\Payment\Helper\Data
$adyenHelper
)
{
$this
->
adyenHelper
=
$adyenHelper
;
}
/**
* @param array $buildSubject
* @return mixed
*/
public
function
build
(
array
$buildSubject
)
{
/** @var \Magento\Payment\Gateway\Data\PaymentDataObject $paymentDataObject */
/** @var \Magento\Payment\Gateway\Data\PaymentDataObject $paymentDataObject */
$paymentDataObject
=
\Magento\Payment\Gateway\Helper\SubjectReader
::
readPayment
(
$buildSubject
);
$payment
=
$paymentDataObject
->
getPayment
();
$order
=
$paymentDataObject
->
getOrder
();
$storeId
=
$order
->
getStoreId
();
$request
=
[];
$request
[
'socialSecurityNumber'
]
=
$payment
->
getAdditionalInformation
(
"social_security_number"
);
$request
[
'selectedBrand'
]
=
$payment
->
getAdditionalInformation
(
"boleto_type"
);
$shopperName
=
[
'firstName'
=>
$payment
->
getAdditionalInformation
(
"firstname"
),
'lastName'
=>
$payment
->
getAdditionalInformation
(
"lastname"
),
];
$request
[
'shopperName'
]
=
$shopperName
;
$deliveryDays
=
(
int
)
$this
->
adyenHelper
->
getAdyenBoletoConfigData
(
"delivery_days"
,
$storeId
);
$deliveryDays
=
(
!
empty
(
$deliveryDays
))
?
$deliveryDays
:
5
;
$deliveryDate
=
date
(
"Y-m-d\TH:i:s "
,
mktime
(
date
(
"H"
),
date
(
"i"
),
date
(
"s"
),
date
(
"m"
),
date
(
"j"
)
+
$deliveryDays
,
date
(
"Y"
))
);
$request
[
'deliveryDate'
]
=
$deliveryDate
;
return
$request
;
}
}
\ No newline at end of file
Gateway/Request/OneclickAuthorizationBuilder.php
→
Gateway/Request/OneclickAuthorization
Data
Builder.php
View file @
0a20e07d
...
...
@@ -25,7 +25,7 @@ namespace Adyen\Payment\Gateway\Request;
use
Magento\Payment\Gateway\Request\BuilderInterface
;
class
OneclickAuthorizationBuilder
implements
BuilderInterface
class
OneclickAuthorization
Data
Builder
implements
BuilderInterface
{
/**
* @var \Adyen\Payment\Helper\Data
...
...
@@ -64,6 +64,11 @@ class OneclickAuthorizationBuilder implements BuilderInterface
$request
[
'selectedRecurringDetailReference'
]
=
$recurringDetailReference
;
$request
[
'shopperInteraction'
]
=
$shopperInteraction
;
// if it is a sepadirectdebit set selectedBrand to sepadirectdebit in the case of oneclick
if
(
$payment
->
getCcType
()
==
"sepadirectdebit"
)
{
$request
[
'selectedBrand'
]
=
"sepadirectdebit"
;
}
/*
* For recurring Ideal and Sofort needs to be converted to SEPA
* for this it is mandatory to set selectBrand to sepadirectdebit
...
...
Gateway/Request/SepaAuthorizationBuilder.php
→
Gateway/Request/SepaAuthorization
Data
Builder.php
View file @
0a20e07d
...
...
@@ -25,7 +25,7 @@ namespace Adyen\Payment\Gateway\Request;
use
Magento\Payment\Gateway\Request\BuilderInterface
;
class
SepaAuthorizationBuilder
implements
BuilderInterface
class
SepaAuthorization
Data
Builder
implements
BuilderInterface
{
/**
* @param array $buildSubject
...
...
Gateway/Response/PaymentAuthorisationDetailsHandler.php
View file @
0a20e07d
...
...
@@ -54,5 +54,6 @@ class PaymentAuthorisationDetailsHandler implements HandlerInterface
// do not close transaction so you can do a cancel() and void
$payment
->
setIsTransactionClosed
(
false
);
$payment
->
setShouldCloseParentTransaction
(
false
);
}
}
\ No newline at end of file
Gateway/Validator/GeneralResponseValidator.php
View file @
0a20e07d
...
...
@@ -60,11 +60,39 @@ class GeneralResponseValidator extends AbstractValidator
$errorMessages
=
[];
// validate result
if
(
$response
)
{
if
(
$response
&&
isset
(
$response
[
'resultCode'
])
)
{
switch
(
$response
[
'resultCode'
])
{
case
"Authorised"
:
$payment
->
setAdditionalInformation
(
'pspReference'
,
$response
[
'pspReference'
]);
break
;
case
"Received"
:
$payment
->
setAdditionalInformation
(
'pspReference'
,
$response
[
'pspReference'
]);
// set additionalData
if
(
isset
(
$response
[
'additionalData'
])
&&
is_array
(
$response
[
'additionalData'
]))
{
$additionalData
=
$response
[
'additionalData'
];
if
(
isset
(
$additionalData
[
'boletobancario.dueDate'
]))
{
$payment
->
setAdditionalInformation
(
'dueDate'
,
$additionalData
[
'boletobancario.dueDate'
]
);
}
if
(
isset
(
$additionalData
[
'boletobancario.expirationDate'
]))
{
$payment
->
setAdditionalInformation
(
'expirationDate'
,
$additionalData
[
'boletobancario.expirationDate'
]
);
}
if
(
isset
(
$additionalData
[
'boletobancario.url'
]))
{
$payment
->
setAdditionalInformation
(
'url'
,
$additionalData
[
'boletobancario.url'
]
);
}
}
break
;
case
"RedirectShopper"
:
$payment
->
setAdditionalInformation
(
'3dActive'
,
true
);
$payment
->
setAdditionalInformation
(
'pspReference'
,
$response
[
'pspReference'
]);
...
...
@@ -85,10 +113,7 @@ class GeneralResponseValidator extends AbstractValidator
}
break
;
case
"Refused"
:
$isValid
=
false
;
if
(
$response
[
'refusalReason'
])
{
$refusalReason
=
$response
[
'refusalReason'
];
switch
(
$refusalReason
)
{
case
"Transaction Not Permitted"
:
...
...
@@ -113,26 +138,17 @@ class GeneralResponseValidator extends AbstractValidator
}
else
{
$errorMsg
=
__
(
'The payment is REFUSED.'
);
}
// exeption is to general
// $this->logger->critical($errorMsg);
// $errorMessages[] = $errorMsg;
// this will result the specific error
throw
new
\Magento\Framework\Exception\LocalizedException
(
__
(
$errorMsg
));
break
;
default
:
$isValid
=
false
;
$errorMsg
=
__
(
'Error with payment method please select different payment method.'
);
$this
->
logger
->
critical
(
$errorMsg
);
$errorMessages
[]
=
$errorMsg
;
throw
new
\Magento\Framework\Exception\LocalizedException
(
__
(
$errorMsg
));
break
;
}
}
else
{
$errorMsg
=
__
(
'Error with payment method please select different payment method.'
);
$this
->
logger
->
critical
(
$errorMsg
);
$errorMessages
[]
=
$errorMsg
;
throw
new
\Magento\Framework\Exception\LocalizedException
(
__
(
$errorMsg
));
}
return
$this
->
createResult
(
$isValid
,
$errorMessages
);
...
...
Model/AdyenGenericConfigProvider.php
View file @
0a20e07d
...
...
@@ -49,7 +49,6 @@ class AdyenGenericConfigProvider implements ConfigProviderInterface
protected
$_methodCodes
=
[
\Adyen\Payment\Model\Method\Hpp
::
METHOD_CODE
,
\Adyen\Payment\Model\Method\Pos
::
METHOD_CODE
,
\Adyen\Payment\Model\Method\Boleto
::
METHOD_CODE
];
/**
...
...
Model/Api/PaymentRequest.php
View file @
0a20e07d
...
...
@@ -202,7 +202,6 @@ class PaymentRequest extends DataObject
$request
=
array_merge
(
$request
,
$requestDelivery
);
}
$enableMoto
=
$this
->
_adyenHelper
->
getAdyenCcConfigDataFlag
(
'enable_moto'
,
$storeId
);
$recurringDetailReference
=
null
;
// define the shopper interaction
...
...
@@ -221,35 +220,8 @@ class PaymentRequest extends DataObject
if
(
$payment
->
getCcType
()
==
"sepadirectdebit"
)
{
$request
[
'selectedBrand'
]
=
"sepadirectdebit"
;
}
if
(
$paymentMethodCode
==
\Adyen\Payment\Model\Method\Boleto
::
METHOD_CODE
)
{
$request
[
'socialSecurityNumber'
]
=
$payment
->
getAdditionalInformation
(
"social_security_number"
);
$request
[
'selectedBrand'
]
=
$payment
->
getAdditionalInformation
(
"boleto_type"
);
$shopperName
=
[
'firstName'
=>
$payment
->
getAdditionalInformation
(
"firstname"
),
'lastName'
=>
$payment
->
getAdditionalInformation
(
"lastname"
),
];
$request
[
'shopperName'
]
=
$shopperName
;
$deliveryDays
=
(
int
)
$this
->
_adyenHelper
->
getAdyenBoletoConfigData
(
"delivery_days"
,
$storeId
);
$deliveryDays
=
(
!
empty
(
$deliveryDays
))
?
$deliveryDays
:
5
;
$deliveryDate
=
date
(
"Y-m-d\TH:i:s "
,
mktime
(
date
(
"H"
),
date
(
"i"
),
date
(
"s"
),
date
(
"m"
),
date
(
"j"
)
+
$deliveryDays
,
date
(
"Y"
))
);
$request
[
'deliveryDate'
]
=
$deliveryDate
;
}
$result
=
$service
->
authorise
(
$request
);
return
$result
;
}
...
...
Model/Method/Boleto.php
deleted
100644 → 0
View file @
eff192e4
This diff is collapsed.
Click to expand it.
Model/AdyenBoletoConfigProvider.php
→
Model/
Ui/
AdyenBoletoConfigProvider.php
View file @
0a20e07d
...
...
@@ -21,13 +21,15 @@
* Author: Adyen <magento@adyen.com>
*/
namespace
Adyen\Payment\Model
;
namespace
Adyen\Payment\Model
\Ui
;
use
Magento\Checkout\Model\ConfigProviderInterface
;
class
AdyenBoletoConfigProvider
implements
ConfigProviderInterface
{
const
CODE
=
'adyen_boleto'
;
/**
* @var PaymentHelper
*/
...
...
@@ -39,34 +41,35 @@ class AdyenBoletoConfigProvider implements ConfigProviderInterface
protected
$_adyenHelper
;
/**
* @var
string[]
* @var
\Magento\Framework\UrlInterface
*/
protected
$_methodCodes
=
[
\Adyen\Payment\Model\Method\Boleto
::
METHOD_CODE
];
protected
$_urlBuilder
;
/**
* @var \Magento\Payment\Model\Method\AbstractMethod[]
* Request object
*
* @var \Magento\Framework\App\RequestInterface
*/
protected
$_methods
=
[];
protected
$_request
;
/**
* AdyenBoletoConfigProvider constructor.
*
* @param \Magento\Payment\Helper\Data $paymentHelper
* @param \Adyen\Payment\Helper\Data $adyenHelper
* @param \Magento\Framework\UrlInterface $urlBuilder
* @param \Magento\Framework\App\RequestInterface $request
*/
public
function
__construct
(
\Magento\Payment\Helper\Data
$paymentHelper
,
\Adyen\Payment\Helper\Data
$adyenHelper
\Adyen\Payment\Helper\Data
$adyenHelper
,
\Magento\Framework\UrlInterface
$urlBuilder
,
\Magento\Framework\App\RequestInterface
$request
)
{
$this
->
_paymentHelper
=
$paymentHelper
;
$this
->
_adyenHelper
=
$adyenHelper
;
foreach
(
$this
->
_methodCodes
as
$code
)
{
$this
->
_methods
[
$code
]
=
$this
->
_paymentHelper
->
getMethodInstance
(
$code
);
}
$this
->
_urlBuilder
=
$urlBuilder
;
$this
->
_request
=
$request
;
}
/**
...
...
@@ -74,20 +77,28 @@ class AdyenBoletoConfigProvider implements ConfigProviderInterface
*/
public
function
getConfig
()
{
$config
=
[];
foreach
(
$this
->
_methodCodes
as
$code
)
{
if
(
$this
->
_methods
[
$code
]
->
isAvailable
())
{
$config
=
[
'payment'
=>
[
'adyenBoleto'
=>
[
'boletoTypes'
=>
$this
->
_adyenHelper
->
getBoletoTypes
()
]
]
];
}
}
// set to active
return
[
'payment'
=>
[
self
::
CODE
=>
[
'isActive'
=>
true
,
'redirectUrl'
=>
$this
->
_urlBuilder
->
getUrl
(
'checkout/onepage/success/'
,
[
'_secure'
=>
$this
->
_getRequest
()
->
isSecure
()])
],
'adyenBoleto'
=>
[
'boletoTypes'
=>
$this
->
_adyenHelper
->
getBoletoTypes
()
]
]
];
}
return
$config
;
/**
* Retrieve request object
*
* @return \Magento\Framework\App\RequestInterface
*/
protected
function
_getRequest
()
{
return
$this
->
_request
;
}
}
\ No newline at end of file
Model/Ui/AdyenCcConfigProvider.php
View file @
0a20e07d
...
...
@@ -250,8 +250,7 @@ class AdyenCcConfigProvider implements ConfigProviderInterface
{
return
$this
->
ccConfig
->
getCvvImageUrl
();
}
/**
* Retrieve request object
*
...
...
Observer/AdyenBoletoDataAssignObserver.php
0 → 100644
View file @
0a20e07d
<?php
/**
* ######
* ######
* ############ ####( ###### #####. ###### ############ ############
* ############# #####( ###### #####. ###### ############# #############
* ###### #####( ###### #####. ###### ##### ###### ##### ######
* ###### ###### #####( ###### #####. ###### ##### ##### ##### ######
* ###### ###### #####( ###### #####. ###### ##### ##### ######
* ############# ############# ############# ############# ##### ######
* ############ ############ ############# ############ ##### ######
* ######
* #############
* ############
*
* Adyen Payment module (https://www.adyen.com/)
*
* Copyright (c) 2015 Adyen BV (https://www.adyen.com/)
* See LICENSE.txt for license details.
*
* Author: Adyen <magento@adyen.com>
*/
namespace
Adyen\Payment\Observer
;
use
Magento\Framework\Event\Observer
;
use
Magento\Payment\Observer\AbstractDataAssignObserver
;
use
Magento\Quote\Api\Data\PaymentInterface
;
/**
* Class DataAssignObserver
*/
class
AdyenBoletoDataAssignObserver
extends
AbstractDataAssignObserver
{
const
SOCIAL_SECURITY_NUMBER
=
'social_security_number'
;
const
BOLETO_TYPE
=
'boleto_type'
;
const
FIRSTNAME
=
'firstname'
;
const
LASTNAME
=
'lastname'
;
/**
* @var array
*/
protected
$additionalInformationList
=
[
self
::
SOCIAL_SECURITY_NUMBER
,
self
::
BOLETO_TYPE
,
self
::
FIRSTNAME
,
self
::
LASTNAME
];
/**
* @param Observer $observer
* @return void
*/
public
function
execute
(
Observer
$observer
)
{
$data
=
$this
->
readDataArgument
(
$observer
);
$additionalData
=
$data
->
getData
(
PaymentInterface
::
KEY_ADDITIONAL_DATA
);
if
(
!
is_array
(
$additionalData
))
{
return
;
}
$paymentInfo
=
$this
->
readPaymentModelArgument
(
$observer
);
foreach
(
$this
->
additionalInformationList
as
$additionalInformationKey
)
{
if
(
isset
(
$additionalData
[
$additionalInformationKey
]))
{
$paymentInfo
->
setAdditionalInformation
(
$additionalInformationKey
,
$additionalData
[
$additionalInformationKey
]
);
}
}
}
}
etc/config.xml
View file @
0a20e07d
...
...
@@ -145,12 +145,22 @@
</adyen_pay_by_mail>
<adyen_boleto>
<active>
0
</active>
<model>
Adyen
\Payment\Model\Method\Boleto
</model>
<model>
Adyen
PaymentBoletoFacade
</model>
<title>
Boleto
</title>
<allowspecific>
0
</allowspecific>
<sort_order>
7
</sort_order>
<payment_action>
authorize
</payment_action>
<delivery_days>
5
</delivery_days>
<is_gateway>
1
</is_gateway>
<can_use_checkout>
1
</can_use_checkout>
<can_authorize>
1
</can_authorize>
<can_capture>
1
</can_capture>
<can_capture_partial>
1
</can_capture_partial>
<can_use_internal>
1
</can_use_internal>
<can_refund_partial_per_invoice>
1
</can_refund_partial_per_invoice>
<can_refund>
1
</can_refund>
<can_void>
1
</can_void>
<can_cancel>
1
</can_cancel>
<group>
adyen
</group>
</adyen_boleto>
</payment>
...
...
etc/di.xml
View file @
0a20e07d
This diff is collapsed.
Click to expand it.
etc/events.xml
View file @
0a20e07d
...
...
@@ -32,4 +32,7 @@
<event
name=
"payment_method_assign_data_adyen_sepa"
>
<observer
name=
"adyen_sepa_gateway_data_assign"
instance=
"Adyen\Payment\Observer\AdyenSepaDataAssignObserver"
/>
</event>
<event
name=
"payment_method_assign_data_adyen_boleto"
>
<observer
name=
"adyen_sepa_gateway_data_assign"
instance=
"Adyen\Payment\Observer\AdyenBoletoDataAssignObserver"
/>
</event>
</config>
etc/frontend/di.xml
View file @
0a20e07d
...
...
@@ -32,7 +32,7 @@
<item
name=
"adyen_oneclick_config_provider"
xsi:type=
"object"
>
Adyen\Payment\Model\Ui\AdyenOneclickConfigProvider
</item>
<item
name=
"adyen_hpp_config_provider"
xsi:type=
"object"
>
Adyen\Payment\Model\AdyenHppConfigProvider
</item>
<item
name=
"adyen_sepa_config_provider"
xsi:type=
"object"
>
Adyen\Payment\Model\Ui\AdyenSepaConfigProvider
</item>
<item
name=
"adyen_boleto_config_provider"
xsi:type=
"object"
>
Adyen\Payment\Model\AdyenBoletoConfigProvider
</item>
<item
name=
"adyen_boleto_config_provider"
xsi:type=
"object"
>
Adyen\Payment\Model\
Ui\
AdyenBoletoConfigProvider
</item>
</argument>
</arguments>
</type>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment