KEMBAR78
MMTC-PAMP API Documentation | PDF | Http Cookie | Login
0% found this document useful (0 votes)
154 views85 pages

MMTC-PAMP API Documentation

The MMTC-PAMP API documentation version 2.0 outlines various APIs for partners to manage user/customer profiles and access resources securely. It includes details on authentication, creating, updating, and retrieving customer profiles, as well as managing account statuses. The documentation is intended for authorized partners and emphasizes the importance of session IDs for secure API access.

Uploaded by

Rajesh Jatav
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
154 views85 pages

MMTC-PAMP API Documentation

The MMTC-PAMP API documentation version 2.0 outlines various APIs for partners to manage user/customer profiles and access resources securely. It includes details on authentication, creating, updating, and retrieving customer profiles, as well as managing account statuses. The documentation is intended for authorized partners and emphasizes the importance of session IDs for secure API access.

Uploaded by

Rajesh Jatav
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 85

API Documentation - MMTC-PAMP

Version: v2.0

Last Updated: [2025-05-22]

This documentation provides a comprehensive list of APIs that can be used by partners based
on their product flow and integration requirements. It outlines the necessary endpoints,
request/response structures, and authentication mechanisms to facilitate seamless
integration with our systems.

Usage Notice:
This documentation is intended for authorized partners only and should not be shared, published,
or distributed elsewhere without permission.

LOGIN/AUTHENTICATION API

Overview
This API allows partners to access resources / APIs in a secure and scalable way. The Login API
(POST /security/login) returns a session ID upon successful authentication. This session ID
must be included in the headers of all subsequent API requests to authenticate the user session.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Authentication & Session Management

To generate the sessionId, MMTC-PAMP will provide the following access credentials:
• partner_id
• username
• password

How to Use:

• The username and password should be used as Basic Authentication credentials when
calling the /security/login endpoint.
• The partner_id must be passed in the headers of the request.

Module SECURITY
API Endpoint /security/login
1. (401) Unauthorized
Sample Error
2. (500) Internal Server Error
Response
Sample Success
200 OK {“sessionId”:” XXXXXXX”}
Response

curl --location --request POST


'https://cemuat.mmtcpamp.com/security/login' --header 'partner_id:
Stack_Finance' --header 'Accept: application/json' --header 'Authorization:
Basic U3RhY2tfRmluYW5jZTpGaW5hbmNlQFN0YWNrMDMwMg==' --
Curl Request
header'Cookie:sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0b
mVyX2lkIjoiU3RhY2tfRmluYW5jZSIsImlhdCI6MTc0NjcwNTc3Mn0.xcquE4R8
d4Ik_COuZZ4vHLrkoIRG9LENz1_m-WrsYl8'

Method POST

CUSTOMER/USER RELATED API’S

Overview
The below API allows partners to create / update / fetch / activate / inactivate the profiles of the
users/customers.

BASE_URL : https://cemuat.mmtcpamp.com
CREATE PROFILE API

Overview
This API allows partners to create the profiles of the users/customers.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Important things while creating a customer profile.

A) KYC STATUS: If validated (value will be “Y”), if “Y”, KYC_INFO object must be passed
B) KYC STATUS: If not validated (value will be “I”), if “I”, can ignore KYC_INFO object.
C) ZIP: Should be in number not STRING. You can fetch the other details like state-code, state,
city from an API (mentioned below in PVT section) and provide this in the billing/delivery
Address objects.
D) There should be one mobile number associated with one account only and the same with
customerRefNo .

Module CUSTOMER
API Endpoint /customer/createProfile

1. (05) Profile Already Exists


Sample Error
2. (39) Must have required property “deliveryAddress”/BillingAddress
Response
2. An Application Error

Sample Success
200 OK {"dgCustomerRefNo": "29RLIIQ5BKVJ"}
Response
curl --location 'https://cemuat.mmtcpamp.com/customer/createProfile'

--header 'Content-Type: application/json'

--header 'Accept: application/json' --header 'Cookie:


sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

--data-raw '{ "mobileNumber": "9718957272", "customerRefNo":


"2352453453", "fullName": "Prashant kumar", "dgCustomerRefNo":
Curl Request "3Y8HOT9F6U2E", "kycStatus": "Y", "kycInfo": { "nameProofType": "pan",
"nameProofDocNo": "djehj23659k", "addressProofType": "aadhar",
"addressProofDocNo": "877656656577" }, "isCorporate": "", "gstin": "", "type":
"", "mainAccountNo": "", "emailAddress": "prashant.chauhan@abcd.com",
"partner_id": "Stack_Finance", "dob": "1998-06-02", "deliveryAddress": {
"line1": "delivery laxmi nagar West Delhi", "line2": "West Delhi", "city": "West
Delhi", "state": "DELHI", "zip": 110041, "country": "India", "mobileNumber":
"9718957271", "statecode": "07" }, "billingAddress": { "line1": "billing laxmi
nagar West Delhi", "line2": "West Delhi", "city": "West Delhi", "state": "DELHI",
"zip": 110041, "country": "India", "mobileNumber": "9718957271",
"statecode": "07" } }'

Method POST

{"mobileNumber": "9999999999", "customerRefNo":


"cxodwmxow3","fullName": "Kumar","kycStatus": "Y","kycInfo":
{"nameProofType": "pan","nameProofDocNo":
"epkud6757l","addressProofType": "","addressProofDocNo": ""},"partner_id":
Mandatory "{{partnerID}}", "deliveryAddress": {"line1": "","line2": "","city":
Parameters "Delhi","state": "DELHI","zip": 110041,"country": "India","mobileNumber":
"9999999999","statecode": "7"},"billingAddress": {"line1": "","line2": "","city":
"","state": "DELHI","zip": 110041,"country": "India","mobileNumber":
"9999999999","statecode": "7"}}
UPDATE PROFILE API

Overview
This API allows partners to update the profile of the user/customer.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module CUSTOMER
API Endpoint /customer/updateProfile

Sample Error 1.(500) An Application Error


Response 2. (39) Must have required property partner_id.

Sample Success
200 OK. Update successfully.
Response
curl --location 'https://cemuat.mmtcpamp.com/customer/updateProfile'

--header 'Content-Type: application/json'

--header 'Accept: application/json'

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

--data-raw '{ "mobileNumber": "9718957272", "customerRefNo":


Curl Request "STF_000001", "fullName": "tarun Aggarwal", "dgCustomerRefNo":
"3Y8HOT9F6U2E", "kycStatus": "Y", "kycInfo": { "nameProofType": "pan",
"nameProofDocNo": "djehj23659k", "addressProofType": "aadhar",
"addressProofDocNo": "877656656577" }, "isCorporate": "", "gstin": "", "type":
"", "mainAccountNo": "", "emailAddress": "prashant.chauhan@abcd.com",
"partner_id": "Stack_Finance", "dob": "1998-06-02", "deliveryAddress": { "id":
"umxGe9JSc02hiGd_dUp-z", "line1": "delivery laxmi nagar West Delhi",
"line2": "West Delhi", "city": "West Delhi", "state": "DELHI", "zip": 110041,
"country": "India", "mobileNumber": "9718957271", "statecode": "07" } ,
"billingAddress": { "id": "es8vu76axhMau64fjYTGq", "line1": "billing laxmi
nagar West Delhi", "line2": "West Delhi", "city": "West Delhi", "state": "DELHI",
"zip": 110041, "country": "India", "mobileNumber": "9718957271",
"statecode": "07" } }'

Method POST

{"customerRefNo": "string","fullName": "string","partner_id":


"string","billingAddress": {"zip": "number","statecode":
Mandatory "string"},"mobileNumber": "string","kycStatus": ["Y","I"],"kycInfo":
Parameters {"nameProofType": "pan", "nameProofDocNo": "string","addressProofType":
"aadhar","addressProofDocNo": "string"}}
GET PORTFOLIO API

Overview
This API allows partners to get the the portfolio balabce of the user/customer.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module CUSTOMER

API Endpoint /customer/getPortfolio

"39": "Unable to find customer account"


Sample Error
"03" :"Session id Invalid/Missing"
Response
"500": "An application error has occured."

{
"customerName": "Tarun Aggarwal",
"kycStatus": "Y",
"balances": [{
"balQuantity": "149.8740",
Sample Success "currencyPair": "XAU/INR",
Response "blockedQuantity": "0.0000"},
{"balQuantity": "96.2000",
"currencyPair": "XAG/INR",
"blockedQuantity": "0.0000" }
]
}
curl --location 'https://cemuat.mmtcpamp.com/customer/getPortfolio' \

--header 'accept: application/json' \

--header 'Content-Type: application/json' \

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
Curl Request
RhY2tfRmluYW5jZSIsImlhdCI6MTc0NzExNjcxN30._yfPATFxPA5cjlY0wMHX6
7ldlpICGl3FwloxMlunlTo' \

--data '{

"customerRefNo": "cxodwmxow3seA"

}'

Method POST
Mandatory 1-customerRefNo
Parameters 2-sessionId passed in the cookie In Headers

GET PROFILE API

Overview
This API allows partners to get the profile details of the user/customer.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}
Module OAT

API Endpoint /oat/getProfile

"03": "Session id Invalid/Missing"


"04": "CustomerRefNo Missing"
Sample Error
'33' :"Multiple User Accounts Exist"
Response
'39' :"Unable to find customer account"
"500": "An Application Error has occurred."

{ "mobileNumber": "9718957271", "customerRefNo":


"STF_te23nfk599", "fullName": "Prashant kumar", "dgCustomerRefNo":
"29RLIIQ5BKVJ", "kycStatus": "Y", "kycInfo": { "nameProofType": "pan",
"nameProofDocNo": "djehj2345l", "addressProofType": "aadhar",
"addressProofDocNo": "877656656577" }, "isCorporate": "N", "gstin": "",
"type": "N", "mainAccountNo": "441750926792", "emailAddress":
"prashant@chauhan.com", "partner_id": "Stack_Finance", "dob": "1998-
06-02T00:00:00.000Z", "deliveryAddress": [ { "id": "ZiAZXtUncIXgomO-
S_W8N", "line1": "laxmi nagar", "line2": "new delhi", "city": "delhi",
Sample Success
"state": "delhi", "zip": 110092, "country": "India", "mobileNumber":
Response
"9718957271", "statecode": "07" } ], "billingAddress": [ { "id":
"GgoOVEuptI2xGAhHTJNje", "line1": "E1-22, Sector 14", "line2": "Panjab
University, Sector 14", "city": "Chandigarh", "state": "Chandigarh", "zip":
160014, "country": "India", "mobileNumber": "6283763297", "statecode":
"12" }, { "id": "MkevMfR5_fyIYcaTtMUpJ", "line1": "E1-22, Sector 14",
"line2": "Panjab University, Sector 14", "city": "Chandigarh", "state":
"Chandigarh", "zip": 160014, "country": "India", "mobileNumber":
"6283763297", "statecode": "12" } ] }
curl --location --request POST
'https://cemuat.mmtcpamp.com/oat/getProfile' \

--header 'Accept: application/json' \

--header 'customerRefNo: cxodwmxow3seA' \


Curl Request
--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTc0NzExNjcxN30._yfPATFxPA5cjlY0wMHX6
7ldlpICGl3FwloxMlunlTo' \

--data ''

Method POST

Mandatory Customer Ref Number or customer mobile no. In the headers, Refer to curl
Parameters request.

ACTIVE ACCOUNT STATUS API

Overview
This API allows partners to Activate / Unblock the user account status.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module CUSTOMER

API Endpoint /customer/activate

"03" "Session id Invalid/Missing"


"04""CustomerRefNo Missing"
Sample Error
'06'"Customer not found"
Response
'07'"Customer already activated"
"500" "An Application Error has occurred."

Sample Success
200 OK
Response

curl --location --request POST


'https://cemuat.mmtcpamp.com/customer/activate'

--header 'customerRefNo: cxodwmxow3seA'

--header 'Accept: application/json'


Curl Request
--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTc0NzIxMzUyOX0.SOhOSXWvkK_5i_TyOXaD
5dSpl0gqQ29SUaHyBpI9EMo'

Method POST
Mandatory
Customer Ref Number In the headers, Refer to curl request.
Parameters

INACITIVATE ACCOUNT STATUS API


Overview
This API allows partners to Inactivate / block the user account status , So that user can not make any
transaction.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module CUSTOMER

API Endpoint /customer/activate

"03": "Session id Invalid/Missing"


"04":"CustomerRefNo Missing"
Sample Error
'06':"Customer not found"
Response
'07':"Customer already activated"
"500" : "An Application Error has occurred."

Sample Success
200 OK
Response

curl --location --request POST


'https://cemuat.mmtcpamp.com/customer/inactivate'

--header 'customerRefNo: STF_te4777'

--header 'mobileNumber;'
Curl Request
--header 'Accept: application/json'

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

Method POST
Mandatory Customer Ref Number Or Mobile Number to be passed the headers, Refer to curl
Parameters request.

VALIDATE KYC API

Overview
This API allows partners to Validate KYC of the User. Although, UpdateProfile API can also validate
KYC

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module CUSTOMER

API Endpoint /customer/validate

"04": "CustomerRefNo Missing"


Sample Error '06': "Customer not found"
Response '07': "Customer already validated"
"09": "Kyc info doesnt exist"

Sample Success
200 OK
Response

curl --location --request POST


'https://cemuat.mmtcpamp.com/customer/validate'
Curl Request
--header 'mobileNumber;'

--header 'Accept: application/json'


--header 'customerRefNo: STF_te4777'

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

Method POST
Mandatory Customer Ref Number Or Mobile Number to be passed the headers, Refer to curl
Parameters request.

INVALIDATE KYC API

Overview
This API allows partners to Invalidate KYC of the User. Although, UpdateProfile API can also
Invalidate KYC.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module CUSTOMER

API Endpoint /customer/invalidate

"03" : "Session id Invalid/Missing"


"04": "CustomerRefNo Missing"
Sample Error
'06': "Customer not found"
Response
'07': "Customer already invalidated"
"500" : "An Application Error has occurred."
Sample Success
200 OK
Response

curl --location --request POST


'https://cemuat.mmtcpamp.com/customer/invalidate'

--header 'customerRefNo: STF_te4777'

--header 'mobileNumber;'
Curl Request
--header 'Accept: application/json'

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

Method POST
Mandatory Customer Ref Number or Mobile Number to be passed the headers, Refer to curl
Parameters request.

HISTORICAL PRICE RELATED API’S

HISTORICAL PRICE API (GOLD)

Overview
This API allows partners to get the historical price of gold metal.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}
Module PRICE

API Endpoint /XAU/INR

Sample Error "code": 39: "timeFrame must be equal to one of the allowed values" ,
Response "code": "500": "An Application Error has occurred."

[
{
"buy_pretax": 6315.55,
"date_time": "20230317"
},
{
"buy_pretax": 6396.37,
"date_time": "20230318"
Sample Success
},
Response
{
"buy_pretax": 6396.54,
"date_time": "20230319"
},
{
"buy_pretax": 5910.88,
"date_time": "20230320"
}]

curl --location 'https://cemuat.mmtcpamp.com/price/XAU/INR'

--header 'Content-Type: application/json'

--header 'Accept: application/json'


Curl Request --header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

--data '{ "timeFrame": "1W" }'

Method POST
Mandatory timeFrame
Parameters sessionId (Cookie)

Note: Allowed timeframes are: “1D”,”1W”,”1M”,”3M”,”6M”,”1Y”,”3Y”,”5Y”

HISTORICAL PRICE API (SILVER)

Overview
This API allows partners to get the historical price of silvermetal.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module PRICE
API Endpoint /XAG/INR
Sample Error "code": 39: "timeFrame must be equal to one of the allowed values" ,
Response "code": "500": "An Application Error has occurred."
[{
"buy_pretax": 6315.55,
"date_time": "20230317"
Sample Success },
Response {
"buy_pretax": 6396.37,
"date_time": "20230318"
}]

curl --location 'https://cemuat.mmtcpamp.com/price/XAG/INR'


Curl Request
--header 'Content-Type: application/json'
--header 'Accept: application/json'

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

--data '{ "timeFrame": "1W" }'

Method POST
Mandatory timeFrame
Parameters sessionId (Cookie)

Note: Allowed timeframes are: “1D”,”1W”,”1M”,”3M”,”6M”,”1Y”,”3Y”,”5Y”

ADDRESS RELATED API’S

Pincode Serviceable API

Overview
his API lets partners verify if a pincode is serviceable and retrieve related details like state code and
state name, which can be used in the Create Profile API.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module PVT
API Endpoint / pvt/isPinCodeServiceable?pincode=110006"
"39" "must have required property 'pin code' "
Sample Error
"06" "Pincode is invalid"
Response
"500" "An Application error has occurred"
{
"serviceable": true,
"pincode": "110094",
Sample Success "state": "DELHI",
Response "statecode": 7,
"city": "East Delhi",
"deliveryInDays": 10
}

curl --location
'https://cemuat.mmtcpamp.com/pvt/isPinCodeServiceable?pinCode=590011
'

--header 'Accept: application/json'


Curl Request
--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

Method GET
Mandatory pinCode in search query i.e. "pvt/isPinCodeServiceable?pincode=110006"
Parameters sessionId (Cookie)

Get Addresses API

Overview
This API lets partners get the Address Details of the customer.
How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module PVT
API Endpoint / pvt/getAddresses
{"code": "06": "CustomerRefNo is invalid"}
Sample Error
{"code": "03": "Session Id Invalid"},
Response
{"code": "500", "An Application Error has occurred."}
[
{
"id": "MkevMfR5_fyIYcaTtMUpJ",
"name": "Sparsh Jain",
"line1": "E1-22, Sector 14",
"line2": "Panjab University, Sector 14",
"city": "Chandigarh",
"state": "Chandigarh",
"zip": 160014,
"country": "India",
"mobileNumber": "6283763297",
Sample Success "statecode": "12",
Response "type": "B",
"customerRefNo": "29RLIIQ5BKVJ"
},
{
"id": "ZiAZXtUncIXgomO-S_W8N",
"name": "Prashant Chauhan",
"line1": "laxmi nagar",
"line2": "new delhi",
"city": "delhi",
"state": "delhi",
"zip": 110092,
"country": "India",
"mobileNumber": "9718957271",
"statecode": "07",
"type": "D",
"customerRefNo": "29RLIIQ5BKVJ"
}
]

curl --location 'https://cemuat.mmtcpamp.com/pvt/getAddresses'

--header 'Content-Type: application/json'

--header 'Accept: application/json'


Curl Request --header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

--data '{ "customerRefNo": "STF_000001" }'

Method POST
1- Need to pass inside the request body : "customerRefNo":
Mandatory
"PTM_1234567890"
Parameters
2- sessionId (Cookie)

Note: In the response of getAddress Api, an object which has type as ‘B’, is Billing Address object and
an object which has type as ‘D’, is Delivery Address object.

3-DELETE ADDRESS API

Overview
This API lets partners delete the Address Details of the customer.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:
Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module PVT
API Endpoint / pvt/deleteAddresses

{"code": 39:"must have required property 'id'"},


Sample Error {"code": "50":"Address id invalid"},
Response {"code": "03", "Session Id Invalid"},
{"code": "500": "An Application Error has occurred."
}
Sample Success
200 OK
Response

curl --location 'https://cemuat.mmtcpamp.com/pvt/deleteAddress'

--header 'Content-Type: application/json'

--header 'Accept: application/json'


Curl Request --header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

--data '{ "id": "EPKD2c4lUM9ybYsUF3Ukw" }'

Method POST
Mandatory
Unique id of the address object
Parameters

Note: The id, which is mandatory in the request body, is the Id you can get from getAddresses Api.

ADD AND UPDATE ADDRESS API


Overview
This API lets partners either add a new address or update the current address details.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module PVT
API Endpoint / pvt/addUpdateAddress

39' Code : will be same for all following reasons:


must have required property
Sample Error "city","country","customerRefNo","line1","mobileNumber","name","state",
Response "statecode","type","zip","line2","zip must be integer"
"code": "06": "CustomerRefNo is invalid"
"code": "03": "Session Id Invalid"
"code": "500": "An Application Error has occurred."
Sample Success
200 OK
Response

curl --location 'https://cemuat.mmtcpamp.com/pvt/addUpdateAddress'

--header 'Content-Type: application/json'

--header 'Accept: application/json'


Curl Request --header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

--data '{ "id": "", "name": "Prashant kumar", "line1": "delivery laxmi nagar
West Delhi", "line2": "West Delhi", "city": "West Delhi", "state": "DELHI", "zip":
110041, "country": "India", "mobileNumber": "9718957271", "statecode":
"07", "type": "D", "customerRefNo": "STF_000001" }'

Method POST
Mandatory "city","country","customerRefNo","line1","mobileNumber", "name", "state",
Parameters "statecode","type", "zip"

Note: If the request body includes the field "id" (with its value obtained from the Get Addresses
API), the API will update the existing address. If "id" is not provided, the API will add a new address.

TRADE / TRANSACTIONS RELATED API’S

TRANSACTION PARTNER USING THEIR PAYMENT


TYPE GATEWAY PARTNER USING OUR PAYMENT GATEWAY

1. trade/getQuoteBuy 1. trade/getQuoteBuy
2- trade/validateQuotePartnerPg 2. trade/validateOrderAndExecute
FOR BUY
3-trade/executeOrderPartnerPg 3. trade/executeOrderWithPayIn

FOR SELL
1. trade/getQuoteSell 1. trade/getQuoteSell
2. trade/executeOrderPartnerPg 2. trade/executeOrderWithPayOut
1-redeem/getRedemptionCatalog
1- redeem/getRedemptionCatalog
2- 2- ValidateAndCreateRedeemOrder
REDEEM redeem/validateRedeemOrderForPart 3- redeem/executeRedeemOrder
nerPg

3-
redeem/executeRedeemOrderForPart
nerPg

1-GET NON-EXECUTABLE QUOTE

Overview
This API is used to get nonexecutable Quotes for buy and sell also currencyPair can be passed to get
quotes for gold and silver respectively.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module PVT
API Endpoint / pvt/ getNonExecutableQuote

Sample Error "49": "Invalid Parameter"


Response 39: calculationType must be equal to one of the allowed values
500:An Application Error has occurred (In case of system issue)
{
"totalAmount": "6105.73",
"quantity": "1.0000",
"quoteValidityTime": "480000",
Sample Success "taxType": "CGST/SGST",
Response "tax1Amt": "88.92",
"tax2Amt": "88.92",
"tax1Perc": "1.50",
"tax2Perc": "1.50",
"preTaxAmount": "5927.89",
"taxAmount": "177.84",
"quoteId": "MPLXpSCMI3gCjv8o1AInbtAia",
"type": "BUY",
"createdAt": "2023-04-04T07:58:30.039Z",
"currencyPair": "XAU/INR"
}

curl --location 'https://cemuat.mmtcpamp.com/pvt/getNonExecutableQuote'


\

--header 'Content-Type: application/json' \


Curl Request
--data '{

"currencyPair": "XAU/INR","type": "BUY"}'

Method POST
Mandatory "currencyPair": "XAU/INR" for gold or “XAG/INR” for silver,
Parameters "type": "BUY" or “SELL”

NOTE: The getNonExecutableApi can be used to show the live price of the metal to the
user/customer.

IF THE PARTNER IS USING MMTC’S PAYMENT GATEWAY :


TO EXECUTE THE BUY TRANSACTIONS USE BELOW API’S SEQUENCIALLY:

1- GET QUOTE BUY API

Overview
This API is used for getting the Buy Quote for a customer without passing his profile details. An RFQ
quote number is returned in response which then can be confirmed using validateQuoteAPI. The
quote returned is for 1 Gram quantity based and for CGST/SGST customer.
How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module PVT
API Endpoint / pvt/getQuoteBuy

code 39 : will be common for any required property missing in the payload: must
Sample Error
have required property 'property name'.
Response
Code 6: Invalid currencyPair.
Code 500: An Application Error has occurred
{
"totalAmount": "6105.73",
"quantity": "1.0000",
"quoteValidityTime": "480000",
"taxType": "CGST/SGST",
"tax1Amt": "88.92",
"tax2Amt": "88.92",
Sample Success "tax1Perc": "1.50",
Response "tax2Perc": "1.50",
"preTaxAmount": "5927.89",
"taxAmount": "177.84",
"quoteId": "MPLXpSCMI3gCjv8o1AInbtAia",
"type": "BUY",
"createdAt": "2023-04-04T07:58:30.039Z",
"currencyPair": "XAU/INR"
}

curl --location 'https://cemuat.mmtcpamp.com/trade/getQuoteBuy'

--header 'Content-Type: application/json'


Curl Request
--header 'Accept: application/json'

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

--data '{ "customerRefNo": "STF_000001", "currencyPair": "XAU/INR",


"transactionRefNo": "4b063cdf-b06e-430a-86e8-d13dbd7a5eb5",
"value":"1000", "type":"A" }'

Method POST
"customerRefNo": "STF_te23nfk599",
"currencyPair": "XAU/INR",
Mandatory
"transactionRefNo": "fed71ea9-b190-42f3-97d9-9086fd4a97b9",
Parameters
"value": "1000000", //not mandatory but used for calculation
"type":"A" // not mandatory but used for calculation

Note: The quotation is generated for 1 gram always. Partner has to calculate the total amount
(rounded up to 2 decimals), preTax(rounded up to 2 decimals), tax1(rounded up to 2 decimals),
tax2(rounded up to 2 decimals), and quantity (rounded up to 4 decimals) then call the validate quote
API. The quotation is valid for 8 min only. The process from quote generation to verifying the
payment(executeOrderAPI) must be done within 8 min of the window.

2-VALIDATE QUOTE API

Overview
This API will fetch the OrderId from Payment Partner and return it back. This will be used for PayIn
integration as providing Order Id for trade. Additionally quote details provided will be validated and
error will be returned if validation fails

To be called only once customer confirms for the final purchase option for a quote.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}
Module TRADE
API Endpoint /trade/validateOrderAndExecute

03: SessionId missing


39: error code will be common for any required property missing in the payload:
must have required property 'property name'.
"23":"QuoteID invalid"
'43':"Error in processing request, payload is wrong"
'53':"Transaction Date Invalid"
'51':"Billing addresses is Missing"
Sample Error '71':"Transaction order id is invalid"
Response '06':"CustomerRefNo is invalid"
'92':"Price anomaly detected. Transaction cancelled."
'73':"Quote type not valid for this transaction"
69: Deal Rejected while conversion during Tax Calculation
74: An Application Error has occurred"(In case of duplicate request for the same
quote id)
39: calculationType must be equal to one of the allowed values
51: Billing addresses is Missing
500:An Application Error has occurred (In case of system issue)

{ "id": "order_LWqaXlRcq16l00", "quoteId": "PTMDKzIUxajxQCw9PURiAQcyD",


"key": "rzp_test_XnlOuOZNrannpU", "orderId": { "transaction_id":
"PTMMC2vDhjD-V7b", "quote_id": "PTMDKzIUxajxQCw9PURiAQcyD", "order_id":
"PTMMC2vDhjD-V7b", "product_sku": "XAU_DMM", "dg_customer_ref_no":
"YNYZL9XH439K", "status": "pending", "type": "BUY", "quantity": "150.0000",
"src_dg_customer_ref_no": "mpipl", "dst_dg_customer_ref_no":
"YNYZL9XH439K", "shipping_address_id": "XR8hDrjrFu80-4bamQNOv",
Sample Success "billing_address_id": "XR8hDrjrFu80-4bamQNOv", "redeem_order_id": null,
Response "redeem_order_status": null, "invoice_id": null, "invoice_url": null, "tax_type":
"IGST", "taxes":
"{"tax1Amt":"12942.00","tax2Amt":"12942.00","tax3Amt":"0.00"}",
"pre_tax_amount": "862828.50", "total_amount": "888712.50",
"client_order_id": "2effe003-e8c0-4a18-af95-c20da39f408b", "payment_info_id":
"VP7LvHk5dqcne1E5I1-8K", "coupon_id": null, "remarks": null, "credit_note_id":
null, "credit_note_url": null, "created_at": "2023-03-28T06:35:00.680Z",
"updated_at": "2023-03-28T06:35:00.680Z" } }

Curl Request
curl --location
'https://cemuat.mmtcpamp.com/trade/validateOrderAndExecute' \

--header 'Content-Type: application/json' \

--header 'Accept: application/json' \

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{

"customerRefNo": "STF_000001",

"billingAddressId": "es8vu76axhMau64fjYTGq",

"calculationType": "A",

"preTaxAmount": "5665.85",

"quantity": "1.0000",

"quoteId": "STFt1fFJOfwYCsp7SCOXmS4Jb",

"tax1Amt": "84.99",

"tax2Amt": "84.99",

"tax3Amt": "5.10",

"transactionDate": "2023-04-27T09:34:46.435Z",

"transactionOrderID": "103879a9-85af-4749-b8dd-d40f81782dea",

"totalAmount": "5835.82"

}'

Method POST
{
Mandatory "customerRefNo": "",
Parameters "billingAddressId": "",
"calculationType": "",
"preTaxAmount": "",
"quantity": "",
"quoteId": "",
"tax1Amt": "",
"tax2Amt": "",
"transactionDate": "",
"transactionOrderID": "",
"totalAmount": ""
}

NOTE : The validateOrderAndExecute API is used to validate the quotation in case a partner is using
our PG to BUY the digital metal. This API will create an Order_ID on PG and return that order_id with
the PG key which then is passed to PG SDK to accept the payment from the customer.

3- EXECUTE ORDER API

Overview
Quote validated in the validateCreateOrder will be passed here along with the payment details
received from PG partner. This API will validate the payment response and execute the quote for
customer and credits gold to his account.

Additionally, this API will be validating the payment details passed through this via signature for Pay
In Module

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module TRADE
API Endpoint /trade/executeOrderWithPayIn
39': error code will be common for any required property missing in the payload:
must have required property 'property name'.
"53": "Transaction date invalid"
"71": "Quote is currently under execution"
'500': "Duplicate request found. Request will not be processed"
'23': "QuoteID Invalid"
Sample Error
'43': "Error in processing request, payload is wrong"
Response
'86': "payment order details provided are incorrect or already processed"
'51': "Billing addresses is Missing"
'89': "Error processing auto-refund"
'109': "Cannot update user balance"
'101': "OrderType is invalid"
'03': Session id Invalid/Missing

{"status": "string","data": {quantity": "string","orderId": "string","transactionId":


"string","netAmount": "string",tax1Amt": "string","customerRefNo":
"string",tax2Amt": "string","tax3Amt": "string","executionDateTime":
"string","customerName": "string","tax1Perc": "string","totalAmount":
"string","pricePerG": "string","taxPercent": "string","remainingBalance":
[{"balQuantity": "string","currencyPair": "string","blockedQuantity":
Sample Success
"string"},{"balQuantity": "string","currencyPair": "string","blockedQuantity":
Response
"string"}],"billingAddressId": "string","taxAmount": "string","tax2Perc":
"string","taxType": "string","invoiceId": "string"},"mobileNumber":
"string","emailAddress": "string","address": {"id": "string","name":
"string","line1": "string","line2": "string","city": "string","state": "string","zip":
"number","country": "string","mobileNumber": "string","stateCode":
"string","type": "string","customerRefNo": "string"},"productSku": "string"}

curl --location
'https://cemuat.mmtcpamp.com/trade/executeOrderWithPayIn' \

--header 'Content-Type: application/json' \

--header 'Accept: application/json' \


Curl Request
--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{
"customerRefNo": "STF_000001",

"billingAddressId": "es8vu76axhMau64fjYTGq",

"payIn": {"pgPaymentId": "pay_LptnixtPzIcSxS","pgOrderId":


"order_LptmxunRtgtn7n","pgSignature":
"f2a53a7b081cf3c1a9818fce9a4e486a46e2e75776a6b0982f06870936c5a71
d","pgProvider": "razorpay","pgAmount": "6511.02"},"calculationType":
"A","preTaxAmount": "6446.56","quantity": "1.0000","quoteId":
"STFEGKPzSSTisyCFCXXD2z4f1","tax1Amt": "32.23","tax2Amt":
"32.23","tax3Amt": "5.10","transactionDate": "2023-05-
15T10:03:35.030Z","transactionOrderID": "2d8e2fc8-1f86-487a-908d-
001cf5be6518", "totalAmount": "6511.02"}'

Method POST
{
"customerRefNo": "string",
"billingAddressId": "string",
"payIn": {
"pgPaymentId": "string",
"pgOrderId": "string",
"pgSignature": "string",
"pgProvider": "string",
"pgAmount": "string"
Mandatory },
Parameters "calculationType": "string",
"preTaxAmount": "string",
"quantity": "string",
"quoteId": "string",
"tax1Amt": "string",
"tax2Amt": "string",
"transactionDate": "string",
"transactionOrderID": "string",
"totalAmount": "string"
}

NOTE: This API is used to validate the payment in case a partner is using our PG to BUY the digital
metal.Quote validated in the validateOrderAndExecute will be passed here along with the payment
details received from PG partner. This API will validate the payment response and execute the quote
for customer and credits gold to his account.
Additionally, this API will be validating the payment details passed through this via signature for Pay
In Module.

TO EXECUTE THE SELL TRANSACTIONS USE BELOW API’S SEQUENCIALLY:

1-GET QUOTE SELL API

Overview
This API is used for getting the Sell Quote for a customer without passing his profile details. An RFQ
quote number is returned back in response of executeOrder API.The quote returned is for 1 Gram
quantity based and for CGST/SGST customer

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module PVT
API Endpoint / pvt/getQuoteSell

code 39 : will be common for any required property missing in the payload: must
Sample Error
have required property 'property name'.
Response
Code 6: Invalid currencyPair.
Code 500: An Application Error has occurred
{
"totalAmount": "5258.06",
"quantity": "1.0000",
Sample Success
"quoteValidityTime": "480000",
Response
"taxType": "CGST/SGST",
"tax1Amt": "0.00",
"tax2Amt": "0.00",
"tax3Amt": "1025.00",
"tax1Perc": "0.00",
"tax2Perc": "0.00",
"preTaxAmount": "5258.06",
"taxAmount": "0.00",
"quoteId": "PTM1YBMHtlOwgC52dokNOShDg",
"type": "SELL",
"createdAt": "2023-03-27T10:42:13.071Z"
}

curl --location 'https://cemuat.mmtcpamp.com/trade/getQuoteSell'

--header 'Content-Type: application/json'

--header 'Accept: application/json'

--header 'Cookie:
Curl Request sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

--data '{ "customerRefNo": "STF_000001", "currencyPair": "XAU/INR",


"transactionRefNo": "4b063cdf-b06e-430a-86e8-d13dbd7a5eb5",
"value":"1000", "type":"A" }'

Method POST

"customerRefNo": "STF_te23nfk599",
Mandatory "currencyPair": "XAU/INR",
Parameters "transactionRefNo": "b7d241ac-24ca"
"value": "1000000", //not mandatory but used for calculation
"type":"A" // not mandatory but used for calculation

Note: The quotation is generated for 1 gram always. Partner has to calculate the total amount
(rounded up to 2 decimals), preTax(rounded up to 2 decimals), tax1(rounded up to 2 decimals),
tax2(rounded up to 2 decimals), and quantity (rounded up to 4 decimals) then call the execute order
with payout API. The quotation is valid for 8 min only.
2-EXECUTE ORDER WITH PAYOUT API

Overview
This API is used for getting the Sell Quote for a customer without passing his profile details. An RFQ
quote number is returned back in response of executeOrder API.The quote returned is for 1 Gram
quantity based and for CGST/SGST customer

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module TRADE
API Endpoint /trade/ executeOrderWithPayOut

53':response.reason = 'Transaction date invalid'


'71':response.reason = 'Quote is currently under execution'
'500':response.reason = 'Duplicate request found. Request will not be processed'
'23':response.reason = 'QuoteID Invalid'
'43':response.reason = 'Error in processing request, payload is wrong'
'86':response.reason = 'payment order details provided are incorrect or already
processed'
Sample Error '68':response.reason = 'Mismatch Present for quote. Parameter {0}'
Response '69':response.reason = 'Deal Rejected while conversion during Tax Calculation'
'06':response.reason = 'CustomerRefNo is Invalid'
'34':response.reason = 'Quantity invalid'
'40':response.reason = 'Insufficient Balance'
'92':response.reason = 'Price anomaly detected. Transaction cancelled.'
'73':response.reason = 'Quote type not valid for this transaction'
'35':response.reason = 'Invalid payout account details'
'39': error code will be common for any required property missing in the payload:
must have required property 'property name'.
500:An Application Error has occurred (In case of system issue)
03: SessionId missing

{ "quantity": "1.0000", "orderId": "STFW05Bla5kxMoM", "transactionId":


"STFW05Bla5kxMoM", "netAmount": "5287.68", "tax1Amt": "0.00",
"customerRefNo": "STF_te23nfk599", "tax2Amt": "0.00", "tax3Amt": "0.00",
"executionDateTime": "2023-03-29T11:12:09.690Z", "customerName": "Prashant
kumar", "tax1Perc": "0.00", "totalAmount": "5287.68", "pricePerG": "5287.68",
"taxPercent": "0.00", "remainingBalance": [ { "balQuantity": "473.8740",
"currencyPair": "XAU/INR", "blockedQuantity": "0.0000" }, { "balQuantity":
Sample Success
"96.2000", "currencyPair": "XAG/INR", "blockedQuantity": "0.0000" } ],
Response
"billingAddressId": null, "taxAmount": "0.00", "tax2Perc": "0.00", "taxType":
"CGST/SGST", "invoiceId": null, "settlementInfo": { "id":
"iPwRZAoDJnF_3ET27T6N4", "provider": "razorpay", "type": "payout",
"payout_payment_id": "pout_LXJqQCz6TQv8Wu", "payout_status": "processing",
"payout_idempotent_id": "UOCJ117QUxbhO2K9B4pBP", "payout_account_id":
"8NU0LGNJIGMD" } }

curl --location
'https://cemuat.mmtcpamp.com/trade/executeOrderWithPayOut' \

--header 'Content-Type: application/json' \

--header 'Accept: application/json' \

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Curl Request Z7p1ywRa8AlBUDKTNY011X4zU' \

--data-raw '{ "calculationType": "Q","customerRefNo": "STF_000001","otp":


"","payOut": {"customerAccountInfo": {"name": "Prashant
KUMAR","accountNumber": "","ifsc": "","vpa":
"abhijeet@paytm"},"paymentChannel":
"UPI/RTGS/NEFT/IMPS"},"preTaxAmount": "5855.81","quantity":
"1.0000","quoteId": "STFxRQmFC0WLy4jYOQIiHH1f8","tax1Amt":
"0.00","tax2Amt": "0.00","tax3Amt": "5.10","transactionDate": "2023-05-
12T08:51:16.814Z","transactionOrderID": "4e47fa36-3ede-41d3-a754-
40f3dd7c3270","totalAmount": "5855.81"}'

Method POST
"calculationType": "string", "customerRefNo": "string","otp": "","payOut":
{"customerAccountInfo": {"name": "string","accountNumber": "string","ifsc":
Mandatory
"string","vpa": "string"},"paymentChannel": "string"},"preTaxAmount":
Parameters
"string","quantity": "string","quoteId": "string","tax1Amt": "string","tax2Amt":
"string","transactionDate": "string","transactionOrderID": "string","totalAmount":
"string"}

Note: The otp field should be passed as an empty string.

TO EXECUTE THE REDEMPTION TRANSACTIONS USE BELOW API’S SEQUENCIALLY:

1-GET REDEMPTION CATALOG

Overview
This API is used to get all redeemable products.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module REDEEM
API Endpoint /redeem/getRedemptionCatalog
Sample Error
99 : Product Catalog doesnt exist
Response
Sample Success [ { "productId": "248309", "name": "GOLD,999.9,RACTANGULAR INGOT,10.0 GM,
Response
F1AU10110339 : FINAL DESIGN,DOMESTIC MINTING
DESIGN,GOLD,999.9,RACTANGULAR INGOT,10.0 GM,MMTC PAMP INDIA PVT.
LTD.,BY MPIPL", "description": "

10 gm Gold 999.9 Minted Bar Lotus Certicard QR

", "skus": [ { "weight": "0.5", "makingCharges": "550", "skuId": "AUYyCOG0.5399",


"availableStock": "100", "maxQuantity": "100", "taxPercentage": "18", "images": [
{ "src": "https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/3868032?download=false", "title": "Picture3.png", "priority": 0 }, {
"src": "https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/3868043?download=false", "title": "Picture3 (1).png", "priority": 0 } ],
"deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount": "466.10",
"taxAmount": "83.90", "dimension": "11 x 11", "shape": "Coin", "purity": "999.9"
}, { "weight": "1", "makingCharges": "0", "skuId": "AUYyRIG1.0703",
"availableStock": "0", "maxQuantity": "0", "taxPercentage": "18", "images": [ {
"src": "https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/3868032?download=false", "title": "Picture3.png", "priority": 0 }, {
"src": "https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/3868043?download=false", "title": "Picture3 (1).png", "priority": 0 } ],
"deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount": "0.00",
"taxAmount": "0.00", "dimension": "8.9 * 14.7 mm", "shape": "Rectangular
Ingot", "purity": "999.9" }, { "weight": "2", "makingCharges": "0", "skuId":
"AUYyRIG2.0848", "availableStock": "0", "maxQuantity": "0", "taxPercentage":
"18", "images": [ { "src": "https://commerceuat.mmtcpamp.com/o/commerce-
media/accounts/-1/images/3868032?download=false", "title": "Picture3.png",
"priority": 0 }, { "src": "https://commerceuat.mmtcpamp.com/o/commerce-
media/accounts/-1/images/3868043?download=false", "title": "Picture3 (1).png",
"priority": 0 } ], "deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount":
"0.00", "taxAmount": "0.00", "dimension": "11.5 * 19 mm", "shape": "Rectangular
Ingot", "purity": "999.9" }, { "weight": "5", "makingCharges": "0", "skuId":
"AUYyRIG5.0353", "availableStock": "0", "maxQuantity": "0", "taxPercentage":
"18", "images": [ { "src": "https://commerceuat.mmtcpamp.com/o/commerce-
media/accounts/-1/images/3868032?download=false", "title": "Picture3.png",
"priority": 0 }, { "src": "https://commerceuat.mmtcpamp.com/o/commerce-
media/accounts/-1/images/3868043?download=false", "title": "Picture3 (1).png",
"priority": 0 } ], "deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount":
"0.00", "taxAmount": "0.00", "dimension": "14 * 23.3 mm", "shape": "Rectangular
Ingot", "purity": "999.9" }, { "weight": "8", "makingCharges": "0", "skuId":
"AUYyCOG8.0779", "availableStock": "0", "maxQuantity": "0", "taxPercentage":
"18", "images": [ { "src": "https://commerceuat.mmtcpamp.com/o/commerce-
media/accounts/-1/images/3868032?download=false", "title": "Picture3.png",
"priority": 0 }, { "src": "https://commerceuat.mmtcpamp.com/o/commerce-
media/accounts/-1/images/3868043?download=false", "title": "Picture3 (1).png",
"priority": 0 } ], "deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount":
"0.00", "taxAmount": "0.00", "dimension": "22 mm", "shape": "Coin", "purity":
"999.9" }, { "weight": "20", "makingCharges": "0", "skuId": "AUYyRIG20.0340",
"availableStock": "0", "maxQuantity": "0", "taxPercentage": "18", "images": [ {
"src": "https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/3868032?download=false", "title": "Picture3.png", "priority": 0 }, {
"src": "https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/3868043?download=false", "title": "Picture3 (1).png", "priority": 0 } ],
"deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount": "0.00",
"taxAmount": "0.00", "dimension": "18 * 31 mm", "shape": "Rectangular Ingot",
"purity": "999.9" } ], "currencyPair": "XAU/INR", "categories": [ { "type": "Metal
Type", "values": [ "Gold" ] }, { "type": "Product Series Type", "values": [ "Lotus" ] },
{ "type": "Product Sub Series Type", "values": [ "" ] }, { "type": "Category",
"values": [ "Classic" ] } ] }, { "productId": "244790", "name": "Product Creation
Test In UAT", "description": "

Product Creation Test In UAT

", "skus": [ { "weight": "1", "makingCharges": "510", "skuId":


"AXYyCPG.975410471234", "availableStock": "999", "maxQuantity": "999",
"taxPercentage": "18", "images": [ { "src":
"https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/244805?download=false", "title": "lotus_ingot_1g_gold_front.webp",
"priority": 0 } ], "deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount":
"432.20", "taxAmount": "77.80", "dimension": "5mm", "shape": "Coin", "purity":
"500" } ], "currencyPair": "XAU/INR", "categories": [ { "type": "Metal Type",
"values": [ "Gold" ] }, { "type": "Product Series Type", "values": [ "Cast Bar" ] }, {
"type": "Category", "values": [ "Gifting" ] } ] } ]

curl --location --request POST


'https://cemuat.mmtcpamp.com/redeem/getRedemptionCatalog' \

--header 'Accept: application/json' \


Curl Request
--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU'

Method POST
Mandatory
SESSION_ID in headers
Parameters
2-VALIDATE AND CREATE REDEEM ORDER API

Overview
This API is used Validate redeem order details and create a payment order for it .

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module REDEEM
API Endpoint /redeem/ validateAndCreateRedeemOrder
"03": "Session ID Missing"
'33': "Invalid Payload"
'40': "Insufficient Balance"
'43': "Error in processing request, payload is wrong"
'06': "CustomerRef NO is invalid"
'65': "Pincode not deliverable"
Sample Error
'49': "Invalid Product"
Response
'50': "Invalid Quantity or Making charge for Product"
'99': "Error in creating order at liferay"
'48': "Multiple requests found"
'500': "An Application Error has occurred"
"74": "Duplicate transactionRefNo/clientOrderId"
"500:An Application Error has occurred (In case of system issue)"

{ "quoteId": "STFPALABL21OQUT", "orderId": "STF2QZ5OM9XH7ME",


"pgOrderId": "order_LaQLlvdLFL8NaV", "key": "rzp_test_XnlOuOZNrannpU",
Sample Success "balances": [ { "balQuantity": "2.0000", "currencyPair": "XAU/INR",
Response "blockedQuantity": "2.0000" }, { "balQuantity": "0.0000", "currencyPair":
"XAG/INR", "blockedQuantity": "0.0000" } ], "silverMakingCharges": "0.00",
"goldMakingCharges": "432.20", "silverQuantity": 0, "goldQuantity": 1,
"productList": [ { "weight": "1", "makingCharges": "510", "skuId":
"AXYyCPG.975410471234", "availableStock": "138", "maxQuantity": "138",
"taxPercentage": "18", "images": [ { "src":
"https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/244805?download=false", "title": "lotus_ingot_1g_gold_front.webp",
"priority": 0 } ], "deliveryInDays": "2023-04-16T07:30:50.567Z", "preTaxAmount":
"432.20", "taxAmount": "77.80", "dimension": "5mm", "shape": "Coin", "purity":
"500", "currencyPair": "XAU/INR" } ], "goldTax": "77.80", "silverTax": "0.00",
"goldPreTaxAmount": "432.20", "silverPreTaxAmount": "0.00", "redeemOrderId":
"3947964" }

curl --location
'https://cemuat.mmtcpamp.com/redeem/validateAndCreateRedeemOrder' \

--header 'Content-Type: application/json' \

--header 'Accept: application/json' \

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
Curl Request RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{"customerRefNo": "STF_000001","transactionRefNo": "7698467a-


f861-4435-b874-bd5d65da03eb","productList": [{"productId":
"244790","quantity": "1","makingCharge": "510","skuId":
"AXYyCPG.975410471234"}],"billingAddressId":
"es8vu76axhMau64fjYTGq","shippingAddressId":
"EPKD2c4lUM9ybYsUF3Ukw","totalAmount": "510","preTaxAmount":
"432.20","taxAmount": "77.80"}'

Method POST
{
"customerRefNo": "{{customerRefNo}}",
"transactionRefNo": "{{$randomUUID}}",
"productList": [
Mandatory {
Parameters "productId": "244790",
"quantity": "1",
"makingCharge": "510",
"skuId": "AXYyCPG.975410471234"
}
],
"billingAddressId": "{{billingAddressId}}",
"shippingAddressId": "{{shippingAddressId}}",
"totalAmount": "510",
"preTaxAmount": "432.20",
"taxAmount": "77.80"
}

3- EXECUTE REDEEM ORDER API

Overview
This API is used to Execute a redeem order and store it in the database.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module REDEEM
API Endpoint /redeem/ executeRedeemOrder
'86':"payment order details provided are incorrect or already processed"
'23':"QuoteID or orderID invalid"
'39':"Order is already confirmed."
Sample Error '101':"OrderType is invalid"
Response '40':"Insufficient balance"
'99':"Error while updating order in liferay"
'109':"Error while updating user balance"
"500:An Application Error has occurred (In case of system issue)"
{ "quoteId": "STFPALABL21OQUT", "orderId": "STF2QZ5OM9XH7ME",
"pgOrderId": "order_LaQLlvdLFL8NaV", "key": "rzp_test_XnlOuOZNrannpU",
"balances": [ { "balQuantity": "2.0000", "currencyPair": "XAU/INR",
"blockedQuantity": "2.0000" }, { "balQuantity": "0.0000", "currencyPair":
"XAG/INR", "blockedQuantity": "0.0000" } ], "silverMakingCharges": "0.00",
"goldMakingCharges": "432.20", "silverQuantity": 0, "goldQuantity": 1,
"productList": [ { "weight": "1", "makingCharges": "510", "skuId":
"AXYyCPG.975410471234", "availableStock": "138", "maxQuantity": "138",
Sample Success
"taxPercentage": "18", "images": [ { "src":
Response
"https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/244805?download=false", "title": "lotus_ingot_1g_gold_front.webp",
"priority": 0 } ], "deliveryInDays": "2023-04-16T07:30:50.567Z", "preTaxAmount":
"432.20", "taxAmount": "77.80", "dimension": "5mm", "shape": "Coin", "purity":
"500", "currencyPair": "XAU/INR" } ], "goldTax": "77.80", "silverTax": "0.00",
"goldPreTaxAmount": "432.20", "silverPreTaxAmount": "0.00", "redeemOrderId":
"3947964" }

curl --location
'https://cemuat.mmtcpamp.com/redeem/executeRedeemOrder' \

--header 'Content-Type: application/json' \

--header 'Accept: application/json' \

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
Curl Request
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{ "quoteId": "MPLJ2KG9K7DJ4X2","transactionDate": "2023-05-


04T09:37:15.776Z","transactionOrderID": "ZAkzcva5PJCrDZA","orderId":
"MPLS2QJNMX4J8CO","payIn": {"pgPaymentId":
"pay_LlXT8aCQDvrsAz","pgOrderId": "order_LlXSXG5sxrlnWO","pgSignature":
"08bc06872c7390099c7765545e9130cf7b5f0cc6d773858cc49d1dc0e82b59
55","pgProvider": "Razorpay","pgAmount": 670.9952}'

Method POST
{"payIn": {"pgPaymentId": "pay_LaQP8eOmcMZYXP","pgOrderId":
Mandatory
"order_LaQLlvdLFL8NaV","pgSignature":
Parameters
"67234acc5b19acac1236280e5f40e5a66072060211f736b5feed735eba150903",
"pgProvider": "razorpay", "pgAmount": "510"},
"orderId":"STF2QZ5OM9XH7ME",
"quoteId": "STFPALABL21OQUT",
"transactionDate": "2023-04-06T07:36:32.757Z",
"transactionOrderID": "fc40bb79-35fe-4ae5-8220-da541002df46"
}

IF THE PARTNER IS USING OWN PAYMENT GATEWAY :


TO EXECUTE THE BUY TRANSACTIONS USE BELOW API’S SEQUENCIALLY:

1- GET QUOTE BUY API

Overview
This API is used for getting the Buy Quote for a customer without passing his profile details. An RFQ
quote number is returned in response which then can be confirmed using validateQuoteAPI. The
quote returned is for 1 Gram quantity based and for CGST/SGST customer.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module PVT
API Endpoint / pvt/getQuoteBuy

code 39 : will be common for any required property missing in the payload: must
Sample Error
have required property 'property name'.
Response
Code 6: Invalid currencyPair.
Code 500: An Application Error has occurred
Sample Success {
Response "totalAmount": "6105.73",
"quantity": "1.0000",
"quoteValidityTime": "480000",
"taxType": "CGST/SGST",
"tax1Amt": "88.92",
"tax2Amt": "88.92",
"tax1Perc": "1.50",
"tax2Perc": "1.50",
"preTaxAmount": "5927.89",
"taxAmount": "177.84",
"quoteId": "MPLXpSCMI3gCjv8o1AInbtAia",
"type": "BUY",
"createdAt": "2023-04-04T07:58:30.039Z",
"currencyPair": "XAU/INR"
}

curl --location 'https://cemuat.mmtcpamp.com/trade/getQuoteBuy'

--header 'Content-Type: application/json'

--header 'Accept: application/json'

--header 'Cookie:
Curl Request sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

--data '{ "customerRefNo": "STF_000001", "currencyPair": "XAU/INR",


"transactionRefNo": "4b063cdf-b06e-430a-86e8-d13dbd7a5eb5",
"value":"1000", "type":"A" }'

Method POST
"customerRefNo": "STF_te23nfk599",
"currencyPair": "XAU/INR",
Mandatory
"transactionRefNo": "fed71ea9-b190-42f3-97d9-9086fd4a97b9",
Parameters
"value": "1000000", //not mandatory but used for calculation
"type":"A" // not mandatory but used for calculation

Note: The quotation is generated for 1 gram always. Partner has to calculate the total amount
(rounded up to 2 decimals), preTax(rounded up to 2 decimals), tax1(rounded up to 2 decimals),
tax2(rounded up to 2 decimals), and quantity (rounded up to 4 decimals) then call the validate quote
API. The quotation is valid for 8 min only. The process from quote generation to verifying the
payment(executeOrderAPI) must be done within 8 min of the window.

2-VALIDATE QUOTE PARTNER PG API

Overview
This API is used to validate the quotation in case a partner is using their own PG to BUY the digital
metal. This API will varify the validity of the quotation and pricing details and taxes and returns "Data
Validated" if everything seems good.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module TRADE
API Endpoint /trade/validateQuotePartnerPg
03': Session id Invalid/Missing
"68": "Mismatch Present for quote. Parameter {0} "
'69': "Deal Rejected while conversion during Tax Calculation"
Sample Error
'23': "QuoteID invalid"
Response
'53': "Transaction Date Invalid"
'39': error code will be common for any required property missing in the payload:
must have required property 'property name'.
Sample Success
200 Data Validated
Response

curl --location
'https://cemuat.mmtcpamp.com/trade/validateQuotePartnerPg' \
Curl Request
--header 'Content-Type: application/json' \
--header 'Accept: application/json' \

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{"customerRefNo": "STF_000001","calculationType":


"A","preTaxAmount": "5632.33","quantity": "1.0000","quoteId":
"STFhtF4gNiqEKnRm1mBEcTxxn","tax1Amt": "0.00","tax2Amt":
"0.00","tax3Amt": "5.10","transactionDate": "2023-05-
01T05:26:54.324Z","transactionOrderID": "7a31de76-1c7d-491d-acc6-
02099154a6de","totalAmount": "5632.33"}'

Method POST
{
"customerRefNo": "{{customerRefNo}}",
"calculationType": "Q",
"preTaxAmount": "936049.50",
"quantity": "150.0000",
Mandatory "quoteId": "PTMgyuCtlvNKjK9B1xovWic8a",
Parameters "tax1Amt": "14040.00",
"tax2Amt": "14040.00",
"transactionDate": "2023-03-24T08:51:56.469Z",
"transactionOrderID": "3c30177f-1e97-4638-b322-22d0b556dc03",
"totalAmount": "964131.00"
}

3- EXECUTE ORDER PARTNER PG API

Overview
Quote validated in the validateQuotePartnerPg will be passed here. This API will validate the quote
details and execute the quote for customer and credits gold to his account.(This API is used in both
cases for buy and sell.)
How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module TRADE
API Endpoint /trade/ executeOrderPartnerPg
"68": "Mismatch Present for quote. Parameter {0} "
'69': "Deal Rejected while conversion during Tax Calculation"
'23': "QuoteID Invalid"
'06': "CustomerRefNo is Invalid"
'34': "Insufficient Balance"
'39': "Customer is not Active"
Sample Error
'48': "Amount is less than Minimum Transaction Amount"
Response
'53': "Transaction Date Invalid"
'71': "Quote is Currently Under Execution"
'39': error code will be common for any required property missing in the payload:
must have required property 'property name'.
500:An Application Error has occurred (In case of system issue)
03: SessionId missing

{"quantity": "150.0000","orderId": {"transactionId":


"PTMvjWjStCOJ0El","quoteId": "PTMoVHy0dL9oncjtgekAgiqjO","orderId":
"PTMvjWjStCOJ0El"},"netAmount": "862312.50","customerRefNo":
"STF_te23nfk599","currencyPair": "XAU/INR","executionDateTime": "2023-03-
28T08:13:49.348Z","customerName": "Prashant kumar","tax1Perc":
Sample Success
"1.50","tax2Perc": "1.50","taxType": "IGST","tax1Amt": 12934.5,"tax2Amt":
Response
12934.5,"taxAmount": "25869.00","totalAmount": "888181.50","pricePerG":
"5921.21","taxPercent": "3","remainingBalance": [{"balQuantity":
"1348.0000","currencyPair": "XAU/INR","blockedQuantity":
"150.0000"},{"balQuantity": "0.0000","currencyPair":
"XAG/INR","blockedQuantity": "0.0000"}]}

curl --location
Curl Request
'https://cemuat.mmtcpamp.com/trade/executeOrderPartnerPg' \
--header 'Content-Type: application/json' \

--header 'Accept: application/json' \

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{"customerRefNo": "STF_000001","calculationType":


"Q","billingAddressId": "es8vu76axhMau64fjYTGq","preTaxAmount":
"5632.33","quantity": "1.0000","quoteId":
"STFhtF4gNiqEKnRm1mBEcTxxn","tax1Amt": "0.00","tax2Amt":
"0.00","tax3Amt": "5.10","transactionDate": "2023-05-
01T05:26:54.324Z","transactionOrderID": "7a31de76-1c7d-491d-acc6-
02099154a6de","totalAmount": "5632.33"}'

Method POST
{
"customerRefNo": "{{customerRefNo}}","calculationType":
"Q","billingAddressId": "XR8hDrjrFu80-4bamQNOv","preTaxAmount":
"862312.50","quantity": "150.0000","quoteId":
Mandatory "PTMoVHy0dL9oncjtgekAgiqjO","tax1Amt": "12934.50","tax2Amt":
Parameters "12934.50","transactionDate": "2023-03-
28T08:13:20.869Z","transactionOrderID": "b2b8ed02-efc7-4211-9a19-
6d3c145cfca8",
"totalAmount": "888181.50"
}

NOTE: Quote validated in the validateQuotePartnerPg will be passed here. This API will validate the
quote details and execute the quote for customer and credits gold to his account.(This API is used in
both cases for buy and sell.)

TO EXECUTE THE SELL TRANSACTIONS USE BELOW API’S SEQUENCIALLY:


1-GET QUOTE SELL API

Overview
This API is used for getting the Sell Quote for a customer without passing his profile details. An RFQ
quote number is returned back in response of executeOrder API.The quote returned is for 1 Gram
quantity based and for CGST/SGST customer

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module PVT
API Endpoint / pvt/getQuoteSell

code 39 : will be common for any required property missing in the payload: must
Sample Error
have required property 'property name'.
Response
Code 6: Invalid currencyPair.
Code 500: An Application Error has occurred
{
"totalAmount": "5258.06",
"quantity": "1.0000",
"quoteValidityTime": "480000",
"taxType": "CGST/SGST",
"tax1Amt": "0.00",
"tax2Amt": "0.00",
Sample Success "tax3Amt": "1025.00",
Response "tax1Perc": "0.00",
"tax2Perc": "0.00",
"preTaxAmount": "5258.06",
"taxAmount": "0.00",
"quoteId": "PTM1YBMHtlOwgC52dokNOShDg",
"type": "SELL",
"createdAt": "2023-03-27T10:42:13.071Z"
}
curl --location 'https://cemuat.mmtcpamp.com/trade/getQuoteSell'

--header 'Content-Type: application/json'

--header 'Accept: application/json'

--header 'Cookie:
Curl Request sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDE0OTcxM30.SReDny8-
GIn8W85ZNX0DyY_J7TsXG2F59eDnf_Bs06Q'

--data '{ "customerRefNo": "STF_000001", "currencyPair": "XAU/INR",


"transactionRefNo": "4b063cdf-b06e-430a-86e8-d13dbd7a5eb5",
"value":"1000", "type":"A" }'

Method POST

"customerRefNo": "STF_te23nfk599",
Mandatory "currencyPair": "XAU/INR",
Parameters "transactionRefNo": "b7d241ac-24ca"
"value": "1000000", //not mandatory but used for calculation
"type":"A" // not mandatory but used for calculation

Note: The quotation is generated for 1 gram always. Partner has to calculate the total amount
(rounded up to 2 decimals), preTax(rounded up to 2 decimals), tax1(rounded up to 2 decimals),
tax2(rounded up to 2 decimals), and quantity (rounded up to 4 decimals) then call the execute order
with payout API. The quotation is valid for 8 min only.

2-EXECUTE ORDER PARTNER PG API

Overview
Quote validated in the validateQuotePartnerPg will be passed here. This API will validate the quote
details and execute the quote for customer and credits gold to his account.(This API is used in both
cases for buy and sell.)
How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module TRADE
API Endpoint /trade/ executeOrderPartnerPg
"68": "Mismatch Present for quote. Parameter {0} "
'69': "Deal Rejected while conversion during Tax Calculation"
'23': "QuoteID Invalid"
'06': "CustomerRefNo is Invalid"
'34': "Insufficient Balance"
'39': "Customer is not Active"
Sample Error
'48': "Amount is less than Minimum Transaction Amount"
Response
'53': "Transaction Date Invalid"
'71': "Quote is Currently Under Execution"
'39': error code will be common for any required property missing in the payload:
must have required property 'property name'.
500:An Application Error has occurred (In case of system issue)
03: SessionId missing

{"quantity": "-15.0000","orderId": {"transactionId":


"PTMvjWjStCOJ0El","quoteId": "PTMoVHy0dL9oncjtgekAgiqjO","orderId":
"PTMvjWjStCOJ0El"},"netAmount": "862312.50","customerRefNo":
"STF_te23nfk599","currencyPair": "XAU/INR","executionDateTime": "2023-03-
28T08:13:49.348Z","customerName": "Prashant kumar","tax1Perc":
Sample Success
"1.50","tax2Perc": "1.50","taxType": "IGST","tax1Amt": 12934.5,"tax2Amt":
Response
12934.5,"taxAmount": "25869.00","totalAmount": "888181.50","pricePerG":
"5921.21","taxPercent": "3","remainingBalance": [{"balQuantity":
"1348.0000","currencyPair": "XAU/INR","blockedQuantity":
"150.0000"},{"balQuantity": "0.0000","currencyPair":
"XAG/INR","blockedQuantity": "0.0000"}]}
curl --location
'https://cemuat.mmtcpamp.com/trade/executeOrderPartnerPg' \

--header 'Content-Type: application/json' \

--header 'Accept: application/json' \

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Curl Request Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{"customerRefNo": "STF_000001","calculationType":


"Q","billingAddressId": "es8vu76axhMau64fjYTGq","preTaxAmount":
"5632.33","quantity": "1.0000","quoteId":
"STFhtF4gNiqEKnRm1mBEcTxxn","tax1Amt": "0.00","tax2Amt":
"0.00","tax3Amt": "5.10","transactionDate": "2023-05-
01T05:26:54.324Z","transactionOrderID": "7a31de76-1c7d-491d-acc6-
02099154a6de","totalAmount": "5632.33"}'

Method POST
{
"customerRefNo": "{{customerRefNo}}","calculationType":
"Q","billingAddressId": "XR8hDrjrFu80-4bamQNOv","preTaxAmount":
"862312.50","quantity": "150.0000","quoteId":
Mandatory "PTMoVHy0dL9oncjtgekAgiqjO","tax1Amt": "12934.50","tax2Amt":
Parameters "12934.50","transactionDate": "2023-03-
28T08:13:20.869Z","transactionOrderID": "b2b8ed02-efc7-4211-9a19-
6d3c145cfca8",
"totalAmount": "888181.50"
}

NOTE: Quote validated in the validateQuotePartnerPg will be passed here. This API will validate the
quote details and execute the quote for customer and credits gold to his account.(This API is used in
both cases for buy and sell.)
TO EXECUTE THE REDEMPTION TRANSACTIONS USE BELOW API’S SEQUENCIALLY:

1-GET REDEMPTION CATALOG

Overview
This API is used to get all redeemable products.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module REDEEM
API Endpoint /redeem/getRedemptionCatalog
Sample Error
99 : Product Catalog doesnt exist
Response

[ { "productId": "248309", "name": "GOLD,999.9,RACTANGULAR INGOT,10.0 GM,


F1AU10110339 : FINAL DESIGN,DOMESTIC MINTING
DESIGN,GOLD,999.9,RACTANGULAR INGOT,10.0 GM,MMTC PAMP INDIA PVT.
LTD.,BY MPIPL", "description": "

10 gm Gold 999.9 Minted Bar Lotus Certicard QR


Sample Success ", "skus": [ { "weight": "0.5", "makingCharges": "550", "skuId": "AUYyCOG0.5399",
Response "availableStock": "100", "maxQuantity": "100", "taxPercentage": "18", "images": [
{ "src": "https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/3868032?download=false", "title": "Picture3.png", "priority": 0 }, {
"src": "https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/3868043?download=false", "title": "Picture3 (1).png", "priority": 0 } ],
"deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount": "466.10",
"taxAmount": "83.90", "dimension": "11 x 11", "shape": "Coin", "purity": "999.9"
}, { "weight": "1", "makingCharges": "0", "skuId": "AUYyRIG1.0703",
"availableStock": "0", "maxQuantity": "0", "taxPercentage": "18", "images": [ {
"src": "https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/3868032?download=false", "title": "Picture3.png", "priority": 0 }, {
"src": "https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/3868043?download=false", "title": "Picture3 (1).png", "priority": 0 } ],
"deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount": "0.00",
"taxAmount": "0.00", "dimension": "8.9 * 14.7 mm", "shape": "Rectangular
Ingot", "purity": "999.9" }, { "weight": "2", "makingCharges": "0", "skuId":
"AUYyRIG2.0848", "availableStock": "0", "maxQuantity": "0", "taxPercentage":
"18", "images": [ { "src": "https://commerceuat.mmtcpamp.com/o/commerce-
media/accounts/-1/images/3868032?download=false", "title": "Picture3.png",
"priority": 0 }, { "src": "https://commerceuat.mmtcpamp.com/o/commerce-
media/accounts/-1/images/3868043?download=false", "title": "Picture3 (1).png",
"priority": 0 } ], "deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount":
"0.00", "taxAmount": "0.00", "dimension": "11.5 * 19 mm", "shape": "Rectangular
Ingot", "purity": "999.9" }, { "weight": "5", "makingCharges": "0", "skuId":
"AUYyRIG5.0353", "availableStock": "0", "maxQuantity": "0", "taxPercentage":
"18", "images": [ { "src": "https://commerceuat.mmtcpamp.com/o/commerce-
media/accounts/-1/images/3868032?download=false", "title": "Picture3.png",
"priority": 0 }, { "src": "https://commerceuat.mmtcpamp.com/o/commerce-
media/accounts/-1/images/3868043?download=false", "title": "Picture3 (1).png",
"priority": 0 } ], "deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount":
"0.00", "taxAmount": "0.00", "dimension": "14 * 23.3 mm", "shape": "Rectangular
Ingot", "purity": "999.9" }, { "weight": "8", "makingCharges": "0", "skuId":
"AUYyCOG8.0779", "availableStock": "0", "maxQuantity": "0", "taxPercentage":
"18", "images": [ { "src": "https://commerceuat.mmtcpamp.com/o/commerce-
media/accounts/-1/images/3868032?download=false", "title": "Picture3.png",
"priority": 0 }, { "src": "https://commerceuat.mmtcpamp.com/o/commerce-
media/accounts/-1/images/3868043?download=false", "title": "Picture3 (1).png",
"priority": 0 } ], "deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount":
"0.00", "taxAmount": "0.00", "dimension": "22 mm", "shape": "Coin", "purity":
"999.9" }, { "weight": "20", "makingCharges": "0", "skuId": "AUYyRIG20.0340",
"availableStock": "0", "maxQuantity": "0", "taxPercentage": "18", "images": [ {
"src": "https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/3868032?download=false", "title": "Picture3.png", "priority": 0 }, {
"src": "https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/3868043?download=false", "title": "Picture3 (1).png", "priority": 0 } ],
"deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount": "0.00",
"taxAmount": "0.00", "dimension": "18 * 31 mm", "shape": "Rectangular Ingot",
"purity": "999.9" } ], "currencyPair": "XAU/INR", "categories": [ { "type": "Metal
Type", "values": [ "Gold" ] }, { "type": "Product Series Type", "values": [ "Lotus" ] },
{ "type": "Product Sub Series Type", "values": [ "" ] }, { "type": "Category",
"values": [ "Classic" ] } ] }, { "productId": "244790", "name": "Product Creation
Test In UAT", "description": "

Product Creation Test In UAT

", "skus": [ { "weight": "1", "makingCharges": "510", "skuId":


"AXYyCPG.975410471234", "availableStock": "999", "maxQuantity": "999",
"taxPercentage": "18", "images": [ { "src":
"https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
1/images/244805?download=false", "title": "lotus_ingot_1g_gold_front.webp",
"priority": 0 } ], "deliveryInDays": "2023-04-22T10:59:25.232Z", "preTaxAmount":
"432.20", "taxAmount": "77.80", "dimension": "5mm", "shape": "Coin", "purity":
"500" } ], "currencyPair": "XAU/INR", "categories": [ { "type": "Metal Type",
"values": [ "Gold" ] }, { "type": "Product Series Type", "values": [ "Cast Bar" ] }, {
"type": "Category", "values": [ "Gifting" ] } ] } ]

curl --location --request POST


'https://cemuat.mmtcpamp.com/redeem/getRedemptionCatalog' \

--header 'Accept: application/json' \


Curl Request
--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU'

Method POST
Mandatory
SESSION_ID in headers
Parameters
\

2-VALIDATE REDEEM ORDER PARTNER PG API

Overview
This API is used Validate redeem order details .
How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module REDEEM
API Endpoint /redeem/validateRedeemOrderForPartnerPg
"40":"Insufficient balance"
"74":"Duplicate transactionRefNo/clientOrderId"
Sample Error '43':"Error in processing request, payload is wrong"
Response '99':"Error in creating order at liferay"
'06':"CustomerRefNo not found"
"500:An Application Error has occurred (In case of system issue)"

{ "quoteId": "STFIPJFRIL33GVK", "orderId": "STFT8JQ25M46BRK", "balances": [ {


"balQuantity": "1.0000", "currencyPair": "XAU/INR", "blockedQuantity": "0.0000"
}, { "balQuantity": "0.0000", "currencyPair": "XAG/INR", "blockedQuantity":
"0.0000" } ], "silverMakingCharges": "0.00", "goldMakingCharges": "432.20",
"silverQuantity": 0, "goldQuantity": 1, "productList": [ { "weight": "1",
"makingCharges": "510", "skuId": "AXYyCPG.975410471234", "availableStock":
"999", "maxQuantity": "999", "taxPercentage": "18", "images": [ { "src":
Sample Success
"https://commerceuat.mmtcpamp.com/o/commerce-media/accounts/-
Response
1/images/244805?download=false", "title": "lotus_ingot_1g_gold_front.webp",
"priority": 0 } ], "deliveryInDays": "2023-04-16T13:03:31.653Z", "preTaxAmount":
"432.20", "taxAmount": "77.80", "dimension": "5mm", "shape": "Coin", "purity":
"500", "currencyPair": "XAU/INR" } ], "goldTax": "77.80", "silverTax": "0.00",
"goldPreTaxAmount": "432.20", "silverPreTaxAmount": "0.00", "redeemOrderId":
"3948113" }

curl --location
'https://cemuat.mmtcpamp.com/redeem/validateRedeemOrderForPartnerP
g' \
Curl Request
--header 'Content-Type: application/json' \

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{"customerRefNo": "STF_000001","transactionRefNo": "73c5e5ed-


9b7c-4f98-a27e-7d390685f235","productList": [{"productId":
"244790","quantity": "1","makingCharge": "510","skuId":
"AXYyCPG.975410471234"}],"billingAddressId":
"es8vu76axhMau64fjYTGq","shippingAddressId":
"es8vu76axhMau64fjYTGq","totalAmount": "510","preTaxAmount":
"432.20","taxAmount": "77.80"}'

Method POST
{
"customerRefNo": "{{customerRefNo}}",
"transactionRefNo": "{{$randomUUID}}",
"productList": [
{
"productId": "244790",
"quantity": "1",
"makingCharge": "510",
Mandatory
"skuId": "AXYyCPG.975410471234"
Parameters
}
],
"billingAddressId": "{{billingAddressId}}",
"shippingAddressId": "{{shippingAddressId}}",
"totalAmount": "510",
"preTaxAmount": "432.20",
"taxAmount": "77.80"
}

3- EXECUTE REDEEM ORDER PARTNER PG API

Overview
Execute the redeem order after payment has been made and verified by the partner.
How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module REDEEM
API Endpoint /redeem/executeRedeemOrderForPartnerPg
23': "QuoteID or orderID invalid"
'39': "Order is already confirmed."
'101': "OrderType is invalid"
Sample Error
'40': "Insufficient balance"
Response
'99': "Error while updating order in liferay"
'109': "Error while updating user balance"
"500:An Application Error has occurred (In case of system issue)"

{
"billingAddressId": "es8vu76axhMau64fjYTGq",
"shippingAddressId": "es8vu76axhMau64fjYTGq",
"orderId": "STFT8JQ25M46BRK",
"makingCharges": 432.2,
"taxAmount": 77.8,
"totalAmount": 510,
"remainingBalance": [
{
Sample Success "balQuantity": "0.0000",
Response "currencyPair": "XAU/INR",
"blockedQuantity": "0.0000"
},
{
"balQuantity": "0.0000",
"currencyPair": "XAG/INR",
"blockedQuantity": "0.0000"
}
],
"createdAt": "2023-04-06T13:04:04.829Z"
}
curl --location
'https://cemuat.mmtcpamp.com/redeem/executeRedeemOrderForPartnerPg
'\

--header 'Content-Type: application/json' \

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Curl Request
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{

"quoteId": "STF3CZ8R1AZ1DDA",

"transactionDate": "2023-04-018T12:00:00.129Z",

"transactionOrderID": "e6ebf87d-261e-4dc9-ac9d-0e187b20e45d"}'

Method POST
{
"quoteId": "STFIPJFRIL33GVK",
Mandatory
"transactionDate": "2023-04-06T07:43:43.129Z",
Parameters
"transactionOrderID": "{{$randomUUID}}"
}

TRANSFER TRANSACTIONS RELATED API’S

1-DIRECT TRASFER API

Overview
This allows the transfer of the balance from the source customer account to the destination customer
account with immediate effect.
How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module TRADE
API Endpoint /trade/transfer
"74": "Duplicate transactionRefNo/clientOrderId"
"04": "Source or Destination Customer not Found"
"40": "Insufficient balance at source"
'53': "Transaction Date Invalid"
'57': "Quantity can not be empty"
Sample Error '64': "Quantity should be more than zero."
Response '58': "KYC should be validated."
'59': "Currency pair invalid."
'39': error code will be common for any required property missing in the payload:
must have required property 'property name'.
500:An Application Error has occurred (In case of system issue)
03: SessionId missing
{
"orderId": "STF76JV7AQAUXVP",
"executionDateTime": "2023-03-30T07:14:54.887Z",
"totalAmount": "120.06",
Sample Success
"quantity": "2.0000",
Response
"pricePerG": "60.03",
"currencyPair": "XAG/INR",
"remainingBalance": "92.2000"
}

curl --location 'https://cemuat.mmtcpamp.com/trade/transfer' \

Curl Request --header 'Content-Type: application/json' \

--header 'Accept: application/json' \


--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{ "channel": "web","currencyPair": "XAG/INR","dstCustomerRefNo":


"PTM_000002","quantity": "1.0000","srcCustomerRefNo":
"PTM_000001","transactionDate": "2023-03-
30T07:06:44.090Z","transactionOrderID": "b150191e-5f64-4f01-86cc-
c93c87a14ff2","message": "Hope you like gold gift."}'

Method POST
{"channel": "",
"currencyPair": "",
"dstCustomerRefNo": "",
"quantity": "",
Mandatory
"srcCustomerRefNo": "",
Parameters
"transactionDate": "",
"transactionOrderID": "",
"message": ""
}

2-BUY AND TRASFER API

Overview
Designed to buy at the Partner Goldback account and transfer the same to the destination account
immediately. Initial validation of Transfer to destination is done, if failed the entire flow is aborted.
Validations for Buy will be applied.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}
Module TRADE
API Endpoint /trade/buyAndTransferPartnerPg
"04":"Source or Destination Customer not Found"
"40":"Insufficient balance at source"
'53':"Transaction Date Invalid"
'57':"Quantity can not be empty"
'64':"Quantity should be more than zero."
"68":"Mismatch Present for quote. Parameter {0}"
'69':"Deal Rejected while conversion during Tax Calculation"
Sample Error
'23':"QuoteID Invalid"
Response
'06':"CustomerRefNo is Invalid"
'34':"Quantity invalid"
'39':"Customer is not Active"
'48':"Amount is less than Minimum Transaction Amount"
'71':"Quote is Currently Under Execution"
'58':"KYC should be validated."
'500':"Duplicate request found. Request will not be processed"
{
"quantity": "10",
"transferCustomerBalance": "21.0000",
"orderId": {
"orderId": "STF8SE5KQY92OXP",
"quantity": "10",
"metal": "gold",
"date": "2023-05-02T06:55:29.863Z"
},
"netAmount": "56471.6",
Sample Success "currencyPair": "XAU/INR",
Response "tax1Amt": "84.71",
"buyCustomerRefNo": "STF_000001",
"tax2Amt": "84.71",
"executionDateTime": "2023-05-02T06:55:29.886Z",
"buyCustomerName": "Prashant kumar",
"transferCustomerName": "Ashutosh kumar",
"tax1Perc": "1.50",
"pricePerG": "5816.58",
"totalAmount": "58165.8",
"taxPercent": "1.501.50",
"billingAddress": {
"line1": "billing laxmi nagar West Delhi",
"line2": "West Delhi",
"city": "West Delhi",
"state": "DELHI",
"zip": 110041,
"country": "India",
"mobileNumber": "9718957271"
},
"tax2Perc": "1.50",
"taxAmount": "1694.1999999999998",
"taxType": "IGST"
}

curl --location
'https://cemuat.mmtcpamp.com/trade/buyAndTransferPartnerPg' \

--header 'Content-Type: application/json' \

--header 'Accept: application/json' \

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
Curl Request RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{"buyCustomerRefNo": "STF_000001","channel":


"web","currencyPair": "XAU/INR","transactionDate": "2023-04-
07T06:46:28.687Z","transactionOrderID": "9144fd67-c9ca-4502-9c4b-
1fa8ee75a11a","transferCustomerRefNo": "STF_000002","amount":
"10334.39","message": "Hope you like the
gift.","billingAddressId":"es8vu76axhMau64fjYTGq"}'

Method POST
{
"buyCustomerRefNo": "STF_000001",
"channel": "web",
"currencyPair": "XAU/INR",
Mandatory
"transactionDate": "2023-04-07T06:46:28.687Z",
Parameters
"transactionOrderID": "b1b06c68-5a45-4df6-8ed9-889d8f871151",
"transferCustomerRefNo": "STF_000002",
"quantity": "10",
"amount": "6334.39",
"message": "Hope you like the gift.",
"billingAddressId":"es8vu76axhMau64fjYTGq"
}

NOTE: please provide the billingAddressId (of the buy customer reference number) parameter and
make sure KYC is validated for both customers.

3-INITIATE TRANSFER API

Overview
This allows to initiate transfer (balance in grams) from source customer account. Either quantity or
amount can be mentioned. Given quantity is debited from the customer account.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module TRADE
API Endpoint /trade/ initiateTransfer
"53":"Transaction date invalid"
'500':"Duplicate request found. Request will not be processed"
Sample Error
'06':"CustomerRefNo is Invalid"
Response
'34':"Quantity invalid"
'48':"Amount is less than Minimum Transaction Amount"
"40":"Insufficient balance at source"
'57':"Quantity can not be empty"
'64':"Quantity should be more than zero."
'67':"Destination customer ref no doesnt exist"
"74":"Duplicate transactionRefNo/clientOrderId"
'39': error code will be common for any required property missing in the payload:
must have required property 'property name'.
500:An Application Error has occurred (In case of system issue)
03: SessionId missing

{
"totalAmount": "52758.10",
"quantity": "10.0000",
"currencyPair": "XAU/INR",
Sample Success
"pricePerG": "5275.81",
Response
"srcCustomerBalance": "552.8740",
"orderId": "STFFPSOOE601R5W",
"executionDateTime": "2023-04-04T07:05:38.673Z"
}

curl --location 'https://cemuat.mmtcpamp.com/trade/initiateTransfer' \

--header 'Content-Type: application/json' \

--header 'Accept: application/json' \

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
Curl Request RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{"currencyPair": "XAU/INR","dstCustomerRefNo":


"","dstMobileNumber": "8957760515","email": "","isKycRequired":
false,"name": "","srcCustomerRefNo": "STF_000001","transactionOrderID":
"a1acf0f8-ffcf-401a-86fe-408a9bcd9c12","channel": "web","transactionDate":
"2023-03-30T07:40:59.087Z","quantity": "10.0000"}'

Method POST
{"currencyPair": "XAU/INR",
Mandatory "dstCustomerRefNo": "",
Parameters "dstMobileNumber": "8957760515",
"email": "Prashant@chauhan.com",
"isKycRequired": true,
"name": "",
"srcCustomerRefNo": "{{customerRefNo}}",
"transactionOrderID": "{{$randomUUID}}",
"channel": "web",
"transactionDate": "2023-03-30T07:40:59.087Z",
"quantity": "10.0000"}

4-CONFIRM TRANSFER API

Overview
This allows to transfer (balance in grams) from the transfer id from the Initiate Transfer API provided
to the destination customer account.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module TRADE
API Endpoint /trade/ confirmTransfer
"53":"Transaction date invalid"
'500':"Duplicate request found. Request will not be processed"
'06':"CustomerRefNo is Invalid"
Sample Error '39':"Customer is not Active"
Response '58':"KYC should be validated."
'54':"order Id is invalid."
"27":"Already confirmed"
'39': error code will be common for any required property missing in the payload:
must have required property 'property name'.
500:An Application Error has occurred (In case of system issue)
03: SessionId missing
{
"dstCustomerBalance": "20.0000",
"srcCustomerBalance": "552.8740",
Sample Success
"currencyPair": "XAU/INR",
Response
"transferId": "STFFPSOOE601R5W",
"executionDateTime": "2023-04-04T07:11:36.141Z"
}

curl --location 'https://cemuat.mmtcpamp.com/trade/confirmTransfer' \

--header 'Content-Type: application/json' \

--header 'Accept: application/json' \

--header 'Cookie:
Curl Request sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{"transferId": "STFW42435WRXWG6","dstCustomerRefNo":


"STF_te23nfk560","currencyPair": "XAU/INR", "transactionDate": "2023-03-
30T07:40:59.087Z"}'

Method POST
{
"transferId": "STFFPSOOE601R5W",
Mandatory "dstCustomerRefNo": "STF_te23nfk560",
Parameters "currencyPair": "XAU/INR",
"transactionDate": "2023-03-30T07:40:59.087Z"
}
ORDER/TRANSACTION DETAILS RELATED API’S

1-GET ORDER HISTORY API

Overview
This API is used to get all the transaction of the user i.e. BUY, SELL, TRANSFER, REDEEM.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module TRADE
API Endpoint /trade/ getOrderHistory
"06":"CustomerRef NO is invalid"
'08':"Start or End Date is Invalid"
Sample Error '39': error code will be common for any required property missing in the payload:
Response must have required property 'property name'.
500:An Application Error has occurred (In case of system issue)
03: SessionId missing
[ {"transactionId": "DZYOFVBVZA34",
"orderId": "STFT8JQ25M46BRK",
"productSku": "XAU_DMM",
"customerRefNo": "3Y8HOT9F6U2E",
"status": "cancelled",
Sample Success
"type": "REDEEM",
Response
"quantity": "-1",
"totalAmount": "510.00",
"preTaxAmount": "432.20",
"couponId": null,
"createdAt": "2023-04-06T13:04:04.829Z",
"remarks": "Quality Issue"}]

curl --location 'https://cemuat.mmtcpamp.com/trade/getOrderHistory' \

--header 'Content-Type: application/json' \

--header 'Accept: application/json' \

Curl Request --header 'Cookie:


sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{"customerRefNo": "STF_000001","endDate": "2023-04-


25T12:57:51.521Z","startDate": "2022-10-13T11:20:00.084Z"}'

Method POST
{
"customerRefNo": "{{customerRefNo}}",
Mandatory
"endDate": "2023-04-20T12:57:51.521Z",
Parameters
"startDate": "2022-10-13T11:20:00.084Z"
}

2-GET ORDER DETAILS API

Overview
This API is used to get all the details of a specific transaction done by the user i.e. BUY, SELL,
TRANSFER, REDEEM.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:
Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module TRADE
API Endpoint /trade/ getOrderDetails
108':"Transaction id invalid"
'190':"Testing error handler"
'06':"CustomerRefNo is invalid"
Sample Error
'39': error code will be common for any required property missing in the payload:
Response
must have required property 'property name'.
500:An Application Error has occurred (In case of system issue)
03: SessionId missing
{
"transactionId": "STFyeu5kuLACv0L",
"orderId": "STFyeu5kuLACv0L",
"quantity": "1.0000",
"couponId": null,
"taxes":
"{\"tax1Amt\":\"88.44\",\"tax2Amt\":\"88.44\",\"tax3Amt\":\"0.00\"}",
"preTaxAmount": "5895.85",
"totalAmount": "6072.72",
"billingAddress": {
"id": "GgoOVEuptI2xGAhHTJNje",
Sample Success "name": "Prashant Chauhan",
Response "line1": "E1-22, Sector 14",
"line2": "Panjab University, Sector 14",
"city": "Chandigarh",
"state": "Chandigarh",
"zip": 160014,
"country": "India",
"mobileNumber": "6283763297",
"stateCode": "12",
"type": "B",
"customerRefNo": "29RLIIQ5BKVJ"
},
"couponDetails": null,
"type": "BUY",
"refundStatus": null
}

curl --location 'https://cemuat.mmtcpamp.com/trade/getOrderDetails' \

--header 'Content-Type: application/json' \

--header 'Accept: application/json' \


Curl Request --header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{"transactionId": "STF1rFrQeKhG-vT","type": "SELL"}'

Method POST
{
Mandatory "transactionId": "STFyeu5kuLACv0L",
Parameters "type": "BUY"
}

3-GET REDEEM HISTORY API

Overview
This API is used to get all the REDEEM orders.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}
Module TRADE
API Endpoint /trade/ getRedeemHistory
83':"Couldn't fetch liferay orders"
'39': error code will be common for any required property missing in the payload:
Sample Error
must have required property 'property name'.
Response
500:An Application Error has occurred (In case of system issue)
03: SessionId missing
[
{
"orderId": "STFRSO4C2XTHEPK",
"productDetails": [
{
"name": "Product Creation Test In UAT",
"quantity": 1,
"imageUrl": "https://commerceuat.mmtcpamp.com/o/commerce-
media/accounts/3947960/images/244805?download=false",
"weight": "1gm"
}
],
"date": "2023-04-06T12:25:35.211Z",
"makingCharges": 432.2,
"taxes": 77.8,
Sample Success
"orderStatus": "Confirmed",
Response
"type": "REDEEM",
"shippingAddress": {
"id": "EPKD2c4lUM9ybYsUF3Ukw",
"name": "Prashant kumar",
"line1": "delivery laxmi nagar West Delhi",
"line2": "West Delhi",
"city": "West Delhi",
"state": "DELHI",
"zip": 110041,
"country": "India",
"mobileNumber": "9718957271",
"stateCode": "07",
"type": "D",
"customerRefNo": "3Y8HOT9F6U2E"
},
"billingAddress": {
"id": "es8vu76axhMau64fjYTGq",
"name": "Prashant kumar",
"line1": "billing laxmi nagar West Delhi",
"line2": "West Delhi",
"city": "West Delhi",
"state": "DELHI",
"zip": 110041,
"country": "India",
"mobileNumber": "9718957271",
"stateCode": "07",
"type": "B",
"customerRefNo": "3Y8HOT9F6U2E"
},
"refundStatus": "processed",
"isCancellationPossible": true,
"isActive": true,
"totalAmount": 510
}
]

curl --location 'https://cemuat.mmtcpamp.com/trade/getOrderHistory' \

--header 'Content-Type: application/json' \

--header 'Accept: application/json' \

Curl Request --header 'Cookie:


sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{"customerRefNo": "STF_000001","endDate": "2023-04-


25T12:57:51.521Z","startDate": "2022-10-13T11:20:00.084Z"}'

Method POST
{
Mandatory "customerRefNo": "{{customerRefNo}}",
Parameters "endDate": "2023-04-06T12:57:51.521Z",
"startDate": "2022-10-13T11:20:00.084Z"
}

4-GET DELIVERY STATUS API

Overview
This API is used to get the status of a particular REDEEM order.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module TRADE
API Endpoint /trade/ getDeliveryStatus
39': error code will be common for any required property missing in the payload:
Sample Error must have required property 'property name'.
Response 500:An Application Error has occurred (In case of system issue)
03: SessionId missing
{
"finalResult": "cancelled",
"deliveryPartner": "NA",
"trackingNumber": "NA",
"statuses": [
{
Sample Success "location": "Chandigarh",
Response "status": "Order Created",
"date": "2023-02-27T10:19:04.000Z"
},
{
"location": "Chandigarh",
"status": "Order Cancelled",
"date": "2023-04-06T10:49:58.000Z"
}
]
}

curl --location 'https://cemuat.mmtcpamp.com/trade/getDeliveryStatus' \

--header 'Content-Type: application/json' \

--header 'Cookie:
Curl Request
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{"orderId":"STFAZSG10BEQGY9"}'

Method POST
{
Mandatory
"orderId":"STFAZSG10BEQGY9"
Parameters
}

CHECK TRADE STATUS API

Overview
This API returns the status of the given trade. Based on the status values can be unconfirmed,
confirmed, or reversed based on the Order ID. Error code of Under Execution is returned if order is
currently under processing.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}
Module TRADE
API Endpoint /trade/ checkTradeStatus

06 – Customer not found (Unable to find customer with the provided


customerRefNo)

Sample Error 56 – Order not Found (Unable to find an order with the provided clientOrderID)
Response
03 – Session Id Invalid (Session Id missing or invalid)

39 – Missing property in request body

{ "totalAmount": "5749.63",
"quantity": "-1.0000",
"orderId": "STFl3quNHFfNAwD",
"pricePerG": "5749.63",
"tax1Amt": "0.00",
Sample Success
"tax2Amt": "0.00",
Response
"taxAmount": "0.00",
"tax2Perc": "0.00",
"tax1Perc": "0.00",
"taxType": "CGST/SGST",
"status": "confirmed"}

curl --location 'https://cemuat.mmtcpamp.com/trade/checkTradeStatus' \

--header 'Content-Type: application/json' \

--header 'Accept: application/json' \

Curl Request --header 'Cookie:


sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTY4NDM4NTQ2OH0.eoh9C0A7A1i3eeFYDy
Z7p1ywRa8AlBUDKTNY011X4zU' \

--data '{"clientOrderID": "2d8e2fc8-1f86-487a-908d-


001cf5be6518","customerRefNo": "STF_000001"}'

Method POST
{
Mandatory "clientOrderID": "e0de83f4-d2c7-40b1-b9d9-acec24eb9106",
Parameters "customerRefNo": "{{customerRefNo}}"
}

INVOICE RELATED API’S

1- GENERATE BUY PDF INVOICE API

Overview
This API is used to generate the invoice PDF for BUY orders .

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module PVT
API Endpoint /pvt/generateBuyPdfInvoice
Sample Error
500: An Application Error has occurred (In case of system issue)
Response
Sample Success JVBERi0xLjQKJdPr6eEKMSAwIG9iago8PC9UaXRsZSAoQ3VzdG9tZXIgQnV5IEludm9
Response pY2UpCi9DcmVhdG9.......
Curl Request
curl --location 'https://cemuat.mmtcpamp.com/pvt/generateBuyPdfInvoice'
\

--header 'accept: application/json' \

--header 'Content-Type: application/json' \

--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTc0NzkxNTI3Mn0.7qZ-
FZsQVya6DVQr_Fsu1aQluSTjNCHJjD51aX-cNr4' \

--data '{"transactionId": "STFiRFKiUDXy_k1"}'

Method POST
{
Mandatory
"transactionId": "STFiRFKiUDXy_k1"
Parameters
}

2-GENERATE SELL PDF INVOICE API

Overview
This API is used to generate the invoice PDF for SELL orders.

How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:
Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module PVT
API Endpoint /pvt/generateSellPdfInvoice
Sample Error
500: An Application Error has occurred (In case of system issue)
Response
Sample Success JVBERi0xLjQKJdPr6eEKMSAwIG9iago8PC9UaXRsZSAoQ3VzdG9tZXIgQnV5IEludm9
Response pY2UpCi9DcmVhdG9.......

curl --location 'https://cemuat.mmtcpamp.com/pvt/generateSellPdfInvoice' \

--header 'accept: application/json' \

--header 'Content-Type: application/json' \


Curl Request --header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTc0NzkxNTI3Mn0.7qZ-
FZsQVya6DVQr_Fsu1aQluSTjNCHJjD51aX-cNr4' \

--data '{"transactionId": "STFiRFKiUDXy_k1"}'

Method POST
{
Mandatory
"transactionId": "STFiRFKiUDXy_k1"
Parameters
}

3-GENERATE REDEEM PDF INVOICE API

Overview
This API is used to generate the invoice PDF for REDEEM orders.
How to Send Session ID in Request Headers

For all protected APIs, include the session ID in the request headers using the following format:

Key: Cookie
Value: sessionId={{sessionId string returned from Login API}}

Module PVT
API Endpoint /pvt/generateRedeemPdfInvoice
Sample Error
500: An Application Error has occurred (In case of system issue)
Response
Sample Success JVBERi0xLjQKJdPr6eEKMSAwIG9iago8PC9UaXRsZSAoQ3VzdG9tZXIgQnV5IEludm9
Response pY2UpCi9DcmVhdG9.......

curl --location
'https://cemuat.mmtcpamp.com/pvt/generateRedeemPdfInvoice' \

--header 'accept: application/json' \

--header 'Content-Type: application/json' \


Curl Request
--header 'Cookie:
sessionId=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJwYXJ0bmVyX2lkIjoiU3
RhY2tfRmluYW5jZSIsImlhdCI6MTc0NzkxNTI3Mn0.7qZ-
FZsQVya6DVQr_Fsu1aQluSTjNCHJjD51aX-cNr4' \

--data '{"transactionId": "STFiRFKiUDXy_k1"}'

Method POST
{
Mandatory
"transactionId": "{{order id of the order}}"
Parameters
}

BASE URL : https://cemuat.mmtcpamp.com (for uat)


SWAGGER LINK : https://cemuat.mmtcpamp.com/api

Endpoint Reference

API Tags Method Purpose/Outcome


Type
/security/login Login POST Partner gets a unique sessionId for subsequent use

/security/logout Logout POST Partner's sessionId gets revoked

/customer/createProfile User POST Add a user in CEM database with a unique customer code

/customer/updateProfile User POST Update information for an existing user

/oat/getProfile User POST Get profile details for a user

/customer/validate User POST Make KYC of user as valid

/customer/invalidate User POST Make KYC of user as invalid

/customer/activate User POST Activate a user for transactions

/customer/inactivate User POST Inactivate a user for transactions

/customer/getPortfolio User POST Gives currencyPair balances for user

/pvt/isPinCodeServiceable User GET To check weather pincode is serviceable

/pvt/getAddresses User POST To get all the address of the user

/pvt/deleteAddress User POST To delete a particular address

/pvt/addUpdateAddress User POST To update a particular address

/pvt/getDeliveryStatus Redeem POST To get delivery status of redeem orders

To get live price feed for Buy and Sell(Much faster compared to
/pvt/getNonExecutableQuote Buy, Sell POST
getQuoteBuy and getQuoteSell)
/price/XAU/INR Price Feed POST Get a historical price feed for gold

/price/XAG/INR Price Feed POST Get a historical price feed for silver

/trade/getQuoteBuy Buy POST Get a buy quote for a currency pair

/trade/validateQuotePartnerPg Buy POST Validate quote details when partner is handling payments

/trade/getQuoteSell Sell POST Get a sell quote for a currency pair


/trade/executeOrderPartnerPg Buy, Sell POST Execute a buy/sell order when partner is handling payments

Buy, Sell,
/trade/checkTradeStatus Redeem, POST Check the status of a given trade
Transfer
Buy, Sell,
/trade/getOrderHistory Redeem, POST Get paginated history of all customer orders
Transfer
Buy, Sell,
/trade/getOrderDetails Redeem, POST More details for a specific order
Transfer

/trade/transfer Transfer POST Transfer metal from one account to another

/trade/initiateTransfer Transfer POST Initiate a transfer from source to MPIPL

/trade/confirmTransfer Transfer POST Confirm a transfer from MPIPL to destination

/trade/buyAndTransferPartnerPg Transfer POST Buy some gold and transfer it to other user

/trade/getRedeemHistory Redeem POST Get the paginated history of all customer redeem orders

/redeem/getRedemptionCatalog Redeem POST Get redemption catalog for a currency pair

/redeem/validateRedeemOrderForPartnerPg Redeem POST Validate redeem order details

Execute the redeem order after payment has been made and
/redeem/executeRedeemOrderForPartnerPg Redeem POST
verified by the partner.

Support & Contact


Email:

tarun.aggarwal@quadrafort.com

Harshit.gupta@mmtcpamp.com

Monika.fotedar@mmtcpamp.com

You might also like