AML Integration Guide
Reduce settlement delays and enhance compliance for international payments with Razorpay’s AML solutions.
Razorpay offers two Anti-Money Laundering (AML) solutions—Basic AML and Smart AML—designed to help businesses reduce settlement delays and minimise compliance-related transaction flags. Our risk prediction engine analyses historical transaction data and regulatory signals to accurately identify potential risks, reducing AML flags by up to 90% while maintaining compliance standards.
- Reduced AML Hits: Up to 90% reduction in flagged transactions with proper implementation.
 - Faster Settlements: Minimise manual reviews and accelerate fund availability.
 - Flexible Integration: Choose between Basic AML for simplicity or Smart AML for intelligent risk management.
 - Improved Conversion: Collect additional details only when necessary, reducing customer friction.
 - Regulatory Compliance: Automatically meet RBI requirements for high-value transactions.
 
Basic AML enables you to proactively provide additional customer information with every order, thereby reducing the likelihood that it will be flagged for AML review.
You need to pass a few additional parameters related to AML in the Orders API. There is no other change in the rest of the
.curl -u [YOUR_KEY_ID]:[YOUR_KEY_SECRET] \-X POST https://api.razorpay.com/v1/orders \-H "Content-Type: application/json" \-d '{"amount": 10000,"currency": "","receipt": "receipt#1","customer_id": "cust_OwZZseNBf9Uqsi","customer_details": {"business_type": "individual","name": " Nur Aisyah","email": "nur.aisyah@example.com","contact": "+60123456789","individual": {"date_of_birth": {"day": 27,"month": 11,"year": 1993},"place_of_birth": "Bengaluru","tax_identity": [{"name": "PAN","value": "ABCDE1234F"}]}}}'
{"amount": 10000,"amount_due": 10000,"amount_paid": 0,"attempts": 0,"created_at": 1703569876,"currency": "INR","entity": "order","id": "order_NGrgEcmYJsfUyl","notes": {"key1": "value3","key2": "value2"},"offer_id": null,"receipt": "receipt#1","status": "created"}
amount
mandatory
integer The amount for which the order was created, in currency subunits. For example, for an amount of RM 295.00, enter 29500. Payment can only be made for this amount against the Order.
currency
mandatory
string ISO code for the currency in which you want to accept the payment. The default length is 3 characters. For example, INR.
receipt
optional
string Receipt number that corresponds to this order, set for your internal reference. Can have a maximum length of 40 characters and has to be unique.
customer_id
mandatory
string Unique identifier of the customer. For example, cust_1Aa00000000004.
customer_details
mandatory
object This contains details about the customer.
business_type
optional
string Indicates whether the customer is an individual or business entity. Possible values:
- 
company - 
individualWatch Out!
For transactions exceeding ₹2,50,000:
- Individual customers: PAN is mandatory.
 - Business customers: GSTIN is mandatory.
 
 
name
mandatory
string Customer's name.
- Character length: Between 5 and 50 characters.
 - Allowed characters: Uppercase letters (A-Z), lowercase letters (a-z), and spaces (not at the beginning).
 - Not allowed characters: Numbers, special characters (For example, @, ", ,, ., and so on.), Unicode characters, emojis, and non-Latin scripts or regional languages.
 - Prohibited names: Names must be meaningful and contextually appropriate.
- Avoid using repetitive patterns (For example, aaa, xyz, kkk kk).
 - Names like litri litri, Hfg Gh, or husi husi are not permitted.
 - Curse words or offensive names are not prohibited.
 
 - Example: 
Gaurav Kumar. 
optional
string The customer's email address. A maximum length of 64 characters for the username. For example, in "
contact
optional
string The customer's phone number. A maximum length of 15 characters including country code. For example, +919123456780.
individual
object Required when business_type is individual.
date_of_birth
object Customer's date of birth (individuals) or date of incorporation (businesses).
day
integer Day of birth/incorporation (1-31).
month
integer Month of birth/incorporation (1-12).
year
integer Year of birth/incorporation (4-digit format).
place_of_birth
string Place where the customer was born or place of incorporation for businesses.
tax_identity
array List of tax identifiers.
name
string Type of tax identifier.
value
string The identifier value matching the expected format.
amount
integer The amount for which the order was created, in currency subunits. For example, for an amount of RM 295.00, enter 29500.
amount_due
integer The amount pending against the order.
amount_paid
integer The amount paid against the order.
attempts
integer The number of payment attempts, successful and failed, that have been made against this order.
created_at
integer Indicates the Unix timestamp when this order was created.
currency
string ISO code for the currency in which you want to accept the payment. The default length is 3 characters.
entity
string Name of the entity. Here, it is order.
id
string The unique identifier of the order.
notes
object Key-value pair used to store additional information about the entity. Holds 15 key-value pairs, 256 characters (maximum) each. For example, "note_key": "Beam me up Scotty”.
offer_id
string The unique identifier of the offer. For example, offer_JHD834hjbxzhd38d.
receipt
string Receipt number that corresponds to this order. Can have a maximum length of 40 characters and has to be unique.
status
string The status of the order. Possible values:
created: When you create an order, it is in thecreatedstate. It stays in this state till a payment is attempted on it.attempted: An order changes to theattemptedstate following the first payment attempt and remains in this state until at least one payment is successfully processed and captured.paid: After the successful capture of the payment, the order moves to thepaidstate. No further payment requests are permitted once the order moves to thepaidstate.
The order stays in thepaidstate even if the payment associated with the order is refunded.
Smart AML applies real-time risk assessment to determine whether additional customer information is required. It ensures minimal friction for low-risk transactions while maintaining strong compliance standards.
Smart Screening allows you to receive risk assessments and decide whether to proceed, collect additional data or decline transactions based on your business logic.
- Create Order with AML screening.
 - Fetch Order With Updated Risk Assessment (optional).
 - Patch Order (If High Risk).
 - Create a Payment.
 
Enable real-time risk assessment in your S2S integration:
curl -u [YOUR_KEY_ID]:[YOUR_KEY_SECRET] \-X POST https://api.razorpay.com/v1/orders \-H "Content-Type: application/json" \-d '{"amount": 10000,"currency": "","receipt": "receipt#1","customer_id": "cust_OwZZseNBf9Uqsi","reviews": {"screening": ["aml"]},"customer_details": {"name": " Nur Aisyah","email": "nur.aisyah@example.com","contact": "+60123456789","billing_address": {"line1": "Mantri apartment","line2": "Koramangala","city": "Bengaluru","country": "IND","state": "Karnataka","zipcode": "560032"},"shipping_address": {"line1": "Mantri apartment","line2": "Koramangala","city": "Bengaluru","country": "IND","state": "Karnataka","zipcode": "560032"}}}'
{"id": "order_EKwxwAgItmmXdp","entity": "order","amount": 10000,"amount_paid": 0,"amount_due": 10000,"currency": "","receipt": "receipt#1","offer_id": null,"status": "created","attempts": 0,"notes": [],"created_at": 1582628071,"reviews": {"entity": "collection","count": 1,"items": [{"screening": "aml","risk_tier": "high","risk_factors_count": 1,"risk_factors": [{"reason": "name_match_sanction_list","description": "Please share date of birth for better AML precision","source": "customer_details.name"}]}]}}
amount
mandatory
integer The amount for which the order was created, in currency subunits. For example, for an amount of RM 295.00, enter 29500. Payment can only be made for this amount against the Order.
currency
mandatory
string ISO code for the currency in which you want to accept the payment. The default length is 3 characters. For example, INR.
receipt
optional
string Receipt number that corresponds to this order, set for your internal reference. Can have a maximum length of 40 characters and has to be unique.
customer_id
mandatory
string Unique identifier of the customer. For example, cust_1Aa00000000004.
reviews
optional
object Contains risk assessment features.
screening
optional
array Types of risk screening to perform. For example aml.
customer_details
mandatory
object This contains details about the customer.
name
mandatory
string Customer's name.
- Character length: Between 5 and 50 characters.
 - Allowed characters: Uppercase letters (A-Z), lowercase letters (a-z), and spaces (not at the beginning).
 - Not allowed characters: Numbers, special characters (For example, @, ", ,, ., and so on.), Unicode characters, emojis, and non-Latin scripts or regional languages.
 - Prohibited names: Names must be meaningful and contextually appropriate.
- Avoid using repetitive patterns (For example, aaa, xyz, kkk kk).
 - Names like litri litri, Hfg Gh, or husi husi are not permitted.
 - Curse words or offensive names are not prohibited.
 
 - Example: 
Gaurav Kumar. 
optional
string The customer's email address. A maximum length of 64 characters for the username. For example, in "
contact
optional
string The customer's phone number. A maximum length of 15 characters including country code. For example, +919123456780.
billing_address
mandatory
object This contains the billing address of the order.
line1
mandatory
string Address Line 1 of the address.
- Character length: Must be between 3 and 100 characters.
 - Allowed characters: Uppercase letters (A-Z), lowercase letters (a-z), numbers (0-9), spaces, and special characters (*&/-()#_+[]:'".,.).
 - Not allowed characters: Regional languages.
 
line2
mandatory
string Address Line 2 of the address.
- Character length: Must be between 3 and 100 characters.
 - Allowed characters: Uppercase letters (A-Z), lowercase letters (a-z), numbers (0-9), spaces, and special characters (*&/-()#_+[]:'".,.).
 - Not allowed characters: Regional languages.
 
city
mandatory
string Name of the city. Must be between 3 and 50 characters in length and can only include uppercase (A-Z) and lowercase (a-z) English letters, and spaces.
country
mandatory
string ISO3 country code of the billing address. Only IND is allowed.
state
mandatory
string Name of the state. It must be between 3 and 50 characters extended and can only include uppercase (A-Z) and lowercase (a-z) English letters and spaces. Please send the full name of the state, for example, Madhya Pradesh.
zipcode
mandatory
string The ZIP code must consist of 6-digit numeric characters. Only valid Indian ZIP codes will be accepted. Refer to the 
latitude
optional
float Latitude of the position expressed in decimal degrees (WSG 84), for example, 6.244203. A positive value denotes the northern hemisphere or the equator, and a negative value denotes the southern hemisphere. The number of digits to represent the precision of the coordinate.
longitude
optional
float Longitude of the position expressed in decimal degrees (WSG 84), for example, -75.581211. A positive value denotes east longitude or the prime meridian, and a negative value denotes west longitude. The number of digits to represent the precision of the coordinate.
shipping_address
mandatory
object This contains the shipping address of the order.
line1
mandatory
string Address Line 1 of the address.
- Character length: Must be between 3 and 100 characters.
 - Allowed characters: Uppercase letters (A-Z), lowercase letters (a-z), numbers (0-9), spaces, and special characters (*&/-()#_+[]:'".,.).
 - Not allowed characters: Regional languages.
 
line2
mandatory
string Address Line 2 of the address.
- Character length: Must be between 3 and 100 characters.
 - Allowed characters: Uppercase letters (A-Z), lowercase letters (a-z), numbers (0-9), spaces, and special characters (*&/-()#_+[]:'".,.).
 - Not allowed characters: Regional languages.
 
city
mandatory
string Name of the city. Must be between 3 and 50 characters in length and can only include uppercase (A-Z) and lowercase (a-z) English letters, and spaces.
country
mandatory
string ISO3 country code of the billing address. Only IND is allowed.
state
mandatory
string Name of the state. It must be between 3 and 50 characters extended and can only include uppercase (A-Z) and lowercase (a-z) English letters and spaces. Please send the full name of the state, for example, Madhya Pradesh.
zipcode
mandatory
string The ZIP code must consist of 6-digit numeric characters. Only valid Indian ZIP codes will be accepted. Refer to the 
latitude
optional
float Latitude of the position expressed in decimal degrees (WSG 84), for example, 6.244203. A positive value denotes the northern hemisphere or the equator, and a negative value denotes the southern hemisphere. The number of digits to represent the precision of the coordinate.
longitude
optional
float Longitude of the position expressed in decimal degrees (WSG 84), for example, -75.581211. A positive value denotes east longitude or the prime meridian, and a negative value denotes west longitude. The number of digits to represent the precision of the coordinate.
amount
integer The amount for which the order was created, in currency subunits. For example, for an amount of RM 295.00, enter 29500.
amount_due
integer The amount pending against the order.
amount_paid
integer The amount paid against the order.
attempts
integer The number of payment attempts, successful and failed, that have been made against this order.
created_at
integer Indicates the Unix timestamp when this order was created.
currency
string ISO code for the currency in which you want to accept the payment. The default length is 3 characters.
entity
string Name of the entity. Here, it is order.
id
string The unique identifier of the order.
notes
object Key-value pair used to store additional information about the entity. Holds 15 key-value pairs, 256 characters (maximum) each. For example, "note_key": "Beam me up Scotty”.
offer_id
string The unique identifier of the offer. For example, offer_JHD834hjbxzhd38d.
receipt
string Receipt number that corresponds to this order. Can have a maximum length of 40 characters and has to be unique.
status
string The status of the order. Possible values:
created: When you create an order, it is in thecreatedstate. It stays in this state till a payment is attempted on it.attempted: An order changes to theattemptedstate following the first payment attempt and remains in this state until at least one payment is successfully processed and captured.paid: After the successful capture of the payment, the order moves to thepaidstate. No further payment requests are permitted once the order moves to thepaidstate.
The order stays in thepaidstate even if the payment associated with the order is refunded.
reviews
object Contains all risk assessment results.
entity
string Type of object. Here it is collection.
count
integer Number of risk assessments performed.
items
array List of risk assessment results.
screening
string Type of screening performed. Here it is aml.
risk_tier
string Overall risk level of the transaction. Possible values:
highmediumlowpending
risk_factors_count
integer Number of risk factors identified.
risk_factors
array Detailed risk factor information.
reason
string Identifier for the specific risk factor. For example name_match_sanction_list.
description
string Description of the risk factor.
source
string Field or data point that triggered the risk factor. For example, customer_details.name.
After creating an order, retrieve the updated risk assessment.
expands[]=order.reviews
string Use to expand the AML risk assessment details for an order. Returns the reviews object containing risk tier, risk factors count, and detailed risk factors with reasons, descriptions and sources.
amount
integer The amount for which the order was created, in currency subunits. For example, for an amount of RM 295.00, enter 29500.
amount_due
integer The amount pending against the order.
amount_paid
integer The amount paid against the order.
attempts
integer The number of payment attempts, successful and failed, that have been made against this order.
created_at
integer Indicates the Unix timestamp when this order was created.
currency
string ISO code for the currency in which you want to accept the payment. The default length is 3 characters.
entity
string Name of the entity. Here, it is order.
id
string The unique identifier of the order.
notes
object Key-value pair used to store additional information about the entity. Holds 15 key-value pairs, 256 characters (maximum) each. For example, "note_key": "Beam me up Scotty”.
offer_id
string The unique identifier of the offer. For example, offer_JHD834hjbxzhd38d.
receipt
string Receipt number that corresponds to this order. Can have a maximum length of 40 characters and has to be unique.
status
string The status of the order. Possible values:
created: When you create an order, it is in thecreatedstate. It stays in this state till a payment is attempted on it.attempted: An order changes to theattemptedstate following the first payment attempt and remains in this state until at least one payment is successfully processed and captured.paid: After the successful capture of the payment, the order moves to thepaidstate. No further payment requests are permitted once the order moves to thepaidstate.
The order stays in thepaidstate even if the payment associated with the order is refunded.
reviews
object Contains all risk assessment results.
entity
string Type of object. Here it is collection.
count
integer Number of risk assessments performed.
items
array List of risk assessment results.
screening
string Type of screening performed. Here it is aml.
risk_tier
string Overall risk level of the transaction. Possible values:
highmediumlowpending
risk_factors_count
integer Number of risk factors identified.
risk_factors
array Detailed risk factor information.
reason
string Identifier for the specific risk factor. For example name_match_sanction_list.
description
string Description of the risk factor.
source
string Field or data point that triggered the risk factor. For example, customer_details.name.
Reduce the risk score by providing additional customer compliance information to the flagged order.
customer_details
mandatory
object This contains details about the customer.
type
optional
string Indicates whether the customer is an individual or business entity. Possible values:
- 
company - 
individualWatch Out!
For transactions exceeding ₹2,50,000:
- Individual customers: PAN is mandatory.
 - Business customers: GSTIN is mandatory.
 
 
name
mandatory
string Customer's name.
- Character length: Between 5 and 50 characters.
 - Allowed characters: Uppercase letters (A-Z), lowercase letters (a-z), and spaces (not at the beginning).
 - Not allowed characters: Numbers, special characters (For example, @, ", ,, ., and so on.), Unicode characters, emojis, and non-Latin scripts or regional languages.
 - Prohibited names: Names must be meaningful and contextually appropriate.
- Avoid using repetitive patterns (For example, aaa, xyz, kkk kk).
 - Names like litri litri, Hfg Gh, or husi husi are not permitted.
 - Curse words or offensive names are not prohibited.
 
 - Example: 
Gaurav Kumar. 
optional
string The customer's email address. A maximum length of 64 characters for the username. For example, in "
contact
optional
string The customer's phone number. A maximum length of 15 characters including country code. For example, +919123456780.
individual
object Required when business_type is individual.
date_of_birth
object Customer's date of birth (individuals) or date of incorporation (businesses).
day
integer Day of birth/incorporation (1-31).
month
integer Month of birth/incorporation (1-12).
year
integer Year of birth/incorporation (4-digit format).
place_of_birth
string Place where the customer was born or place of incorporation for businesses.
tax_identity
array List of tax identifiers.
name
string Type of tax identifier.
value
string The identifier value matching the expected format.
amount
integer The amount for which the order was created, in currency subunits. For example, for an amount of RM 295.00, enter 29500.
amount_due
integer The amount pending against the order.
amount_paid
integer The amount paid against the order.
attempts
integer The number of payment attempts, successful and failed, that have been made against this order.
created_at
integer Indicates the Unix timestamp when this order was created.
currency
string ISO code for the currency in which you want to accept the payment. The default length is 3 characters.
entity
string Name of the entity. Here, it is order.
id
string The unique identifier of the order.
notes
object Key-value pair used to store additional information about the entity. Holds 15 key-value pairs, 256 characters (maximum) each. For example, "note_key": "Beam me up Scotty”.
offer_id
string The unique identifier of the offer. For example, offer_JHD834hjbxzhd38d.
receipt
string Receipt number that corresponds to this order. Can have a maximum length of 40 characters and has to be unique.
status
string The status of the order. Possible values:
created: When you create an order, it is in thecreatedstate. It stays in this state till a payment is attempted on it.attempted: An order changes to theattemptedstate following the first payment attempt and remains in this state until at least one payment is successfully processed and captured.paid: After the successful capture of the payment, the order moves to thepaidstate. No further payment requests are permitted once the order moves to thepaidstate.
The order stays in thepaidstate even if the payment associated with the order is refunded.
customer_details
mandatory
object This contains details about the customer.
name
mandatory
string Customer's name.
- Character length: Between 5 and 50 characters.
 - Allowed characters: Uppercase letters (A-Z), lowercase letters (a-z), and spaces (not at the beginning).
 - Not allowed characters: Numbers, special characters (For example, @, ", ,, ., and so on.), Unicode characters, emojis, and non-Latin scripts or regional languages.
 - Prohibited names: Names must be meaningful and contextually appropriate.
- Avoid using repetitive patterns (For example, aaa, xyz, kkk kk).
 - Names like litri litri, Hfg Gh, or husi husi are not permitted.
 - Curse words or offensive names are not prohibited.
 
 - Example: 
Gaurav Kumar. 
optional
string The customer's email address. A maximum length of 64 characters for the username. For example, in "
contact
optional
string The customer's phone number. A maximum length of 15 characters including country code. For example, +919123456780.
business_type
optional
string Indicates whether the customer is an individual or business entity. Possible values:
companyindividual
Watch Out!
For transactions exceeding ₹2,50,000:
- Individual customers: PAN is mandatory.
 - Business customers: GSTIN is mandatory.
 
individual
object Required when business_type is individual.
date_of_birth
object Customer's date of birth (individuals) or date of incorporation (businesses).
day
integer Day of birth/incorporation (1-31).
month
integer Month of birth/incorporation (1-12).
year
integer Year of birth/incorporation (4-digit format).
place_of_birth
string Place where the customer was born or place of incorporation for businesses.
tax_identity
array List of tax identifiers.
name
string Type of tax identifier.
value
string The identifier value matching the expected format.
Once the order is created, pass the order_id from the Orders API response to the
.How it works:
- Razorpay automatically fails transactions predicted to be AML-positive at the Create Order step.
 - Orders identified as high-risk are declined before payment processing.
 - No additional data collection required from customers.
 - Receive T+1 reports showing failed order statistics.
 
Best for:
- Businesses prioritising zero AML risk.
 - Use cases where declining high-risk transactions is acceptable.
 - Businesses unable to implement additional data collection.
 
Reporting:
- Daily T+1 reports showing:
- Number of orders failed due to AML.
 - Percentage of total orders affected.
 
 
For further assistance, reach out to our
or email us atimport-mission@razorpay.com.
Is this integration guide useful?