Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/main' into worldpay-wallets-api-…
Browse files Browse the repository at this point in the history
…updates
  • Loading branch information
kashif-m committed Oct 18, 2024
2 parents e1fcfde + 451376e commit f43eff1
Show file tree
Hide file tree
Showing 31 changed files with 439 additions and 255 deletions.
19 changes: 19 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,25 @@ All notable changes to HyperSwitch will be documented here.

- - -

## 2024.10.18.0

### Features

- **router:** Add payments create-intent flow for v2 ([#6193](https://github.com/juspay/hyperswitch/pull/6193)) ([`afa803e`](https://github.com/juspay/hyperswitch/commit/afa803e0f9711f83b31ce53a59e867517a885963))
- **worldpay:** Migrate to v7 ([#6109](https://github.com/juspay/hyperswitch/pull/6109)) ([`962afbd`](https://github.com/juspay/hyperswitch/commit/962afbd084458e9afb11a0278a8210edd9226a3d))

### Bug Fixes

- **mandates:** Handle the connector_mandate creation once and only if the payment is charged ([#6327](https://github.com/juspay/hyperswitch/pull/6327)) ([`e14a0fe`](https://github.com/juspay/hyperswitch/commit/e14a0fe8f290a697126756ba2facc58234e5d135))
- **payments_list:** Skip count query if no filters and add logging ([#6331](https://github.com/juspay/hyperswitch/pull/6331)) ([`df2501c`](https://github.com/juspay/hyperswitch/commit/df2501ceafab6180e867953f7c298a541fcea757))
- **router:** Set the eligible connector in the payment attempt for nti based mit flow ([#6347](https://github.com/juspay/hyperswitch/pull/6347)) ([`1a3d0a6`](https://github.com/juspay/hyperswitch/commit/1a3d0a60f4e3b07786460621c14c5aa37510b53a))
- **users:** Add max wrong attempts for two-fa ([#6247](https://github.com/juspay/hyperswitch/pull/6247)) ([`2798f57`](https://github.com/juspay/hyperswitch/commit/2798f575605cc4439166344e57ff19b612f1304a))
- Set headers as optional in ob flows ([#6305](https://github.com/juspay/hyperswitch/pull/6305)) ([`9576ee3`](https://github.com/juspay/hyperswitch/commit/9576ee37a6468d79afc4be280749a2176a95e63b))

**Full Changelog:** [`2024.10.17.0...2024.10.18.0`](https://github.com/juspay/hyperswitch/compare/2024.10.17.0...2024.10.18.0)

- - -

## 2024.10.17.0

### Features
Expand Down
13 changes: 13 additions & 0 deletions crates/common_enums/src/enums.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3356,3 +3356,16 @@ pub enum SurchargeCalculationOverride {
/// Calculate surcharge
Calculate,
}

/// Connector Mandate Status
#[derive(
Clone, Copy, Debug, Eq, PartialEq, serde::Deserialize, serde::Serialize, strum::Display,
)]
#[strum(serialize_all = "snake_case")]
#[serde(rename_all = "snake_case")]
pub enum ConnectorMandateStatus {
/// Indicates that the connector mandate is active and can be used for payments.
Active,
/// Indicates that the connector mandate is not active and hence cannot be used for payments.
Inactive,
}
41 changes: 40 additions & 1 deletion crates/diesel_models/src/payment_attempt.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,16 @@ use crate::schema::payment_attempt;
#[cfg(feature = "v2")]
use crate::schema_v2::payment_attempt;

common_utils::impl_to_sql_from_sql_json!(ConnectorMandateReferenceId);
#[derive(
Clone, Debug, serde::Deserialize, serde::Serialize, Eq, PartialEq, diesel::AsExpression,
)]
#[diesel(sql_type = diesel::sql_types::Jsonb)]
pub struct ConnectorMandateReferenceId {
pub connector_mandate_id: Option<String>,
pub payment_method_id: Option<String>,
pub mandate_metadata: Option<serde_json::Value>,
}
#[cfg(feature = "v2")]
#[derive(
Clone, Debug, Eq, PartialEq, Identifiable, Queryable, Serialize, Deserialize, Selectable,
Expand Down Expand Up @@ -76,6 +86,7 @@ pub struct PaymentAttempt {
pub id: String,
pub shipping_cost: Option<MinorUnit>,
pub order_tax_amount: Option<MinorUnit>,
pub connector_mandate_detail: Option<ConnectorMandateReferenceId>,
}

#[cfg(feature = "v1")]
Expand Down Expand Up @@ -153,6 +164,7 @@ pub struct PaymentAttempt {
pub shipping_cost: Option<MinorUnit>,
pub order_tax_amount: Option<MinorUnit>,
pub connector_transaction_data: Option<String>,
pub connector_mandate_detail: Option<ConnectorMandateReferenceId>,
}

#[cfg(feature = "v1")]
Expand Down Expand Up @@ -256,6 +268,7 @@ pub struct PaymentAttemptNew {
pub card_network: Option<String>,
pub shipping_cost: Option<MinorUnit>,
pub order_tax_amount: Option<MinorUnit>,
pub connector_mandate_detail: Option<ConnectorMandateReferenceId>,
}

#[cfg(feature = "v1")]
Expand Down Expand Up @@ -328,6 +341,7 @@ pub struct PaymentAttemptNew {
pub card_network: Option<String>,
pub shipping_cost: Option<MinorUnit>,
pub order_tax_amount: Option<MinorUnit>,
pub connector_mandate_detail: Option<ConnectorMandateReferenceId>,
}

#[cfg(feature = "v1")]
Expand Down Expand Up @@ -442,6 +456,7 @@ pub enum PaymentAttemptUpdate {
unified_message: Option<Option<String>>,
payment_method_data: Option<serde_json::Value>,
charge_id: Option<String>,
connector_mandate_detail: Option<ConnectorMandateReferenceId>,
},
UnresolvedResponseUpdate {
status: storage_enums::AttemptStatus,
Expand Down Expand Up @@ -757,6 +772,7 @@ pub struct PaymentAttemptUpdateInternal {
customer_acceptance: Option<pii::SecretSerdeValue>,
card_network: Option<String>,
connector_payment_data: Option<String>,
connector_mandate_detail: Option<ConnectorMandateReferenceId>,
}

#[cfg(feature = "v1")]
Expand Down Expand Up @@ -813,6 +829,7 @@ pub struct PaymentAttemptUpdateInternal {
pub shipping_cost: Option<MinorUnit>,
pub order_tax_amount: Option<MinorUnit>,
pub connector_transaction_data: Option<String>,
pub connector_mandate_detail: Option<ConnectorMandateReferenceId>,
}

#[cfg(feature = "v2")]
Expand Down Expand Up @@ -1002,6 +1019,7 @@ impl PaymentAttemptUpdate {
shipping_cost,
order_tax_amount,
connector_transaction_data,
connector_mandate_detail,
} = PaymentAttemptUpdateInternal::from(self).populate_derived_fields(&source);
PaymentAttempt {
amount: amount.unwrap_or(source.amount),
Expand Down Expand Up @@ -1059,6 +1077,7 @@ impl PaymentAttemptUpdate {
order_tax_amount: order_tax_amount.or(source.order_tax_amount),
connector_transaction_data: connector_transaction_data
.or(source.connector_transaction_data),
connector_mandate_detail: connector_mandate_detail.or(source.connector_mandate_detail),
..source
}
}
Expand Down Expand Up @@ -2054,6 +2073,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost: None,
order_tax_amount: None,
connector_transaction_data: None,
connector_mandate_detail: None,
},
PaymentAttemptUpdate::AuthenticationTypeUpdate {
authentication_type,
Expand Down Expand Up @@ -2109,6 +2129,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost: None,
order_tax_amount: None,
connector_transaction_data: None,
connector_mandate_detail: None,
},
PaymentAttemptUpdate::ConfirmUpdate {
amount,
Expand Down Expand Up @@ -2194,6 +2215,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost,
order_tax_amount,
connector_transaction_data: None,
connector_mandate_detail: None,
},
PaymentAttemptUpdate::VoidUpdate {
status,
Expand Down Expand Up @@ -2250,6 +2272,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost: None,
order_tax_amount: None,
connector_transaction_data: None,
connector_mandate_detail: None,
},
PaymentAttemptUpdate::RejectUpdate {
status,
Expand Down Expand Up @@ -2307,6 +2330,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost: None,
order_tax_amount: None,
connector_transaction_data: None,
connector_mandate_detail: None,
},
PaymentAttemptUpdate::BlocklistUpdate {
status,
Expand Down Expand Up @@ -2364,6 +2388,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost: None,
order_tax_amount: None,
connector_transaction_data: None,
connector_mandate_detail: None,
},
PaymentAttemptUpdate::PaymentMethodDetailsUpdate {
payment_method_id,
Expand Down Expand Up @@ -2419,6 +2444,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost: None,
order_tax_amount: None,
connector_transaction_data: None,
connector_mandate_detail: None,
},
PaymentAttemptUpdate::ResponseUpdate {
status,
Expand All @@ -2441,6 +2467,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
unified_message,
payment_method_data,
charge_id,
connector_mandate_detail,
} => {
let (connector_transaction_id, connector_transaction_data) =
connector_transaction_id
Expand Down Expand Up @@ -2498,6 +2525,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
card_network: None,
shipping_cost: None,
order_tax_amount: None,
connector_mandate_detail,
}
}
PaymentAttemptUpdate::ErrorUpdate {
Expand Down Expand Up @@ -2570,6 +2598,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
card_network: None,
shipping_cost: None,
order_tax_amount: None,
connector_mandate_detail: None,
}
}
PaymentAttemptUpdate::StatusUpdate { status, updated_by } => Self {
Expand Down Expand Up @@ -2623,6 +2652,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost: None,
order_tax_amount: None,
connector_transaction_data: None,
connector_mandate_detail: None,
},
PaymentAttemptUpdate::UpdateTrackers {
payment_token,
Expand Down Expand Up @@ -2684,6 +2714,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost: None,
order_tax_amount: None,
connector_transaction_data: None,
connector_mandate_detail: None,
},
PaymentAttemptUpdate::UnresolvedResponseUpdate {
status,
Expand Down Expand Up @@ -2752,6 +2783,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
card_network: None,
shipping_cost: None,
order_tax_amount: None,
connector_mandate_detail: None,
}
}
PaymentAttemptUpdate::PreprocessingUpdate {
Expand Down Expand Up @@ -2819,6 +2851,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
card_network: None,
shipping_cost: None,
order_tax_amount: None,
connector_mandate_detail: None,
}
}
PaymentAttemptUpdate::CaptureUpdate {
Expand Down Expand Up @@ -2876,6 +2909,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost: None,
order_tax_amount: None,
connector_transaction_data: None,
connector_mandate_detail: None,
},
PaymentAttemptUpdate::AmountToCaptureUpdate {
status,
Expand Down Expand Up @@ -2932,6 +2966,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost: None,
order_tax_amount: None,
connector_transaction_data: None,
connector_mandate_detail: None,
},
PaymentAttemptUpdate::ConnectorResponse {
authentication_data,
Expand Down Expand Up @@ -2997,6 +3032,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
card_network: None,
shipping_cost: None,
order_tax_amount: None,
connector_mandate_detail: None,
}
}
PaymentAttemptUpdate::IncrementalAuthorizationAmountUpdate {
Expand Down Expand Up @@ -3053,6 +3089,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost: None,
order_tax_amount: None,
connector_transaction_data: None,
connector_mandate_detail: None,
},
PaymentAttemptUpdate::AuthenticationUpdate {
status,
Expand Down Expand Up @@ -3111,6 +3148,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost: None,
order_tax_amount: None,
connector_transaction_data: None,
connector_mandate_detail: None,
},
PaymentAttemptUpdate::ManualUpdate {
status,
Expand Down Expand Up @@ -3178,6 +3216,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
card_network: None,
shipping_cost: None,
order_tax_amount: None,
connector_mandate_detail: None,
}
}
PaymentAttemptUpdate::PostSessionTokensUpdate {
Expand Down Expand Up @@ -3234,6 +3273,7 @@ impl From<PaymentAttemptUpdate> for PaymentAttemptUpdateInternal {
shipping_cost: None,
order_tax_amount: None,
connector_transaction_data: None,
connector_mandate_detail: None,
},
}
}
Expand Down Expand Up @@ -3319,7 +3359,6 @@ mod tests {
"user_agent": "amet irure esse"
}
},
"mandate_type": {
"single_use": {
"amount": 6540,
"currency": "USD"
Expand Down
1 change: 1 addition & 0 deletions crates/diesel_models/src/schema.rs
Original file line number Diff line number Diff line change
Expand Up @@ -850,6 +850,7 @@ diesel::table! {
order_tax_amount -> Nullable<Int8>,
#[max_length = 512]
connector_transaction_data -> Nullable<Varchar>,
connector_mandate_detail -> Nullable<Jsonb>,
}
}

Expand Down
1 change: 1 addition & 0 deletions crates/diesel_models/src/schema_v2.rs
Original file line number Diff line number Diff line change
Expand Up @@ -821,6 +821,7 @@ diesel::table! {
id -> Varchar,
shipping_cost -> Nullable<Int8>,
order_tax_amount -> Nullable<Int8>,
connector_mandate_detail -> Nullable<Jsonb>,
}
}

Expand Down
4 changes: 3 additions & 1 deletion crates/diesel_models/src/user/sample_data.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ use crate::schema::payment_attempt;
use crate::schema_v2::payment_attempt;
use crate::{
enums::{MandateDataType, MandateDetails},
PaymentAttemptNew,
ConnectorMandateReferenceId, PaymentAttemptNew,
};

#[cfg(feature = "v2")]
Expand Down Expand Up @@ -204,6 +204,7 @@ pub struct PaymentAttemptBatchNew {
pub shipping_cost: Option<MinorUnit>,
pub order_tax_amount: Option<MinorUnit>,
pub connector_transaction_data: Option<String>,
pub connector_mandate_detail: Option<ConnectorMandateReferenceId>,
}

#[cfg(feature = "v1")]
Expand Down Expand Up @@ -282,6 +283,7 @@ impl PaymentAttemptBatchNew {
organization_id: self.organization_id,
shipping_cost: self.shipping_cost,
order_tax_amount: self.order_tax_amount,
connector_mandate_detail: self.connector_mandate_detail,
}
}
}
Loading

0 comments on commit f43eff1

Please sign in to comment.