Affirm-developers

Oracle Commerce Multiple Financing Programs

Overview

Multiple Financing Programs (MFPs) in Oracle Commerce (ATG) enables you to selectively offer a specific custom financing program to consumers based on product or category attributes in your catalog, and site-wide, time-based programs.

Financing program are defined by the following inputs:

Interest rate (APR) range

APR, or Annual Percentage Rate, is the cost of credit (i.e., interest) as a yearly rate.

Range of loan term lengths

The loan term length is the number of months that a customer has to repay the loan.

Merchant fee (MDR)

The merchant fee is a percentage of the purchase price that gets deducted from the settlements made to the merchant. 

How do I start using Multiple Financing Programs?

Financing programs are built by the Affirm Client Success team, and are specific to each merchant. If you'd like to start offering custom financing programs, please reach out to the Client Success team at [email protected]. Not all merchants qualify for custom financing programs.

Once your financing program has been created, you will be provided with a financing program ID and Promo ID by the Affirm Client Success team for your financing program(s). These IDs are utilized later in the sections below regarding the implementation of MFP. Affirm Promo ID displays correct terms in the Affirm marketing messages, monthly payment pricing and modal, while financing program value provides these terms during the checkout process.

Get started with MFP

Once you have received your financing program name from our Client Success team, you can setup the Affirm Magento extension to apply that program when certain conditions are met. There are some common examples illustrated below show for a given promotion which fields need to be populated, and the possible outcomes.

How are different rules ranked?

This chart illustrates the relative ranking of the financing programs that are defined in Magento:

RankingType of financing programOptions
1Product-levelInclusive
2Product-levelExclusive
3Category-levelInclusive
4Category-levelExclusive
5Cart-size
6Date
7Default

Financing programs

These are some common scenarios that illustrate which financing program would be chosen based on the products that are in cart.

Offer a financing program only for specific products

ScenarioCart item 1Cart item 2Program selected
Consumer picks out two products, one with an inclusive product-level program and one without a financing programProduct 1

- financing program = "zero_percent"
- inclusive
- priority 1
Product 3
Has no financing program
zero_percent
Consumer picks out one product, one with an exclusive product-level program.

This is the only scenario where this exclusive program is applied.
Product 2

- financing program = "zero_percent"
- exclusive
- priority 1
No productzero_percent
Consumer picks out two products, one with an exclusive product-level program, and one without a financing program.Product 2

- financing program = "zero_percent"
- exclusive
- priority 1
Product 8
has no financing program
none

Offer a financing program for a weekend

ScenarioCart item 1Cart item 2Program selected
- Consumer picks out products with no financing programs.

- Current date is inside the financing program's date range.

- (financing program = "zero_percent")
Product 1
no financing programs
Product 3
no financing programs
zero_percent
- Consumer picks out products with no financing programs.

- Current date is outside the financing program's date range.

- (financing program = "zero_percent")
Product 2
no financing programs
Product 2
no financing programs
none

Offer a financing program for an entire category of products**

ScenarioCart item 1Cart item 2Program selected
Consumer picks out two products, one with an inclusive product-level program and one without a financing programProduct 1

No financing program

Category 1

- financing program = "zero_percent"
- inclusive
- priority 1
Product 3

- no financing program

Category 1

no financing program
zero_percent
Consumer picks out one product, one with an exclusive product-level program.

This is the only scenario where this exclusive program is applied.
Product 2

No financing program

Category 1

- financing program = "zero_percent"
- exclusive
- priority 1
No productzero_percent
Consumer picks out two products, one with an exclusive product-level program, and one without a financing program.Product 2

no financing program

Category 1

- financing program = "zero_percent"
- exclusive
- priority 1
Product 8
has no financing program

Category 2

- financing program = "zero_percent"
- exclusive
- priority 1
none
Consumer picks out two category, one with an exclusive category-level program, and one without a financing program.Product 2

no financing program

Category 1

- financing program = "zero_percent"
- exclusive
- priority 1
Product 8

no financing program

Category 2

- financing program = "zero_percent"
- exclusive
- priority 1
zero_percent

Offer financing program on a weekend in addition to product-specific financing programs

These are some common scenarios that illustrate which financing program would be chosen based on the products that are in cart.

ScenarioCart item 1Cart item 2Program selected
Consumer picks out two category, one with an inclusive product-level program, and one no financing programs.

Current date is inside the financing program's date range.

(financing program = "zero_percent")
Product 2

- financing program = "zero_percent"
- inclusive
- priority 1
Product 8

- no financing program
zero_percent_plus
Customer selects two products, with an inclusive product-level program, and one no financing programs.

Current date is inside the financing program's date range.

(financing program = "zero_percent")
Product 2

- financing program = "zero_percent"
- exclusive
- priority 1
Product 8

- no financing program
zero_percent
Customer selects one product with an exclusive product-level program.

Current date is inside the financing program's date range.

(financing program = "zero_percent")
Product 2

- financing program = "zero_percent"
- exclusive
- priority 1
No productzero_percent_plus

Offer a financing program only for large carts, or for specific products

ScenarioCart item 1Cart item 2Program selected
Consumer picks out products with no financing programs.

Total cart amount is higher than the financing programs threshold.

(financing program = "zero_percent")
Product 1

no financing program
Product 3

no financing program
zero_percent
Consumer picks out products with no financing programs.

Total cart amount is lower than the financing programs threshold.

(financing program = "zero_percent")
Product 2

No financing program
Product 2

No financing program
none

Tutorial

Get the latest cartridge

  1. Installation instructions
  2. Create Rules

Create rules

Affirm Rules can be managed in the Oracle Commerce application. These are set up in the ProductCatalog repository. Affirm Rules can be created or edited in Oracle Commerce BCC: BCC -> Project_Name -> Affirm Rules. Depending on what the conditions are for a particular financing program, you will need to make edits to these areas of the Affirm Rules

Note: This assumes you already have been provided with a financing program ID and Promo ID. If you haven't received one, please contact us. Financing programs cannot be based on any other term or condition at this time.

Rule properties

The BCC-managed rules have the following properties:

Property nameDescription
Rule ID stringUsed internally by ATG and auto-generated. All items must have a unique ID.
Display Name stringAll rules are queried, and sorted by priority, and then evaluated one at a time. The first rule to match is used
Priority intThis is the value that is passed as the "data-promo-id" in the Javascript call to Affirm
Data promo ID stringThis is the Financing program id sent during checkout
Rule Type enumThis determines how the rule is evaluated. See below for details
Dollar Amount double This can be used with either product_amount or cart_total rule types, and sets the threshold for the rule to apply
Products listThe list of product repository items that a rule applies to. If "exclusive=true" then this option only applies if all products in the cart are in the list.
Category RepositoryItemThe category that a rule applies to. If "exclusive=true", then all items in cart must also be in this category.
Exclusive booleanf this is true, then a product must be the only item in the cart. If this is set on a category rule, then all other items in the cart must be children of that category. Default is set to "No"
Start Date timestampFor a time-based rule, the current date must be after the end date.
End Date timestampFor a time-based rule, the current date must be before the end date. If this is left blank, then there is no end date and the rule is assumed to remain valid indefinitely.

Rule Types

The following table shows the rule types:

TypeDescription
cart_totalThis type requires the Dollar amount field to be entered. A cart with a value higher than the "Dollar Amount" will qualify for this rule.
product_amountThis type requires the Dollar amount field to be entered. A product with a sale price higher than the "Dollar Amount" will qualify for this rule.
ProductIf the product passed in matches this product, and the rule is "inclusive", then the rule matches. If the rule is "exclusive" then there can not be any other products in the cart
CategoryIf the product passed in is a child of this category, and the rule has exclusive="false", then the rule matches. If the rule has exclusive="true", then the all items in the cart must also be children of this category.
TimeThe current time needs to be between the start and end date properties. If no end date is specified, the date only needs to be after the start date.

Site-wide financing programs:

1. Visit BCC -> Project_Name -> Affirm Rules
2. Add Affirm Rule and enter the properties:

  • Display Name (Ex: Site-wide Rules)
  • Affirm Program ID (financing_program ID provided by Affirm)
  • Data Promo ID (data-promo-id provided by Affirm)
  • Rule Type - product_amount
  • Dollar Amount - 50

3. Click Save

Date-range financing programs:

1. Visit BCC -> Project_Name -> Affirm Rules
2. Add Affirm Rule and enter the properties:

  • Display Name (Ex: Date between 10/4/2017 and 12/31/2017)
  • Affirm Program ID (financing_program ID provided by Affirm)
  • Data Promo ID (data-promo-id provided by Affirm)
  • Rule Type - time
  • Start Date
  • End Date

3. Click Save

Cart-size financing programs:

1. Visit BCC -> Project_Name -> Affirm Rules
2. Add Affirm Rule and enter the properties:

  • Display Name (Ex: Zero percent when cart is over $300)
  • Affirm Program ID (financing_program/MFP ID provided by Affirm)
  • Data Promo ID (data-promo-id provided by Affirm)
  • Rule Type - cart_total
  • Dollar Amount (Ex: 300)

3. Click Save

Category-level financing programs

Category-level financing programs will apply a financing program to a customer's cart when one or more items are from that category. The financing program could apply to the customer's entire cart, even items in the cart which may not qualify for a financing program on their own.

1. Visit BCC -> Project_Name -> Affirm Rules
2. Add Affirm Rule and enter the properties:

  • Display Name (Ex: Products in Accessories category)
  • Affirm Program ID (financing_program provided by Affirm)
  • Data Promo ID (data-promo-id provided by Affirm)
  • Rule Type - Category
  • Category - Select categories from the list

3. Click Save

Product-level financing programs:

Product-level financing programs will apply a financing program to a customer's cart when the product is included in the cart. The financing program will apply to the customer's entire cart, even items in the cart which may not qualify for a financing program on their own.

1. Visit BCC -> Project_Name -> Affirm Rules
2. Add Affirm Rule and enter the properties:

  • Display Name (Ex: Date between 10/4/2017 and 12/31/2017)
  • Affirm Program ID (financing_program provided by Affirm)
  • Data Promo ID (data-promo-id provided by Affirm)
  • Rule Type - Product
  • Product - Select products from the list

3. Click Save

If you have any questions about offering financing programs, please Contact us

Compliance with Consumer Protection Laws and Requirements

MFPs must comply with applicable federal, state, and local fair lending laws, regulations, and regulatory guidance. The purpose of fair lending standards is to ensure that individuals seeking financing are treated fairly and consistently. Generally, financing options must be offered to all qualified consumers without discrimination on the basis of race, color, religion, national origin, sex, marital status, age (provided that the applicant has the capacity to enter into a binding contract), the applicant's receipt of income through a public assistance program, the applicant's good faith exercise of a right under the federal Consumer Credit Protection Act, military status, sexual orientation, and other factors that may be prohibited under applicable state and local requirements. For example, merchants whose MFPs exclusively provide promotional pricing on items that appeal more to female customers than male customers may be found to be in non-compliance with fair lending requirements.

MFPs must also comply with the prohibitions in Title X of the Dodd-Frank Act and Section 5 of the Federal Trade Commission Act relating to unfair, deceptive, and abusive acts or practices. In essence, terms and conditions of financing programs must be clearly and accurately communicated to consumers.

Affirm reserves the right to request modifications to a financing program if it determines that the program may run afoul with applicable consumer protection requirements. Violating any applicable consumer protection requirement is a breach of your agreement with Affirm and can be grounds for termination as an Affirm merchant (and may result in legal action).

Reporting

In your settlement reports, we will include the financing program name that was active for a given transaction.

Updated 5 months ago


Oracle Commerce Multiple Financing Programs


Suggested Edits are limited on API Reference Pages

You can only suggest edits to Markdown body content, but not to the API spec.