Barclays ePDQ Extra Plus Gateway Guide
Services and Compatibility
- Payment Gateway Company Name:
- Barclays ePDQ Extra Plus
- Services that work with Spreedly:
-
- Barclays ePDQ Extra Plus
- Services that do not work with Spreedly:
-
- ePDQ essential
- ePDQ extra
- Supported operations:
- Purchase, Authorize, Capture, Refund, Void
- Supported payment types:
- Credit Card
- Spreedly 3DS2 Global Supported
- No
- Gateway Specific 3DS2 Supported
- No
- Populate MIT GSF Support
- No
- Regions:
- Europe
- API endpoint URL:
-
https://payments.epdq.co.uk/ncol/prod/
Authentication and Security
- Specific names for credentials:
-
default mode:
Pspid, Signature Strength, Userid, Password, Signature -
no_signature mode:
Pspid, Userid, Password
Onboarding Merchants in:
- United Kingdom
Default Mode
To add a Barclays ePDQ Extra Plus gateway you need to supply a pspid, a userid, a password, a signature, and a signature strength:
curl https://core.spreedly.com/v1/gateways.xml \
-u 'C7cRfNJGODKh4Iu5Ox3PToKjniY:4UIuWybmdythfNGPqAqyQnYha6s451ri0fYAo4p3drZUi7q2Jf4b7HKg8etDtoKJ' \
-H 'Content-Type: application/xml' \
-d '<gateway>
<gateway_type>barclays_epdq_extra_plus</gateway_type>
<pspid>psp</pspid>
<userid>user</userid>
<password>password</password>
<signature>sig</signature>
<signature_strength>sha512</signature_strength>
</gateway>'
The signature_strength
can be any of sha1
, sha256
, or sha512
, and will have to match the strength set in the Barclays ePDQ Extra Plus backend.
The Spreedly API will give you back the token:
<gateway>
<token>aE9xEaeaX14C6H2rTjxIUnUuONe</token>
<gateway_type>barclays_epdq_extra_plus</gateway_type>
<name>Barclays ePDQ Extra Plus</name>
<description nil="true"/>
<merchant_profile_key nil="true"/>
<pspid>psp</pspid>
<userid>user</userid>
<signature_strength>sha512</signature_strength>
<characteristics>
<supports_purchase type="boolean">true</supports_purchase>
<supports_authorize type="boolean">true</supports_authorize>
<supports_capture type="boolean">true</supports_capture>
<supports_credit type="boolean">true</supports_credit>
<supports_general_credit type="boolean">false</supports_general_credit>
<supports_void type="boolean">true</supports_void>
<supports_adjust type="boolean">false</supports_adjust>
<supports_verify type="boolean">false</supports_verify>
<supports_reference_purchase type="boolean">false</supports_reference_purchase>
<supports_purchase_via_preauthorization type="boolean">false</supports_purchase_via_preauthorization>
<supports_offsite_purchase type="boolean">false</supports_offsite_purchase>
<supports_offsite_authorize type="boolean">false</supports_offsite_authorize>
<supports_3dsecure_purchase type="boolean">false</supports_3dsecure_purchase>
<supports_3dsecure_authorize type="boolean">false</supports_3dsecure_authorize>
<supports_3dsecure_2_mpi_purchase type="boolean">false</supports_3dsecure_2_mpi_purchase>
<supports_3dsecure_2_mpi_authorize type="boolean">false</supports_3dsecure_2_mpi_authorize>
<supports_store type="boolean">false</supports_store>
<supports_remove type="boolean">false</supports_remove>
<supports_fraud_review type="boolean">false</supports_fraud_review>
<supports_network_tokenization type="boolean">false</supports_network_tokenization>
</characteristics>
<credentials>
<credential>
<name>pspid</name>
<value>psp</value>
</credential>
<credential>
<name>userid</name>
<value>user</value>
</credential>
<credential>
<name>signature_strength</name>
<value>sha512</value>
</credential>
</credentials>
<gateway_settings>
</gateway_settings>
<gateway_specific_fields>
<gateway_specific_field>eci</gateway_specific_field>
</gateway_specific_fields>
<payment_methods>
<payment_method>credit_card</payment_method>
</payment_methods>
<state>retained</state>
<redacted type="boolean">false</redacted>
<sandbox type="boolean">false</sandbox>
<created_at type="dateTime">2021-07-02T17:48:35Z</created_at>
<updated_at type="dateTime">2021-07-02T17:48:35Z</updated_at>
<mode>default</mode>
</gateway>
env = Spreedly::Environment.new('C7cRfNJGODKh4Iu5Ox3PToKjniY', '4UIuWybmdythfNGPqAqyQnYha6s451ri0fYAo4p3drZUi7q2Jf4b7HKg8etDtoKJ', base_url: 'https://core.spreedly.com')
env.add_gateway(:barclays_epdq_extra_plus, pspid: 'psp', userid: 'user',
password: 'password', signature: 'sig', signature_strength: 'sha512')
The signature_strength
can be any of sha1
, sha256
, or sha512
, and will have to match the strength set in the Barclays ePDQ Extra Plus backend.
The Spreedly API will give you back the token:
#<Spreedly::Gateway:0x007fe333a5dca0
@token="5FreR5gWmG1RPcghjHJCjGV6f5C",
@created_at="2017-07-27T17:47:49Z",
@updated_at="2017-07-27T17:47:49Z",
@gateway_type="barclays_epdq_extra_plus",
@state="retained",
@name="Barclays ePDQ Extra Plus",
@credentials={"pspid"=>"psp", "userid"=>"user", "signature_strength"=>"sha512"}>
No Signature Mode
Some Barclays ePDQ Extra Plus accounts may not require or use a signature; for these you can specify the no_signature
mode:
curl https://core.spreedly.com/v1/gateways.xml \
-u 'C7cRfNJGODKh4Iu5Ox3PToKjniY:4UIuWybmdythfNGPqAqyQnYha6s451ri0fYAo4p3drZUi7q2Jf4b7HKg8etDtoKJ' \
-H 'Content-Type: application/xml' \
-d '<gateway>
<gateway_type>barclays_epdq_extra_plus</gateway_type>
<mode>no_signature</mode>
<pspid>psp</pspid>
<userid>user</userid>
<password>password</password>
</gateway>'
<gateway>
<token>JKyxDNXgzvRupScN1nF30vh5dTh</token>
<gateway_type>barclays_epdq_extra_plus</gateway_type>
<name>Barclays ePDQ Extra Plus</name>
<description nil="true"/>
<pspid>psp</pspid>
<userid>user</userid>
<characteristics>
<supports_purchase type="boolean">true</supports_purchase>
<supports_authorize type="boolean">true</supports_authorize>
<supports_capture type="boolean">true</supports_capture>
<supports_credit type="boolean">true</supports_credit>
<supports_general_credit type="boolean">false</supports_general_credit>
<supports_void type="boolean">true</supports_void>
<supports_verify type="boolean">false</supports_verify>
<supports_reference_purchase type="boolean">false</supports_reference_purchase>
<supports_purchase_via_preauthorization type="boolean">false</supports_purchase_via_preauthorization>
<supports_offsite_purchase type="boolean">false</supports_offsite_purchase>
<supports_offsite_authorize type="boolean">false</supports_offsite_authorize>
<supports_3dsecure_purchase type="boolean">false</supports_3dsecure_purchase>
<supports_3dsecure_authorize type="boolean">false</supports_3dsecure_authorize>
<supports_store type="boolean">false</supports_store>
<supports_remove type="boolean">false</supports_remove>
<supports_fraud_review type="boolean">false</supports_fraud_review>
<supports_disburse type="boolean">false</supports_disburse>
</characteristics>
<credentials>
<credential>
<name>pspid</name>
<value>psp</value>
</credential>
<credential>
<name>userid</name>
<value>user</value>
</credential>
</credentials>
<gateway_specific_fields>
</gateway_specific_fields>
<payment_methods>
<payment_method>credit_card</payment_method>
</payment_methods>
<state>retained</state>
<redacted type="boolean">false</redacted>
<created_at type="dateTime">2017-07-27T17:47:49Z</created_at>
<updated_at type="dateTime">2017-07-27T17:47:50Z</updated_at>
<mode>no_signature</mode>
</gateway>
env = Spreedly::Environment.new('C7cRfNJGODKh4Iu5Ox3PToKjniY', '4UIuWybmdythfNGPqAqyQnYha6s451ri0fYAo4p3drZUi7q2Jf4b7HKg8etDtoKJ', base_url: 'https://core.spreedly.com')
env.add_gateway(:barclays_epdq_extra_plus, mode: 'no_signature', pspid: 'psp',
userid: 'user', password: 'password')
#<Spreedly::Gateway:0x007fe332b48cb0
@token="MgudaTMQxqjFVsbedArvuL9eHGY",
@created_at="2017-07-27T17:47:50Z",
@updated_at="2017-07-27T17:47:50Z",
@gateway_type="barclays_epdq_extra_plus",
@state="retained",
@name="Barclays ePDQ Extra Plus",
@credentials={"pspid"=>"psp", "userid"=>"user"}>
Gateway specific fields
Spreedly supports the following gateway specific fields when transacting with a Barclays ePDQ Extra Plus gateway:
eci
If eci
is not passed and the payment method is successful, the eci
will default to 9
curl https://core.spreedly.com/v1/gateways/LlkjmEk0xNkcWrNixXa1fvNoTP4/purchase.xml \
-u 'C7cRfNJGODKh4Iu5Ox3PToKjniY:4UIuWybmdythfNGPqAqyQnYha6s451ri0fYAo4p3drZUi7q2Jf4b7HKg8etDtoKJ' \
-H 'Content-Type: application/xml' \
-d '<transaction>
<payment_method_token>56wyNnSmuA6CWYP7w0MiYCVIbW6</payment_method_token>
<amount>100</amount>
<currency_code>USD</currency_code>
<gateway_specific_fields>
<barclays_epdq_extra_plus>
<eci>1</eci>
</barclays_epdq_extra_plus>
</gateway_specific_fields>
</transaction>'
<transaction>
<on_test_gateway type="boolean">true</on_test_gateway>
<created_at type="dateTime">2021-07-02T17:51:03Z</created_at>
<updated_at type="dateTime">2021-07-02T17:51:03Z</updated_at>
<succeeded type="boolean">true</succeeded>
<state>succeeded</state>
<token>ClmApAraHcBVNE1EOrokVhLsBAe</token>
<transaction_type>Purchase</transaction_type>
<order_id nil="true"/>
<ip nil="true"/>
<description nil="true"/>
<email nil="true"/>
<merchant_name_descriptor nil="true"/>
<merchant_location_descriptor nil="true"/>
<merchant_profile_key nil="true"/>
<gateway_specific_fields>
<barclays_epdq_extra_plus>
<eci>1</eci>
</barclays_epdq_extra_plus>
</gateway_specific_fields>
<gateway_specific_response_fields>
</gateway_specific_response_fields>
<gateway_transaction_id>58</gateway_transaction_id>
<gateway_latency_ms type="integer">1</gateway_latency_ms>
<stored_credential_initiator nil="true"/>
<stored_credential_reason_type nil="true"/>
<warning nil="true"/>
<application_id nil="true"/>
<amount type="integer">100</amount>
<currency_code>USD</currency_code>
<retain_on_success type="boolean">false</retain_on_success>
<payment_method_added type="boolean">false</payment_method_added>
<smart_routed type="boolean">false</smart_routed>
<message key="messages.transaction_succeeded">Succeeded!</message>
<gateway_token>T11bJAANtTWnxl36GYjKWvbNK0g</gateway_token>
<gateway_type>test</gateway_type>
<shipping_address>
<name>Newfirst Newlast</name>
<address1 nil="true"/>
<address2 nil="true"/>
<city nil="true"/>
<state nil="true"/>
<zip nil="true"/>
<country nil="true"/>
<phone_number nil="true"/>
</shipping_address>
<response>
<success type="boolean">true</success>
<message>Successful purchase</message>
<avs_code nil="true"/>
<avs_message nil="true"/>
<cvv_code nil="true"/>
<cvv_message nil="true"/>
<pending type="boolean">false</pending>
<result_unknown type="boolean">false</result_unknown>
<error_code nil="true"/>
<error_detail nil="true"/>
<cancelled type="boolean">false</cancelled>
<fraud_review nil="true"/>
<created_at type="dateTime">2021-07-02T17:51:03Z</created_at>
<updated_at type="dateTime">2021-07-02T17:51:03Z</updated_at>
</response>
<api_urls>
</api_urls>
<payment_method>
<token>1rpKvP8zOUhj4Y9EDrIoIYQzzD5</token>
<created_at type="dateTime">2017-06-26T17:04:38Z</created_at>
<updated_at type="dateTime">2021-07-02T16:52:05Z</updated_at>
<email>joey@example.com</email>
<data>
<my_payment_method_identifier>448</my_payment_method_identifier>
<extra_stuff>
<some_other_things>Can be anything really</some_other_things>
</extra_stuff>
</data>
<storage_state>retained</storage_state>
<test type="boolean">true</test>
<metadata>
<key>string value</key>
</metadata>
<callback_url nil="true"/>
<last_four_digits>1111</last_four_digits>
<first_six_digits>411111</first_six_digits>
<card_type>visa</card_type>
<first_name>Newfirst</first_name>
<last_name>Newlast</last_name>
<month type="integer">3</month>
<year type="integer">2032</year>
<address1 nil="true"/>
<address2 nil="true"/>
<city nil="true"/>
<state nil="true"/>
<zip nil="true"/>
<country nil="true"/>
<phone_number nil="true"/>
<company nil="true"/>
<full_name>Newfirst Newlast</full_name>
<eligible_for_card_updater type="boolean">true</eligible_for_card_updater>
<shipping_address1 nil="true"/>
<shipping_address2 nil="true"/>
<shipping_city nil="true"/>
<shipping_state nil="true"/>
<shipping_zip nil="true"/>
<shipping_country nil="true"/>
<shipping_phone_number nil="true"/>
<payment_method_type>credit_card</payment_method_type>
<errors>
</errors>
<verification_value></verification_value>
<number>XXXX-XXXX-XXXX-1111</number>
<fingerprint>e3cef43464fc832f6e04f187df25af497994</fingerprint>
</payment_method>
<attempt_3dsecure type="boolean">false</attempt_3dsecure>
</transaction>
env = Spreedly::Environment.new('C7cRfNJGODKh4Iu5Ox3PToKjniY', '4UIuWybmdythfNGPqAqyQnYha6s451ri0fYAo4p3drZUi7q2Jf4b7HKg8etDtoKJ', base_url: 'https://core.spreedly.com')
env.purchase_on_gateway("LlkjmEk0xNkcWrNixXa1fvNoTP4", "56wyNnSmuA6CWYP7w0MiYCVIbW6", 4432,
gateway_specific_fields: {
barclays_epdq_extra_plus: {
eci: 1
}
}
)
#<Spreedly::Purchase:0x00007faf021df430
@token="3sc5PR430rcUpvSqQ8yAzRqCyGO",
@created_at="2021-07-02T17:53:07Z",
@updated_at="2021-07-02T17:53:07Z",
@state="succeeded",
@message="Succeeded!",
@succeeded="true",
@order_id="",
@ip="",
@description="",
@gateway_token="T11bJAANtTWnxl36GYjKWvbNK0g",
@gateway_transaction_id="55",
@email="",
@transaction_type="Purchase",
@merchant_name_descriptor="",
@merchant_location_descriptor="",
@on_test_gateway="true",
@currency_code="USD",
@callback_url="",
@stored_credential_initiator="",
@stored_credential_reason_type="",
@amount="4432",
@response,=
#<Spreedly::Response:0x00007faf021beaa0
@success="true",
@pending="false",
@cancelled="false",
@fraud_review="",
@created_at="2021-07-02T17:53:07Z",
@updated_at="2021-07-02T17:53:07Z",
@message="Successful purchase",
@avs_code="",
@avs_message="",
@cvv_code="",
@cvv_message="",
@error_code="",
@error_detail="">,
@shipping_address,=
#<Spreedly::ShippingAddress:0x00007faf021a7198
@name="Newfirst Newlast",
@address1="",
@address2="",
@city="",
@state="",
@zip="",
@country="",
@phone_number="">,
@gateway_specific_fields={:barclays_epdq_extra_plus=>{:eci=>"1"}},
@gateway_specific_response_fields={},
@payment_method,=
#<Spreedly::CreditCard:0x00007faf02196028
@token="1rpKvP8zOUhj4Y9EDrIoIYQzzD5",
@created_at="2017-06-26T17:04:38Z",
@updated_at="2021-07-02T17:51:03Z",
@email="joey@example.com",
@storage_state="retained",
@data="<my_payment_method_identifier>448</my_payment_method_identifier>\n <extra_stuff>\n <some_other_things>Can be anything really</some_other_things>\n </extra_stuff>",
@payment_method_type="credit_card",
@first_name="Newfirst",
@last_name="Newlast",
@full_name="Newfirst Newlast",
@month="3",
@year="2032",
@number="XXXX-XXXX-XXXX-1111",
@last_four_digits="1111",
@first_six_digits="411111",
@card_type="visa",
@verification_value="",
@address1="",
@address2="",
@city="",
@state="",
@zip="",
@country="",
@phone_number="",
@company="",
@fingerprint="e3cef43464fc832f6e04f187df25af497994",
@eligible_for_card_updater="true",
@errors=[]>>
Please refer to using a payment method for more information on how to send GSFs