mirror of
https://github.com/juspay/hyperswitch.git
synced 2025-11-01 19:42:27 +08:00
feat(router): add card_info in payment_attempt table if not provided in request (#1538)
Co-authored-by: Sahkal Poddar <sahkal.poddar@juspay.in>
This commit is contained in:
@ -2449,3 +2449,93 @@ mod test {
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
pub async fn get_additional_payment_data(
|
||||
pm_data: &api_models::payments::PaymentMethodData,
|
||||
db: &dyn StorageInterface,
|
||||
) -> api_models::payments::AdditionalPaymentData {
|
||||
match pm_data {
|
||||
api_models::payments::PaymentMethodData::Card(card_data) => {
|
||||
if card_data.card_issuer.is_some()
|
||||
&& card_data.card_network.is_some()
|
||||
&& card_data.card_type.is_some()
|
||||
&& card_data.card_issuing_country.is_some()
|
||||
&& card_data.bank_code.is_some()
|
||||
{
|
||||
api_models::payments::AdditionalPaymentData::Card {
|
||||
card_issuer: card_data.card_issuer.to_owned(),
|
||||
card_network: card_data.card_network.clone(),
|
||||
card_type: card_data.card_type.to_owned(),
|
||||
card_issuing_country: card_data.card_issuing_country.to_owned(),
|
||||
bank_code: card_data.bank_code.to_owned(),
|
||||
}
|
||||
} else {
|
||||
let card_number = card_data.clone().card_number;
|
||||
let card_info = db
|
||||
.get_card_info(&card_number.get_card_isin())
|
||||
.await
|
||||
.map_err(|error| services::logger::warn!(card_info_error=?error))
|
||||
.ok()
|
||||
.flatten()
|
||||
.map(
|
||||
|card_info| api_models::payments::AdditionalPaymentData::Card {
|
||||
card_issuer: card_info.card_issuer,
|
||||
card_network: card_info
|
||||
.card_network
|
||||
.clone()
|
||||
.map(|network| network.foreign_into()),
|
||||
bank_code: card_info.bank_code,
|
||||
card_type: card_info.card_type,
|
||||
card_issuing_country: card_info.card_issuing_country,
|
||||
},
|
||||
);
|
||||
card_info.unwrap_or(api_models::payments::AdditionalPaymentData::Card {
|
||||
card_issuer: None,
|
||||
card_network: None,
|
||||
bank_code: None,
|
||||
card_type: None,
|
||||
card_issuing_country: None,
|
||||
})
|
||||
}
|
||||
}
|
||||
api_models::payments::PaymentMethodData::BankRedirect(bank_redirect_data) => {
|
||||
match bank_redirect_data {
|
||||
api_models::payments::BankRedirectData::Eps { bank_name, .. } => {
|
||||
api_models::payments::AdditionalPaymentData::BankRedirect {
|
||||
bank_name: bank_name.to_owned(),
|
||||
}
|
||||
}
|
||||
api_models::payments::BankRedirectData::Ideal { bank_name, .. } => {
|
||||
api_models::payments::AdditionalPaymentData::BankRedirect {
|
||||
bank_name: bank_name.to_owned(),
|
||||
}
|
||||
}
|
||||
_ => api_models::payments::AdditionalPaymentData::BankRedirect { bank_name: None },
|
||||
}
|
||||
}
|
||||
api_models::payments::PaymentMethodData::Wallet(_) => {
|
||||
api_models::payments::AdditionalPaymentData::Wallet {}
|
||||
}
|
||||
api_models::payments::PaymentMethodData::PayLater(_) => {
|
||||
api_models::payments::AdditionalPaymentData::PayLater {}
|
||||
}
|
||||
api_models::payments::PaymentMethodData::BankTransfer(_) => {
|
||||
api_models::payments::AdditionalPaymentData::BankTransfer {}
|
||||
}
|
||||
api_models::payments::PaymentMethodData::Crypto(_) => {
|
||||
api_models::payments::AdditionalPaymentData::Crypto {}
|
||||
}
|
||||
api_models::payments::PaymentMethodData::BankDebit(_) => {
|
||||
api_models::payments::AdditionalPaymentData::BankDebit {}
|
||||
}
|
||||
api_models::payments::PaymentMethodData::MandatePayment => {
|
||||
api_models::payments::AdditionalPaymentData::MandatePayment {}
|
||||
}
|
||||
api_models::payments::PaymentMethodData::Reward(_) => {
|
||||
api_models::payments::AdditionalPaymentData::Reward {}
|
||||
}
|
||||
api_models::payments::PaymentMethodData::Upi(_) => {
|
||||
api_models::payments::AdditionalPaymentData::Upi {}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user