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
43ca397e
Commit
43ca397e
authored
Aug 01, 2016
by
Rik ter Beek
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
#67 Adyen Hpp is now using the Facade implementation
parent
0a20e07d
Changes
10
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
403 additions
and
47 deletions
+403
-47
Block/Redirect/Redirect.php
Block/Redirect/Redirect.php
+164
-22
Gateway/Command/HppCommand.php
Gateway/Command/HppCommand.php
+66
-0
Model/AdyenGenericConfigProvider.php
Model/AdyenGenericConfigProvider.php
+0
-1
Model/Method/Hpp.php
Model/Method/Hpp.php
+1
-1
Model/Ui/AdyenHppConfigProvider.php
Model/Ui/AdyenHppConfigProvider.php
+33
-20
Observer/AdyenHppDataAssignObserver.php
Observer/AdyenHppDataAssignObserver.php
+69
-0
etc/config.xml
etc/config.xml
+11
-1
etc/di.xml
etc/di.xml
+54
-0
etc/events.xml
etc/events.xml
+4
-1
etc/frontend/di.xml
etc/frontend/di.xml
+1
-1
No files found.
Block/Redirect/Redirect.php
View file @
43ca397e
This diff is collapsed.
Click to expand it.
Gateway/Command/HppCommand.php
0 → 100644
View file @
43ca397e
<?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\Command
;
use
Magento\Payment\Gateway\Command
;
use
Magento\Payment\Gateway\CommandInterface
;
class
HppCommand
implements
CommandInterface
{
/**
* @var \Adyen\Payment\Helper\Data
*/
protected
$_adyenHelper
;
/**
* HppCommand constructor.
*
* @param \Adyen\Payment\Helper\Data $adyenHelper
*/
public
function
__construct
(
\Adyen\Payment\Helper\Data
$adyenHelper
)
{
$this
->
_adyenHelper
=
$adyenHelper
;
}
/**
* @param array $commandSubject
* @return $this
*/
public
function
execute
(
array
$commandSubject
)
{
$payment
=
\Magento\Payment\Gateway\Helper\SubjectReader
::
readPayment
(
$commandSubject
);
$stateObject
=
\Magento\Payment\Gateway\Helper\SubjectReader
::
readStateObject
(
$commandSubject
);
// do not send email
$payment
=
$payment
->
getPayment
();
$payment
->
getOrder
()
->
setCanSendNewEmailFlag
(
false
);
// update status and state
$stateObject
->
setState
(
\Magento\Sales\Model\Order
::
STATE_NEW
);
$stateObject
->
setStatus
(
$this
->
_adyenHelper
->
getAdyenAbstractConfigData
(
'order_status'
));
$stateObject
->
setIsNotified
(
false
);
return
$this
;
}
}
\ No newline at end of file
Model/AdyenGenericConfigProvider.php
View file @
43ca397e
...
...
@@ -47,7 +47,6 @@ class AdyenGenericConfigProvider implements ConfigProviderInterface
* @var string[]
*/
protected
$_methodCodes
=
[
\Adyen\Payment\Model\Method\Hpp
::
METHOD_CODE
,
\Adyen\Payment\Model\Method\Pos
::
METHOD_CODE
,
];
...
...
Model/Method/Hpp.php
View file @
43ca397e
...
...
@@ -292,7 +292,7 @@ class Hpp extends \Magento\Payment\Model\Method\AbstractMethod implements Gatewa
*/
public
function
getFormUrl
()
{
$paymentRoutine
=
$this
->
getConfigData
(
'payment_routine'
);
$paymentRoutine
=
$this
->
getConfigData
(
'payment_routine'
);
switch
(
$this
->
_adyenHelper
->
isDemoMode
())
{
case
true
:
...
...
Model/AdyenHppConfigProvider.php
→
Model/
Ui/
AdyenHppConfigProvider.php
View file @
43ca397e
...
...
@@ -21,7 +21,7 @@
* Author: Adyen <magento@adyen.com>
*/
namespace
Adyen\Payment\Model
;
namespace
Adyen\Payment\Model
\Ui
;
use
Magento\Checkout\Model\ConfigProviderInterface
;
use
Magento\Payment\Helper\Data
as
PaymentHelper
;
...
...
@@ -30,6 +30,8 @@ use Magento\Directory\Helper\Data;
class
AdyenHppConfigProvider
implements
ConfigProviderInterface
{
const
CODE
=
'adyen_hpp'
;
/**
* @var PaymentHelper
*/
...
...
@@ -41,16 +43,16 @@ class AdyenHppConfigProvider implements ConfigProviderInterface
protected
$_adyenHelper
;
/**
* @var string[]
* Request object
*
* @var \Magento\Framework\App\RequestInterface
*/
protected
$_methodCodes
=
[
'adyen_hpp'
];
protected
$_request
;
/**
* @var \Magento\
Payment\Model\Method\AbstractMethod[]
* @var \Magento\
Framework\UrlInterface
*/
protected
$
methods
=
[]
;
protected
$
_urlBuilder
;
/**
* AdyenHppConfigProvider constructor.
...
...
@@ -60,14 +62,14 @@ class AdyenHppConfigProvider implements ConfigProviderInterface
*/
public
function
__construct
(
PaymentHelper
$paymentHelper
,
\Adyen\Payment\Helper\Data
$adyenHelper
\Adyen\Payment\Helper\Data
$adyenHelper
,
\Magento\Framework\App\RequestInterface
$request
,
\Magento\Framework\UrlInterface
$urlBuilder
)
{
$this
->
_paymentHelper
=
$paymentHelper
;
$this
->
_adyenHelper
=
$adyenHelper
;
foreach
(
$this
->
_methodCodes
as
$code
)
{
$this
->
methods
[
$code
]
=
$this
->
_paymentHelper
->
getMethodInstance
(
$code
);
}
$this
->
_request
=
$request
;
$this
->
_urlBuilder
=
$urlBuilder
;
}
/**
...
...
@@ -77,20 +79,31 @@ class AdyenHppConfigProvider implements ConfigProviderInterface
*/
public
function
getConfig
()
{
// set to active
$config
=
[
'payment'
=>
[
'adyenHpp'
=>
[
self
::
CODE
=>
[
'isActive'
=>
true
,
'redirectUrl'
=>
$this
->
_urlBuilder
->
getUrl
(
'adyen/process/redirect'
,
[
'_secure'
=>
$this
->
_getRequest
()
->
isSecure
()])
]
]
];
foreach
(
$this
->
_methodCodes
as
$code
)
{
if
(
$this
->
methods
[
$code
]
->
isAvailable
())
{
$paymentMethodSelectionOnAdyen
=
$this
->
_adyenHelper
->
getAdyenHppConfigDataFlag
(
'payment_selection_on_adyen'
);
$config
[
'payment'
]
[
'adyenHpp'
][
'isPaymentMethodSelectionOnAdyen'
]
=
$paymentMethodSelectionOnAdyen
;
}
}
$paymentMethodSelectionOnAdyen
=
$this
->
_adyenHelper
->
getAdyenHppConfigDataFlag
(
'payment_selection_on_adyen'
);
$config
[
'payment'
]
[
'adyenHpp'
][
'isPaymentMethodSelectionOnAdyen'
]
=
$paymentMethodSelectionOnAdyen
;
return
$config
;
}
/**
* Retrieve request object
*
* @return \Magento\Framework\App\RequestInterface
*/
protected
function
_getRequest
()
{
return
$this
->
_request
;
}
}
\ No newline at end of file
Observer/AdyenHppDataAssignObserver.php
0 → 100644
View file @
43ca397e
<?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
AdyenHppDataAssignObserver
extends
AbstractDataAssignObserver
{
const
BRAND_CODE
=
'brand_code'
;
const
ISSUER_ID
=
'issuer_id'
;
/**
* @var array
*/
protected
$additionalInformationList
=
[
self
::
BRAND_CODE
,
self
::
ISSUER_ID
];
/**
* @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 @
43ca397e
...
...
@@ -88,7 +88,7 @@
</adyen_oneclick>
<adyen_hpp>
<active>
0
</active>
<model>
Adyen
\Payment\Model\Method\Hpp
</model>
<model>
Adyen
PaymentHppFacade
</model>
<order_status>
pending
</order_status>
<title>
Adyen HPP
</title>
<payment_selection_on_adyen>
0
</payment_selection_on_adyen>
...
...
@@ -99,6 +99,16 @@
<place_order_url>
adyen/process/redirect
</place_order_url>
<order_place_redirect_url>
adyen/process/redirect
</order_place_redirect_url>
<payment_action>
order
</payment_action>
<can_initialize>
1
</can_initialize>
<is_gateway>
1
</is_gateway>
<can_use_checkout>
1
</can_use_checkout>
<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_hpp>
<adyen_sepa>
...
...
etc/di.xml
View file @
43ca397e
...
...
@@ -46,6 +46,16 @@
<argument
name=
"commandPool"
xsi:type=
"object"
>
AdyenPaymentOneclickCommandPool
</argument>
</arguments>
</virtualType>
<virtualType
name=
"AdyenPaymentHppFacade"
type=
"Magento\Payment\Model\Method\Adapter"
>
<arguments>
<argument
name=
"code"
xsi:type=
"const"
>
Adyen\Payment\Model\Ui\AdyenHppConfigProvider::CODE
</argument>
<argument
name=
"formBlockType"
xsi:type=
"string"
>
Adyen\Payment\Block\Form\Hpp
</argument>
<argument
name=
"infoBlockType"
xsi:type=
"string"
>
Adyen\Payment\Block\Info\Hpp
</argument>
<argument
name=
"valueHandlerPool"
xsi:type=
"object"
>
AdyenPaymentHppValueHandlerPool
</argument>
<argument
name=
"validatorPool"
xsi:type=
"object"
>
AdyenPaymentHppValidatorPool
</argument>
<argument
name=
"commandPool"
xsi:type=
"object"
>
AdyenPaymentHppCommandPool
</argument>
</arguments>
</virtualType>
<virtualType
name=
"AdyenPaymentSepaFacade"
type=
"Magento\Payment\Model\Method\Adapter"
>
<arguments>
<argument
name=
"code"
xsi:type=
"const"
>
Adyen\Payment\Model\Ui\AdyenSepaConfigProvider::CODE
</argument>
...
...
@@ -94,6 +104,19 @@
</arguments>
</virtualType>
<virtualType
name=
"AdyenPaymentHppValueHandlerPool"
type=
"Magento\Payment\Gateway\Config\ValueHandlerPool"
>
<arguments>
<argument
name=
"handlers"
xsi:type=
"array"
>
<item
name=
"default"
xsi:type=
"string"
>
AdyenPaymentHppConfigValueHandler
</item>
</argument>
</arguments>
</virtualType>
<virtualType
name=
"AdyenPaymentHppConfigValueHandler"
type=
"Magento\Payment\Gateway\Config\ConfigValueHandler"
>
<arguments>
<argument
name=
"configInterface"
xsi:type=
"object"
>
AdyenPaymentHppConfig
</argument>
</arguments>
</virtualType>
<virtualType
name=
"AdyenPaymentSepaValueHandlerPool"
type=
"Magento\Payment\Gateway\Config\ValueHandlerPool"
>
<arguments>
<argument
name=
"handlers"
xsi:type=
"array"
>
...
...
@@ -131,6 +154,11 @@
<argument
name=
"methodCode"
xsi:type=
"const"
>
Adyen\Payment\Model\Ui\AdyenOneclickConfigProvider::CODE
</argument>
</arguments>
</virtualType>
<virtualType
name=
"AdyenPaymentHppConfig"
type=
"Magento\Payment\Gateway\Config\Config"
>
<arguments>
<argument
name=
"methodCode"
xsi:type=
"const"
>
Adyen\Payment\Model\Ui\AdyenHppConfigProvider::CODE
</argument>
</arguments>
</virtualType>
<virtualType
name=
"AdyenPaymentSepaConfig"
type=
"Magento\Payment\Gateway\Config\Config"
>
<arguments>
<argument
name=
"methodCode"
xsi:type=
"const"
>
Adyen\Payment\Model\Ui\AdyenSepaConfigProvider::CODE
</argument>
...
...
@@ -170,6 +198,18 @@
</arguments>
</virtualType>
<virtualType
name=
"AdyenPaymentHppCommandPool"
type=
"Magento\Payment\Gateway\Command\CommandPool"
>
<arguments>
<argument
name=
"commands"
xsi:type=
"array"
>
<item
name=
"initialize"
xsi:type=
"string"
>
Adyen\Payment\Gateway\Command\HppCommand
</item>
<item
name=
"capture"
xsi:type=
"string"
>
AdyenPaymentCaptureCommand
</item>
<item
name=
"void"
xsi:type=
"string"
>
AdyenPaymentCancelCommand
</item>
<item
name=
"refund"
xsi:type=
"string"
>
AdyenPaymentRefundCommand
</item>
<item
name=
"cancel"
xsi:type=
"string"
>
AdyenPaymentCancelCommand
</item>
</argument>
</arguments>
</virtualType>
<virtualType
name=
"AdyenPaymentSepaCommandPool"
type=
"Magento\Payment\Gateway\Command\CommandPool"
>
<arguments>
<argument
name=
"commands"
xsi:type=
"array"
>
...
...
@@ -463,6 +503,20 @@
</arguments>
</virtualType>
<virtualType
name=
"AdyenPaymentHppValidatorPool"
type=
"Magento\Payment\Gateway\Validator\ValidatorPool"
>
<arguments>
<argument
name=
"validators"
xsi:type=
"array"
>
<item
name=
"country"
xsi:type=
"string"
>
AdyenHppCountryValidator
</item>
</argument>
</arguments>
</virtualType>
<!--FIXME: Config does not exists-->
<virtualType
name=
"AdyenHppCountryValidator"
type=
"Magento\Payment\Gateway\Validator\CountryValidator"
>
<arguments>
<argument
name=
"config"
xsi:type=
"object"
>
Adyen\Payment\Gateway\Config\HppConfig
</argument>
</arguments>
</virtualType>
<virtualType
name=
"AdyenPaymentSepaValidatorPool"
type=
"Magento\Payment\Gateway\Validator\ValidatorPool"
>
<arguments>
<argument
name=
"validators"
xsi:type=
"array"
>
...
...
etc/events.xml
View file @
43ca397e
...
...
@@ -29,10 +29,13 @@
<event
name=
"payment_method_assign_data_adyen_oneclick"
>
<observer
name=
"adyen_cc_gateway_data_assign"
instance=
"Adyen\Payment\Observer\AdyenOneclickDataAssignObserver"
/>
</event>
<event
name=
"payment_method_assign_data_adyen_hpp"
>
<observer
name=
"adyen_hpp_gateway_data_assign"
instance=
"Adyen\Payment\Observer\AdyenHppDataAssignObserver"
/>
</event>
<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"
/>
<observer
name=
"adyen_
boleto
_gateway_data_assign"
instance=
"Adyen\Payment\Observer\AdyenBoletoDataAssignObserver"
/>
</event>
</config>
etc/frontend/di.xml
View file @
43ca397e
...
...
@@ -30,7 +30,7 @@
<item
name=
"adyen_generic_config_provider"
xsi:type=
"object"
>
Adyen\Payment\Model\AdyenGenericConfigProvider
</item>
<item
name=
"adyen_cc_config_provider"
xsi:type=
"object"
>
Adyen\Payment\Model\Ui\AdyenCcConfigProvider
</item>
<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_hpp_config_provider"
xsi:type=
"object"
>
Adyen\Payment\Model\
Ui\
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\Ui\AdyenBoletoConfigProvider
</item>
</argument>
...
...
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