DDS Configurations
Learn about direct deposit switching (DDS) configurations.
Argyle Link initiates a direct deposit update when a DDS configuration is provided that has been encrypted to a payDistributionConfig. DDS configurations contain bank account and debit card details that determine which DDS screens are shown to users, and what pay allocations are suggested.
Refer to the structuring DDS configurations section of our direct deposit switching guide for more information.
bank_account
, card
, and card_source
objects are validated when they are passed to the /pay-distribution-configs/encrypt
endpoint. Learn more encryption validation below.
#The DDS configuration object
- Allocation related properties define the amount or percentage of money that is allocated to a bank account. Allocation fields do not apply to cards. Visit our direct deposit switching guide for which pay allocations to use for your use case.
- At least one
bank_account
orcard
/card_source
object must be specified in your DDS configuration.- At least one of
percent_allocation
oramount_allocation
object is required for partial paycheckbank_account
DDS configurations.
- At least one of
- Refer to add a bank and debit account in our direct deposit switching guide before including both
bank_account
andcard
in a single DDS configuration.
- #percent_allocationobject
An object representing a percentage to be transferred into the bank account.
If no
percent_allocation
object is provided, the user will not be able to enter a percent-based allocation. - #valuestringrequired
The default percent value that will be displayed to the user during the direct deposit update process.
value
is required apercent_allocation
object is included in the configuration. - #min_valuestring
The minimum percent value that the user will be able to input.
Set this to the same as
value
if you do not want the user to choose a lower percentage than your default value. - #max_valuestring
The maximum percent value that the user will be able to input.
Set this to the same as
value
if you do not want the user to choose a higher percentage than your default value. - #amount_allocationobject
An object representing a dollar amount to be transferred into the bank account.
If no
amount_allocation
object is provided, the user will not be able to enter a amount-based allocation. - #valuestringrequired
The default amount value that will be displayed to the user during the direct deposit update process.
value
is required aamount_allocation
object is included in the configuration. - #min_valuestring
The minimum amount value that the user will be able to input.
Set this to the same as
value
if you do not want the user to choose a lower amount than your default value. - #max_valuestring
The maximum amount value that the user will be able to input.
Set this to the same as
value
if you do not want the user to choose a higher amount than your default value. - #entire_allocationboolean
If included in the DDS configuration and set to
true
, the user's entire net pay will be assigned to the newly introduced allocation. Previous allocations will be removed.Default value is
false
. - #allow_editingboolean
If set to
true
, users will see the Edit button in the direct deposit update screen and will be able to change their allocations. If set tofalse
, users will not see the Edit button and will not be able to make any changes.Default value is
true
. - #default_allocation_type *DEPRECATEDstring
The allocation type that is presented to the user by default:
percent_allocation
oramount_allocation
.Not all employment accounts support both types. If you select a default that is not supported by the user's employment account, the user is still presented with an allocation of supported type as long the
percent_allocation
and/oramount_allocation
object is populated. - #bank_accountobjectThe object that contains bank account information for a pay allocation.
- #bank_namestringBank name that will be displayed alongside an obfuscated account number in Argyle Link. This is used for labeling purposes and does not need to perfectly match the actual bank name.
- #routing_numberstring9-digit code that is based on the bank location where the user's account was opened.
- #account_numberstring8 to 17-digit code that identifies the user as the account holder in the bank. The allocation will be sent to this account.
- #account_typestring
Type of the bank account.
- #cardobject
The object that contains card details for a pay allocation.
Argyle recommends populating every field in the card object when creating a DDS configuration for debit cards, including the optional fields. Doing so enables compatibility with all platforms that support adding debit cards.
- #card_numberstring8 to 19-digit payout card number as displayed on the card.required
- #cardholder_titlestringTitle of the person to which the card has been issued. This should be entered exactly as displayed on the card.
- #cardholder_first_namestringForename of the person to which the card has been issued.
- #cardholder_last_namestringSurname of the person to which the card has been issued.
- #card_namestring
Card name that is displayed alongside an obfuscated card number in Argyle Link. You can define
card_name
to label cards (e.g.My favorite card
). - #expiration_yearinteger ≥ 2000Expiration year as specified on the card.required
- #expiration_monthinteger between 1 and 12Expiration month as specified on the card.required
- #card_cvc_cvvstring3 or 4-digit security code found on the back of the card.required
- #address_line1stringAddress line 1—for example, street, PO Box, or company name.
- #address_line2stringAddress line 2—for example, apartment, suite, unit, or building.
- #statestringState, county, province, or region.
- #citystringCity, district, suburb, town, or village.
- #postal_codestringPostal code of the address associated with the card.
- #countrystring
Card's country of issue in ISO 3166-1 alpha-2 format.
- #card_sourceobject
The object that contains card details for a pay allocation when you are not PCI DSS compliant and are using a third-party to handle sensitive card details.
- #partnerstring
Denotes the third-party financial service provider that handles card data.
unit
is the only accepted value, but more may be added in the future. - #card_namestring
Card name that is displayed alongside an obfuscated card number in Argyle Link (e.g.
My favorite card
). You can definecard_name
to label cards. - #detailsobjectThe object that contains all required information used in authentication and data retrieval between Argyle's API and the third-party financial service provider.
- #idstring
The card identifier that is used to retrieve card details from Unit's database. Visit Unit's documentation on Cards for more information.
- #org_idstring
Identifies your organization in Unit's database. This ID is represented as
orgId
by Unit. Visit Unit's documentation on Partner API Tokens for more information.
Refer to DDS flows in our direct deposit switching guide for a full list of example DDS configuration objects and their associated use cases.
1{
2 "bank_account": {
3 "bank_name": "YellowHorizon",
4 "routing_number": "084101234",
5 "account_number": "9483746361234",
6 "account_type": "checking"
7 },
8 "entire_allocation": true,
9 "allow_editing": false
10}
1{
2 "card": {
3 "card_number": "4253177385403456",
4 "cardholder_title": "Mr",
5 "cardholder_first_name": "John",
6 "cardholder_last_name": "Doe",
7 "card_name": "Master Visa",
8 "expiration_year": 2030,
9 "expiration_month": 10,
10 "card_cvc_cvv": "900",
11 "address_line1": "759 Victoria Plaza",
12 "address_line2": "Unit 12",
13 "city": "Los Angeles",
14 "state": "CA",
15 "postal_code": "90210",
16 "country": "US"
17 }
18}
1{
2 "card_source": {
3 "partner": "unit",
4 "card_name": "My Unit payout card",
5 "details": {
6 "id": "ymp000f9",
7 "org_id": "lj93cqt2"
8 }
9 }
10}
1{
2 "bank_account": {
3 "bank_name": "YellowHorizon",
4 "routing_number": "084101234",
5 "account_number": "9483746361234",
6 "account_type": "checking"
7 },
8 "entire_allocation": true,
9 "allow_editing": false,
10 "card": {
11 "card_number": "4253177385403456",
12 "cardholder_title": "Mr",
13 "cardholder_first_name": "John",
14 "cardholder_last_name": "Doe",
15 "card_name": "Master Visa",
16 "expiration_year": 2030,
17 "expiration_month": 10,
18 "card_cvc_cvv": "900",
19 "address_line1": "759 Victoria Plaza",
20 "address_line2": "Unit 12",
21 "city": "Los Angeles",
22 "state": "CA",
23 "postal_code": "90210",
24 "country": "US"
25 }
26}
#Encrypt to payDistributionConfig
Encrypt a DDS configuration to a payDistributionConfig
.
- To start the direct deposit update process in Link you must initialize it with the
payDistributionConfig
parameter set to the encrypted string returned asencrypted_config
after encrypting your DDS configuration. - The encryption is necessary to ensure bank account and card details are never exposed on the front-end. Full routing, account, and card numbers always appear encrypted on the end user's device.
- To encrypt your DDS configuration make a POST request to
/pay-distribution-configs/encrypt
with your DDS configuration in the payload.
- #—objectDDS configuration (pre-encryption).required
1curl --request POST \
2 --url https://api.argyle.com/v1/pay-distribution-configs/encrypt \
3 --header 'accept: application/json' \
4 --header 'content-type: application/json' \
5 --data '{
6 "bank_account": {
7 "bank_name": "YellowHorizon",
8 "routing_number": "084101234",
9 "account_number": "9483746361234",
10 "account_type": "checking"
11 },
12 "amount_allocation": {
13 "value": "177",
14 "min_value": "177",
15 "max_value": "177"
16 }
17 }'
1{
2 "encrypted_config": "CiQAB/5leT7O7tuqZTNRlvgzuORNFdZu0tYaImtc7v5uTy5vBc0S4AQAL2UHl11enTB971I0t8Tx0U729+vnVIIX8splHDJijiiDEtcScd3W8b52FmFpg/IL3eHs7umRmd6JO8mvORDhBGQqF+x0XrZhzaZC4qB+ZiEs2rztEYGLMPgoYKegh7oKauNc9ZDf43l/KFDCYlYgW2Zd7LbB4M+PN39E8+GgMqHYTOKgpXFMYVBAniV8r58eu2PI9FV8sZ0JXRlOX2YTXAkEFC3XeX174olNQU4Eu1xlu+EPf61yCF1/UBvetVB7rSXMW/IcFrYkZCFVw+1YlDtGgk7uksStCB6ePuyWeu0/erjOitZidL5FwCx90OS0AEoMDqsXVQq+nyB+rCe2IAX9YFEL/xiWCB5gGXxzE+Y814WinVKq3YsSzsaMOhpKOpLfFuOb8YhQDzsq+OTlMx6W6RjOPSaqk29yQYWTDOaH37/iOABqnM8YWwbdz434KbuH02vo9gpS5Ny4MEyYTk5Uy0l8Z9rCce+/hUIRjqGNPQgim+kNwBp204V3tGX96fI/3JLwTeTUcmk4JrSK3G/LfDWQrxz+UYvxKO3BV56I6lvJcXMPrAlDGTzlxHOO9jUhSpBun0mU/gdbUXr9wunufZrb/Zc+4th+YCeVoBuwJ/TReBP8+fCfo0WQGXCX3wKGB5kl+PaoxRmTSrj24iSJLRCFTCygEeyW3/IFNK6/lCbYCLitJgLeOlz+oh+//1IDIrwj7f0h61ZQ15UdHqXBua0dJ/INxUjlUKyfmG8tMY5fCJaLLQkfhe/E0StQ8JdzYTbq2YGQIBfDuWCJpRbXYHQ40L7mQGXPDF+ocA=="
3}