NETBANKING
Request Details
| Parameter Name | Data Type | Mandatory | Description |
|---|---|---|---|
merchantOrderId | String | Yes | Unique order ID generated by merchant |
amount | long | Yes | Amount of order in Paisa |
contraints | List<InstrumentConstraint> | Yes | Different type of constraints that must be applied to the payment |
bankId | String | Yes | Bank id from where payment will be completed. |
Sample Request
public async Task<IActionResult> CustomPay()
{
var merchantOrderID = $"Order_{DateTime.UtcNow:yyyyMMddHHmmssfff}";
var metaInfo = MetaInfo.Builder()
.SetUdf1("xyz")
.Build();
var payRequest = PgPaymentRequest.NetBankingPayRequestBuilder()
.SetMerchantOrderId(merchantOrderID)
.SetMerchantUserId("123")
.SetAmount(100)
.SetBankId("HDFC")
.SetRedirectUrl("")
.SetMetaInfo(metaInfo)
.SetExpireAfter(300)
_logger.LogInformation("Custom Pay Request:\n{Request}", JsonSerializer.Serialize(payRequest, JsonOptions.IndentedWithRelaxedEscaping));
try
{
var response = await _customCheckoutClient.Pay(payRequest);
_logger.LogInformation("Custom Pay Response:\n{Response}", JsonSerializer.Serialize(response, JsonOptions.IndentedWithRelaxedEscaping));
return Ok(response);
}
catch (Exception ex)
{
_logger.LogError(ex, "Custom Pay API Failed");
return StatusCode(500, new { message = ex.Message });
}
}
Extract the redirectUrl from the response received
Response Details
| Property | Type | Description |
|---|---|---|
orderId | String | Order Id created by PhonePe |
state | String | State of the order. Initially it will be PENDING. |
expireAt | Long | Order expire date in epoch |
redirectUrl | String | Redirect url to perform the Net Banking for mentioned bankId |