Skip to content

Commit

Permalink
fix: update card_scheme while saving cards
Browse files Browse the repository at this point in the history
  • Loading branch information
Sakilmostak committed Dec 17, 2024
1 parent fa1a33b commit 99e7704
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 6 deletions.
16 changes: 15 additions & 1 deletion crates/diesel_models/src/payment_method.rs
Original file line number Diff line number Diff line change
Expand Up @@ -219,6 +219,7 @@ pub enum PaymentMethodUpdate {
},
UpdatePaymentMethodDataAndLastUsed {
payment_method_data: Option<Encryption>,
scheme: Option<String>,
last_used_at: PrimitiveDateTime,
},
PaymentMethodDataUpdate {
Expand Down Expand Up @@ -395,6 +396,7 @@ pub struct PaymentMethodUpdateInternal {
last_modified: PrimitiveDateTime,
network_token_locker_id: Option<String>,
network_token_payment_method_data: Option<Encryption>,
scheme: Option<String>,
}

#[cfg(all(
Expand All @@ -419,14 +421,15 @@ impl PaymentMethodUpdateInternal {
last_modified,
network_token_locker_id,
network_token_payment_method_data,
scheme,
} = self;

PaymentMethod {
customer_id: source.customer_id,
merchant_id: source.merchant_id,
payment_method_id: source.payment_method_id,
accepted_currency: source.accepted_currency,
scheme: source.scheme,
scheme: scheme.or(source.scheme),
token: source.token,
cardholder_name: source.cardholder_name,
issuer_name: source.issuer_name,
Expand Down Expand Up @@ -489,6 +492,7 @@ impl From<PaymentMethodUpdate> for PaymentMethodUpdateInternal {
last_modified: common_utils::date_time::now(),
network_token_locker_id: None,
network_token_payment_method_data: None,
scheme: None,
},
PaymentMethodUpdate::PaymentMethodDataUpdate {
payment_method_data,
Expand All @@ -508,6 +512,7 @@ impl From<PaymentMethodUpdate> for PaymentMethodUpdateInternal {
last_modified: common_utils::date_time::now(),
network_token_locker_id: None,
network_token_payment_method_data: None,
scheme: None,
},
PaymentMethodUpdate::LastUsedUpdate { last_used_at } => Self {
metadata: None,
Expand All @@ -525,9 +530,11 @@ impl From<PaymentMethodUpdate> for PaymentMethodUpdateInternal {
last_modified: common_utils::date_time::now(),
network_token_locker_id: None,
network_token_payment_method_data: None,
scheme: None,
},
PaymentMethodUpdate::UpdatePaymentMethodDataAndLastUsed {
payment_method_data,
scheme,
last_used_at,
} => Self {
metadata: None,
Expand All @@ -545,6 +552,7 @@ impl From<PaymentMethodUpdate> for PaymentMethodUpdateInternal {
last_modified: common_utils::date_time::now(),
network_token_locker_id: None,
network_token_payment_method_data: None,
scheme,
},
PaymentMethodUpdate::NetworkTransactionIdAndStatusUpdate {
network_transaction_id,
Expand All @@ -565,6 +573,7 @@ impl From<PaymentMethodUpdate> for PaymentMethodUpdateInternal {
last_modified: common_utils::date_time::now(),
network_token_locker_id: None,
network_token_payment_method_data: None,
scheme: None,
},
PaymentMethodUpdate::StatusUpdate { status } => Self {
metadata: None,
Expand All @@ -582,6 +591,7 @@ impl From<PaymentMethodUpdate> for PaymentMethodUpdateInternal {
last_modified: common_utils::date_time::now(),
network_token_locker_id: None,
network_token_payment_method_data: None,
scheme: None,
},
PaymentMethodUpdate::AdditionalDataUpdate {
payment_method_data,
Expand Down Expand Up @@ -609,6 +619,7 @@ impl From<PaymentMethodUpdate> for PaymentMethodUpdateInternal {
last_modified: common_utils::date_time::now(),
network_token_locker_id,
network_token_payment_method_data,
scheme: None,
},
PaymentMethodUpdate::ConnectorMandateDetailsUpdate {
connector_mandate_details,
Expand All @@ -628,6 +639,7 @@ impl From<PaymentMethodUpdate> for PaymentMethodUpdateInternal {
last_modified: common_utils::date_time::now(),
network_token_locker_id: None,
network_token_payment_method_data: None,
scheme: None,
},
PaymentMethodUpdate::NetworkTokenDataUpdate {
network_token_requestor_reference_id,
Expand All @@ -649,6 +661,7 @@ impl From<PaymentMethodUpdate> for PaymentMethodUpdateInternal {
network_token_requestor_reference_id,
network_token_locker_id,
network_token_payment_method_data,
scheme: None,
},
PaymentMethodUpdate::ConnectorNetworkTransactionIdAndMandateDetailsUpdate {
connector_mandate_details,
Expand All @@ -670,6 +683,7 @@ impl From<PaymentMethodUpdate> for PaymentMethodUpdateInternal {
network_token_requestor_reference_id: None,
network_token_locker_id: None,
network_token_payment_method_data: None,
scheme: None,
},
}
}
Expand Down
8 changes: 4 additions & 4 deletions crates/router/src/core/payment_methods/cards.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2796,9 +2796,11 @@ pub async fn update_payment_method_and_last_used(
pm: domain::PaymentMethod,
payment_method_update: Option<Encryption>,
storage_scheme: MerchantStorageScheme,
card_scheme: Option<String>,
) -> errors::CustomResult<(), errors::VaultError> {
let pm_update = payment_method::PaymentMethodUpdate::UpdatePaymentMethodDataAndLastUsed {
payment_method_data: payment_method_update,
scheme: card_scheme,
last_used_at: common_utils::date_time::now(),
};
db.update_payment_method(&(state.into()), key_store, pm, pm_update, storage_scheme)
Expand Down Expand Up @@ -5330,8 +5332,7 @@ pub async fn get_card_details_with_locker_fallback(
});

Ok(if let Some(mut crd) = card_decrypted {
let scheme = crd.card_network.clone().map(|cn| cn.to_string());
crd.scheme.clone_from(&scheme);
crd.scheme.clone_from(&pm.scheme);
Some(crd)
} else {
logger::debug!(
Expand Down Expand Up @@ -5360,8 +5361,7 @@ pub async fn get_card_details_without_locker_fallback(
});

Ok(if let Some(mut crd) = card_decrypted {
let scheme = crd.card_network.clone().map(|cn| cn.to_string());
crd.scheme.clone_from(&scheme);
crd.scheme.clone_from(&pm.scheme);
crd
} else {
logger::debug!(
Expand Down
10 changes: 9 additions & 1 deletion crates/router/src/core/payments/tokenization.rs
Original file line number Diff line number Diff line change
Expand Up @@ -549,8 +549,15 @@ where
let existing_pm_data = payment_methods::cards::get_card_details_without_locker_fallback(&existing_pm,state)
.await?;

// scheme should be updated in case of co-badged cards
let card_scheme = card
.card_network
.clone()
.map(|card_network| card_network.to_string())
.or(existing_pm_data.scheme.clone());

let updated_card = Some(CardDetailFromLocker {
scheme: existing_pm.scheme.clone(),
scheme: card_scheme.clone(),
last4_digits: Some(card.card_number.get_last4()),
issuer_country: card
.card_issuing_country
Expand Down Expand Up @@ -596,6 +603,7 @@ where
existing_pm,
pm_data_encrypted.map(Into::into),
merchant_account.storage_scheme,
card_scheme,
)
.await
.change_context(errors::ApiErrorResponse::InternalServerError)
Expand Down

0 comments on commit 99e7704

Please sign in to comment.