# Payment Plans

Payment plans allow customers to pay down their debt in recurring fashion. You can create payment plan by passing payment_plan parameters when creating a Debt Account.

# Payment Plan

Once a Payment Plan is created for a Debt Account, it will be attached to the resource.

{
  "id": "1234-5678-1234",
  "frequency": "weekly",
  "start_date": "2021-01-01",
  "amount": 1000,
  "rules": {
    "unscheduled_payment_plan_editable": false
  },
  "charges": [{
    "charge_date": "ISO8601",
    "amount": 1000,
    "scheduled": false,
    "charged_at": "ISO8601"
  },...]
}

charges

Charges associated with payment plan. Once customer agrees on Payment Plan, scheduled will be updated to true. Successful charge will be updated with charged_at datetime.

Charges for a payment plan will become available once the customer is enrolled in the plan.

# Create Payment Plan Request

You can create a payment plan request that notifies Customer via sms or email about the request. Message is send using the phone number or email set up through Console and contains a Customer Session link to the Collect.

POST https://<org-uuid>.production.tratta.io/api/v1/payment-plans/request

curl https://<org-uuid>.production.tratta.io/api/v1/payment-plans/request \
 -H "Authorization: Bearer eyJ0eXA3asdk..." \
 -d type="email" \
 -d debt_account_external_id="123456" \
 -d frequency="weekly" \
 -d start_date="2023-03-01" \
 -d min_payment_amount="700" \
 -d email="example@example.com" \
 -X POST

# Parameters


type sometimes|in:sms,email

The type parameter specifies the mode of the message and accepts two possible values: sms or email. It is an optional parameter and can be omitted if message delivery is not required.

It can be set as:

  • sms: The message will be sent via text message to the recipient's phone number.
  • email: The message will be sent to the recipient's email address.

email sometimes

The email parameter is required only when the type parameter is set to email.

phone sometimes

The phone parameter is required only when the type parameter is set to phone.

frequency required|string

Specified the periodicity of payments.

Supported frequencies:

  • weekly
  • every_other_week
  • monthly
  • last_of_month

start_date required|date

It must be a date at least 1 day after enrollment and within the number of days defined in the payment_plan_max_days_until_start_date rule, which defaults to 31.

min_payment_amount sometimes|numeric

It specifies minimum amount for a payment.

expiration_date sometimes|date

It's required for a customer session link when the type parameter is present. This parameter sets an expiration date for the session link, after which it becomes invalid and cannot be used.

# Other validations


# Create and Enroll Payment Plan with Payment Method

You can create and scheduled payment plan in a single request.

POST https://<org-uuid>.production.tratta.io/api/v1/payment-plans

curl https://<org-uuid>.production.tratta.io/api/v1/payment-plans \
 -H "Authorization: Bearer eyJ0eXA3asdk..." \
 -d debt_account_external_id="123456" \
 -d amount="700" \
 -d frequency="weekly" \
 -d start_date="2023-03-01" \
 -d scheduled_at="2023-03-01" \
 -d email="example@example.com" \
 -d card[card_holder]="Card Holder" \
 -d card[card_number]="4242424242424242" \
 -d card[card_expiration_month]="12" \
 -d card[card_expiration_year]="23" \
 -d card[card_security_code]="123" 
 -X POST

# Parameters


frequency required|string

Specified the periodicity of payments.

Supported frequencies:

  • weekly
  • every_other_week
  • monthly
  • last_of_month

start_date required|date

It must be a date at least 1 day after enrollment and within the number of days defined in the payment_plan_max_days_until_start_date rule, which defaults to 31.

amount required|numeric

The amount of single payment plan payment.

debt_account_external_id required without no account|exists

External debt account id generated in the 3rd party application.

linked_debt_account optional|boolean

Specifies whether the transaction should be associated with a specific debt account or not. It allows you to process a charge without linking it to a particular debt account in the system. If you pass debt_account_external_id with linked_debt_account=false then it will create a charge without linking it to an debt account.

email optional|email

Email address of the customer.

send_email optional|boolean

Specifies whether or not to send the confirmation email to the customer.

payment_method_id required without card/ach|exists

Specifies the UUID of the existing payment method.

card json object with paramters

  • card_holder required without payment_method_id/ach
  • card_number required without payment_method_id/ach|valid card number
  • card_expiration_month required without payment_method_id/ach|numeric|between:1,12
  • card_expiration_year required without payment_method_id/ach|last 2 digits of a year
  • card_security_code optional
  • card_postal_code optional|5 digits

ach json object with parameters

  • account_holder required without payment_method_id/card

  • account_type required without payment_method_id/card|in:checking, savings

    Checking or Savings account type.

  • routing_number required without payment_method_id/card|valid routing number

  • account_number required without payment_method_id/card|min:4|max:17

  • account_zip required without payment_method_id/card|5 digits

    Specifies the Postal code of the account.

  • account_state required without payment_method_id/card

billing_address_id optional|exists

Specifies the UUID of the billing address.

billing_address json object with parameters

  • name optional|string
  • city optional|string
  • state optional|string
  • postal_code required with billing address object|5 digits
  • country optional|string
  • line1 optional|string
  • line2 optional|string
  • is_primary optional|boolean

# Other validations


# Returns

A json with data property that contains created payment-plan object.

{
  "id": "1234-5678-1234",
  "frequency": "weekly",
  "start_date": "2021-01-01",
  "amount": 1000,
  "rules": {
    "unscheduled_payment_plan_editable": false
  },
  "charges": [{
    "charge_date": "ISO8601",
    "amount": 1000,
    "scheduled": false,
    "charged_at": "ISO8601"
  },...]
}

# Get Payment Plan

GET https://<org-uuid>.production.tratta.io/api/v1/payment-plans/{payment-plan-uuid}

curl https://<org-uuid>.production.tratta.io/api/v1/payment-plans/{payment-plan-uuid} \
 -H "Authorization: Bearer eyJ0eXA3asdk..."

# Update Payment Plan

If payment plan doesn't have any scheduled charges and the rule unscheduled_payment_plan_editable is set to true it can be edited.

PUT https://<org-uuid>.production.tratta.io/api/v1/payment-plans/{payment-plan-uuid}

curl https://<org-uuid>.production.tratta.io/api/v1/payment-methods/{payment-method-uuid} \
 -H "Authorization: Bearer eyJ0eXA3asdk..." \
 -d frequency="weekly" \
 -d start_date="2021-01-01" \
 -d amount="700"
 -X PUT

# Parameters


frequency required|string

Specified the periodicity of payments.

Supported frequencies:

  • weekly
  • every_other_week
  • monthly
  • last_of_month

start_date required|date

It must be a date at least 1 day after enrollment and within the number of days defined in the payment_plan_max_days_until_start_date rule, which defaults to 31.

amount required|numeric

The amount of single payment plan payment.

# Returns

A json with data property that contains created payment-plan object.

{
  "id": "1234-5678-1234",
  "frequency": "weekly",
  "start_date": "2021-01-01",
  "amount": 1000,
  "rules": {
    "unscheduled_payment_plan_editable": false
  },
  "charges": [{
    "charge_date": "ISO8601",
    "amount": 1000,
    "scheduled": false,
    "charged_at": "ISO8601"
  },...]
}

# Update Payment Plan Status

PATCH https://<org-uuid>.production.tratta.io/api/v1/payment-plans/{payment-plan-uuid}/status

curl https://<org-uuid>.production.tratta.io/api/v1/payment-plans/{payment-plan-uuid}/status \
 -H "Authorization: Bearer eyJ0eXA3asdk..." \
 -d status="canceled" \
 -X PATCH

# Parameters


status required|in:canceled

Supported statuses:

  • canceled

# Returns

A json with data property that contains created payment-plan object.

{
  "id": "1234-5678-1234",
  "frequency": "weekly",
  "start_date": "2021-01-01",
  "amount": 1000,
  "rules": {
    "unscheduled_payment_plan_editable": false
  },
  "charges": [{
    "charge_date": "ISO8601",
    "amount": 1000,
    "scheduled": false,
    "charged_at": "ISO8601"
  },...]
}

# Delete Payment Plan

DELETE https://<org-uuid>.production.tratta.io/api/v1/payment-plans/{payment-plan-uuid}

curl https://<org-uuid>.production.tratta.io/api/v1/payment-plans/{payment-plan-uuid} \
 -H "Authorization: Bearer eyJ0eXA3asdk..."

# Returns

{
  "success": "boolean"
}