SafeCharge Gateway Guide

close

Services and Compatibility

Payment Gateway Company Name:
SafeCharge
Services that work with Spreedly:
  • SafeCharge
Supported operations:
Purchase, Authorize, Capture, Refund, Void, Verify, General Credit
Supported payment types:
Credit Card
Does Spreedly support 3D Secure with this gateway?
Partially
Regions:
Europe, North America

Authentication and Security

Specific names for credentials:
Client Login, Client Password

Onboarding Merchants in:

Adding a SafeCharge Gateway

To add a SafeCharge gateway:


curl https://core.spreedly.com/v1/gateways.xml \
  -u 'C7cRfNJGODKh4Iu5Ox3PToKjniY:4UIuWybmdythfNGPqAqyQnYha6s451ri0fYAo4p3drZUi7q2Jf4b7HKg8etDtoKJ' \
  -H 'Content-Type: application/xml' \
  -d '<gateway>
        <gateway_type>safe_charge</gateway_type>
        <client_login_id>Your login</client_login_id>
        <client_password>Your password</client_password>
      </gateway>'

<gateway>
  <token>R3WBT9usBm6nCITJKfwGkbWx9fw</token>
  <gateway_type>safe_charge</gateway_type>
  <name>SafeCharge</name>
  <description nil="true"/>
  <client_login_id>Your login</client_login_id>
  <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">true</supports_general_credit>
    <supports_void type="boolean">true</supports_void>
    <supports_verify type="boolean">true</supports_verify>
    <supports_reference_purchase type="boolean">true</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">true</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>client_login_id</name>
      <value>Your login</value>
    </credential>
  </credentials>
  <gateway_specific_fields>
    <gateway_specific_field>user_id</gateway_specific_field>
    <gateway_specific_field>auth_type</gateway_specific_field>
    <gateway_specific_field>expected_fulfillment_count</gateway_specific_field>
    <gateway_specific_field>website_id</gateway_specific_field>
    <gateway_specific_field>vendor_id</gateway_specific_field>
    <gateway_specific_field>merchant_descriptor</gateway_specific_field>
    <gateway_specific_field>merchant_phone_number</gateway_specific_field>
    <gateway_specific_field>merchant_name</gateway_specific_field>
    <gateway_specific_field>stored_credential_mode</gateway_specific_field>
  </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">2018-06-19T17:07:35Z</created_at>
  <updated_at type="dateTime">2018-06-19T17:07:35Z</updated_at>
</gateway>


env = Spreedly::Environment.new('C7cRfNJGODKh4Iu5Ox3PToKjniY', '4UIuWybmdythfNGPqAqyQnYha6s451ri0fYAo4p3drZUi7q2Jf4b7HKg8etDtoKJ', base_url: 'https://core.spreedly.com')
env.add_gateway(:safe_charge, client_login_id: "Your login", client_password: "Your password")


#<Spreedly::Gateway:0x007ffce4b56b00
@token="IFmcml8uRYlhKWwk6ZOxOHvJv9n",
@created_at="2017-09-29T07:15:00Z",
@updated_at="2017-09-29T07:15:00Z",
@gateway_type="safe_charge",
@state="retained",
@name="SafeCharge",
@credentials={"client_login_id"=>"Your login"}>

Optional Gateway Specific Fields

When interacting with a SafeCharge gateway to run transactions, there are several gateway specific field you can specify.

  • When making a transaction, you can specify user_id; this maps to the gateway’s UserID field.
  • When making an authorize call you can specify auth_type and expected_fulfillment_count; these parameters map to sg_AuthType (to trigger the pre-authorization transaction type) and sg_ExpectedFulfillmentCount respectively.
  • When making any call, you may specify website_id and vendor_id, which correspond to sg_WebsiteID and sg_VendorID, respectively.
  • When making a purchase, authorize, or credit you can specify stored_credential_mode as true or false. When specified as true, the transaction will be flagged as completed using a previously tokenized and stored card data. Specify false when the card data was entered for the first time, which will be tokenized and stored for future transactions.
  • When making any call, you may specify merchant_descriptor, merchant_phone_number, and merchant_name. These fields are part of SafeCharge’s Dynamic Descriptor service and may used to display information on a customer’s credit card statement.

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>
          <safe_charge>
            <user_id>123</user_id>
            <auth_type>1</auth_type>
            <expected_fulfillment_count>12</expected_fulfillment_count>
            <merchant_descriptor>Descriptor</merchant_descriptor>
            <merchant_phone_number>(555)555-5555</merchant_phone_number>
            <merchant_name>Merchant</merchant_name>
            <stored_credential_mode>true</stored_credential_mode>
          </safe_charge>
        </gateway_specific_fields>
      </transaction>'

<transaction>
  <on_test_gateway type="boolean">true</on_test_gateway>
  <created_at type="dateTime">2018-04-25T16:51:05Z</created_at>
  <updated_at type="dateTime">2018-04-25T16:51:05Z</updated_at>
  <succeeded type="boolean">true</succeeded>
  <state>succeeded</state>
  <token>JlScKStQxqlEFV0bLU7o7Wi4udb</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"/>
  <gateway_specific_fields>
    <safe_charge>
      <user_id>123</user_id>
      <auth_type>1</auth_type>
      <expected_fulfillment_count>12</expected_fulfillment_count>
      <merchant_descriptor>Descriptor</merchant_descriptor>
      <merchant_phone_number>(555)555-5555</merchant_phone_number>
      <merchant_name>Merchant</merchant_name>
      <stored_credential_mode>true</stored_credential_mode>
    </safe_charge>
  </gateway_specific_fields>
  <gateway_specific_response_fields>
  </gateway_specific_response_fields>
  <gateway_transaction_id>49</gateway_transaction_id>
  <gateway_latency_ms type="integer">4</gateway_latency_ms>
  <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>
  <message key="messages.transaction_succeeded">Succeeded!</message>
  <gateway_token>ESkKCzXVwkdZnZ7Y5ed9cbSR7D4</gateway_token>
  <gateway_type>test</gateway_type>
  <shipping_address>
    <name>Kory Hauck</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></error_code>
    <error_detail nil="true"/>
    <cancelled type="boolean">false</cancelled>
    <fraud_review nil="true"/>
    <created_at type="dateTime">2018-04-25T16:51:05Z</created_at>
    <updated_at type="dateTime">2018-04-25T16:51:05Z</updated_at>
  </response>
  <api_urls>
  </api_urls>
  <payment_method>
    <token>XNEtlBSKOyvIpL96euioRt8F9FX</token>
    <created_at type="dateTime">2018-04-25T14:40:02Z</created_at>
    <updated_at type="dateTime">2018-04-25T15:56:43Z</updated_at>
    <email nil="true"/>
    <data nil="true"/>
    <storage_state>retained</storage_state>
    <test type="boolean">true</test>
    <last_four_digits>1111</last_four_digits>
    <first_six_digits>411111</first_six_digits>
    <card_type>visa</card_type>
    <first_name>Kory</first_name>
    <last_name>Hauck</last_name>
    <month type="integer">4</month>
    <year type="integer">2020</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>Kory Hauck</full_name>
    <eligible_for_card_updater nil="true"/>
    <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 nil="true"/>
  </payment_method>
</transaction>