Accept card payments
Linking a card to a Moov account automatically verifies the card details with the card networks. This process verifies the existence of the card account and returns information about the Address Verification Service (AVS) and Card Verification Value (CVV) checks that occur.
Some examples of card acceptance use cases include:
- An e-commerce platform that allows buyers and sellers to transact
- A software-as-a-service (SaaS) platform connecting service providers with clients
- A utility or subscription based company looking to allow their customers different payment options
Link card to Moov account
You can use the pre-built card link Drop, or if you’ve submitted an attestation of PCI compliance to Moov, you can link cards directly through the API. If you opt for the API method, you’ll be responsible for storing and handling card data.
Save a card for future use
Before you link a card, consider whether the card should be saved on file to use Moov’s card account updater service. This can be done by setting cardOnFile
to true when linking a card. If nothing is passed to cardOnFile
, or you set it to false, the card will not automatically update card number and expiration date information. If a card becomes out of date, it will not work for future payments.
If you set the cardOnFile
flag to true, the merchantAccountID
(Moov account ID of a merchant on your platform) provided should signify which merchant the cardholder has consented to save their information. The account associated with the merchantAccountID
will incur fees for successful card updates using Moov’s card account updater.
If you leave the merchantAccountID
field blank while saving a card on file, the system will default to your platform’s account ID, indicating the cardholder’s relationship with your platform’s brand. You can update the merchantAccountID
at any time using the update card PATCH
endpoint.
Drop
The simplest way to securely collect sensitive card details is by using the card link Drop, a prebuilt UI component for embedding card-based payments. By using the card link Moov Drop, you’ll send card data directly to Moov’s PCI-compliant card vault, and the information will not touch your servers.
Once the information has been submitted via the Drop, Moov verifies the card details with card networks.
|
|
API & SDKs
Link a card using our API, or Go or Node SDKs. If you set the optional X-Wait-For
header to payment-method
, the response will include any payment methods that were created for the newly linked card in the paymentMethods
field.
|
|
|
|
|
|
Card verification
When a card is linked, Moov performs a verification with the relevant card network to confirm that the card account is open and valid. Additionally, the verification checks if the CVV and address match the information on file with the card issuer.
The merchantAccountID
is used to pass merchant information during card verification. Although these verification transactions are rarely visible to cardholders, when they are, it’s crucial that cardholders recognize the merchant associated with the verification so they know it’s not fraudulent.
merchantAccountID
during card verification, it’s not mandatory. If you omit this field, the system defaults to your platform’s account ID.
It is possible the verification request will be declined by the card issuer. Decline information is provided in the response body of the 422
error. Errors could be validation errors, such as an invalid card number, or actual declines from the card issuer. Below is an example of a card issuer decline.
|
|
Submit the card payment
The customer’s card will be the source of funds, so Moov needs the card-payment
payment method from their account. You can obtain the paymentmethodID
from the payment methods GET
endpoint. The sourceID
should be the cardID
, which you can get from the cards GET
endpoint.
Since the merchant’s wallet will be the destination of the funds, we will need the moov-wallet
payment method. You can obtain the paymentmethodID using the payment methods GET
endpoint and finding the moov-wallet
payment method associated with the merchant account.
To submit the card payment, create a transfer from the cardholder (source) to the merchant (destination).
|
|
|
|
Card-based payments first settle in a Moov wallet. The funds can later be moved to an external bank account through a disbursement transfer.
X-Wait-For
header in the request, you will get a synchronous response that includes full transfer and rail-specific details from the payment network. This is useful for when a user is clicking a button to make a payment and needs a synchronous response so they can get confirmation that it worked. If you omit the X-Wait-For
header, you will get an asynchronous response that only includes the transferID and the timestamp for when the transfer was created.
Check status
After a transfer is created, it will be pending
until the funds are disbursed to the destination moov-wallet
. Funds typically settle and become available by the end of the next business day. You can check the status of the transfer anytime using the GET
endpoint.
You can also see card specific status details in the response within the source.cardDetails
object.
|
|
Access funds
Once the payment has been processed and the funds are available, the funds can be moved out of the merchant moov-wallet
using another transfer where that wallet is the source. Bank holidays may delay the availability of funds.
Cardholder disputes
As the main account holder, you are responsible for notifying impacted merchants of any incoming disputes. You can receive notifications about incoming disputes by setting up the dispute.updated
webhook. Read our webhooks guide for more information.
If you receive a 202
response from creating a transfer, do not consider the transfer as successful or failed. Instead, you should wait for the webhook notification to determine the status of the transfer, or subsequently look up the transfer status using the transferID
. Read more on our transfer responses guide.
Reverify a card
You can use the update a card PATCH
endpoint to update and re-verify certain information about the card. The cardID
is the ID of the card you want to update, and the accountID
represents the Moov account that the card is linked to.
|
|
Optional request data:
Field | Type | Description |
---|---|---|
expiration |
object | The card’s expiration month and year |
cardCvv |
string | The card’s CVV number |
billingAddress |
object | The billing address associated with the card |
Note that when performing a PATCH
on an existing card, Moov will perform another CVV verification request to the card networks using the new information provided. If the new verification is declined by the card issuer, the previously linked card will not be affected. If the verification succeeds, the card record will be updated with the new information.
Refer to the cardVerification{}
object in the response to see if the new CVV information is correct.
|
|
Best practices
Some card issuers display alerts or notifications about card verifications to cardholders. Being transparent and recognizable prevents accidental suspicion.
Include as much complete and accurate data as possible to comply with card brand rules and mandates, optimize card authorization rates, prevent interchange downgrades, and increase defensibility against chargebacks. Consider the following best practices:
- Street address: Send the optional
addressLine1
inbillingAddress
. For most situations, Moov recommends sending the address so that full address verification can take place. Not includingaddressLine1
may impact approval rates, cause interchange downgrades, and impact chargeback win rate. - Card verification: Always include
merchantAccountID
when performing a card verification. This provides context to the cardholder if the verification transaction becomes visible. - Save a card on file: If you’re saving a card for future use, specify
merchantAccountID
and set thecardOnFile
flag to true. This indicates the cardholder’s relationship with the merchant, and their consent to save their card details for future transactions.