mirror of
				https://github.com/juspay/hyperswitch.git
				synced 2025-10-26 19:04:36 +08:00 
			
		
		
		
	feat(webhooks): Adding event search option in the webhooks page (#9907)
Co-authored-by: hyperswitch-bot[bot] <148525504+hyperswitch-bot[bot]@users.noreply.github.com>
This commit is contained in:
		 Venu Madhav Bandarupalli
					Venu Madhav Bandarupalli
				
			
				
					committed by
					
						 GitHub
						GitHub
					
				
			
			
				
	
			
			
			 GitHub
						GitHub
					
				
			
						parent
						
							8fd8884d5c
						
					
				
				
					commit
					b0d5a1b046
				
			| @ -16103,6 +16103,11 @@ | |||||||
|             "description": "Filter all events associated with the specified object identifier (Payment Intent ID,\nRefund ID, etc.)", |             "description": "Filter all events associated with the specified object identifier (Payment Intent ID,\nRefund ID, etc.)", | ||||||
|             "nullable": true |             "nullable": true | ||||||
|           }, |           }, | ||||||
|  |           "event_id": { | ||||||
|  |             "type": "string", | ||||||
|  |             "description": "Filter all events associated with the specified Event_id", | ||||||
|  |             "nullable": true | ||||||
|  |           }, | ||||||
|           "profile_id": { |           "profile_id": { | ||||||
|             "type": "string", |             "type": "string", | ||||||
|             "description": "Filter all events associated with the specified business profile ID.", |             "description": "Filter all events associated with the specified business profile ID.", | ||||||
|  | |||||||
| @ -27,6 +27,9 @@ pub struct EventListConstraints { | |||||||
|     /// Refund ID, etc.) |     /// Refund ID, etc.) | ||||||
|     pub object_id: Option<String>, |     pub object_id: Option<String>, | ||||||
|  |  | ||||||
|  |     /// Filter all events associated with the specified Event_id | ||||||
|  |     pub event_id: Option<String>, | ||||||
|  |  | ||||||
|     /// Filter all events associated with the specified business profile ID. |     /// Filter all events associated with the specified business profile ID. | ||||||
|     #[schema(value_type = Option<String>)] |     #[schema(value_type = Option<String>)] | ||||||
|     pub profile_id: Option<common_utils::id_type::ProfileId>, |     pub profile_id: Option<common_utils::id_type::ProfileId>, | ||||||
| @ -53,6 +56,7 @@ pub enum EventListConstraintsInternal { | |||||||
|     }, |     }, | ||||||
|     ObjectIdFilter { |     ObjectIdFilter { | ||||||
|         object_id: String, |         object_id: String, | ||||||
|  |         event_id: String, | ||||||
|     }, |     }, | ||||||
| } | } | ||||||
|  |  | ||||||
|  | |||||||
| @ -46,10 +46,11 @@ impl Event { | |||||||
|         .await |         .await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn list_initial_attempts_by_merchant_id_primary_object_id( |     pub async fn list_initial_attempts_by_merchant_id_primary_object_id_or_initial_attempt_id( | ||||||
|         conn: &PgPooledConn, |         conn: &PgPooledConn, | ||||||
|         merchant_id: &common_utils::id_type::MerchantId, |         merchant_id: &common_utils::id_type::MerchantId, | ||||||
|         primary_object_id: &str, |         primary_object_id: &str, | ||||||
|  |         initial_attempt_id: &str, | ||||||
|     ) -> StorageResult<Vec<Self>> { |     ) -> StorageResult<Vec<Self>> { | ||||||
|         generics::generic_filter::<<Self as HasTable>::Table, _, _, _>( |         generics::generic_filter::<<Self as HasTable>::Table, _, _, _>( | ||||||
|             conn, |             conn, | ||||||
| @ -57,7 +58,11 @@ impl Event { | |||||||
|                 .nullable() |                 .nullable() | ||||||
|                 .eq(dsl::initial_attempt_id) // Filter initial attempts only |                 .eq(dsl::initial_attempt_id) // Filter initial attempts only | ||||||
|                 .and(dsl::merchant_id.eq(merchant_id.to_owned())) |                 .and(dsl::merchant_id.eq(merchant_id.to_owned())) | ||||||
|                 .and(dsl::primary_object_id.eq(primary_object_id.to_owned())), |                 .and( | ||||||
|  |                     dsl::primary_object_id | ||||||
|  |                         .eq(primary_object_id.to_owned()) | ||||||
|  |                         .or(dsl::initial_attempt_id.eq(initial_attempt_id.to_owned())), | ||||||
|  |                 ), | ||||||
|             None, |             None, | ||||||
|             None, |             None, | ||||||
|             Some(dsl::created_at.desc()), |             Some(dsl::created_at.desc()), | ||||||
| @ -129,10 +134,11 @@ impl Event { | |||||||
|         .await |         .await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn list_initial_attempts_by_profile_id_primary_object_id( |     pub async fn list_initial_attempts_by_profile_id_primary_object_id_or_initial_attempt_id( | ||||||
|         conn: &PgPooledConn, |         conn: &PgPooledConn, | ||||||
|         profile_id: &common_utils::id_type::ProfileId, |         profile_id: &common_utils::id_type::ProfileId, | ||||||
|         primary_object_id: &str, |         primary_object_id: &str, | ||||||
|  |         initial_attempt_id: &str, | ||||||
|     ) -> StorageResult<Vec<Self>> { |     ) -> StorageResult<Vec<Self>> { | ||||||
|         generics::generic_filter::<<Self as HasTable>::Table, _, _, _>( |         generics::generic_filter::<<Self as HasTable>::Table, _, _, _>( | ||||||
|             conn, |             conn, | ||||||
| @ -140,7 +146,11 @@ impl Event { | |||||||
|                 .nullable() |                 .nullable() | ||||||
|                 .eq(dsl::initial_attempt_id) // Filter initial attempts only |                 .eq(dsl::initial_attempt_id) // Filter initial attempts only | ||||||
|                 .and(dsl::business_profile_id.eq(profile_id.to_owned())) |                 .and(dsl::business_profile_id.eq(profile_id.to_owned())) | ||||||
|                 .and(dsl::primary_object_id.eq(primary_object_id.to_owned())), |                 .and( | ||||||
|  |                     dsl::primary_object_id | ||||||
|  |                         .eq(primary_object_id.to_owned()) | ||||||
|  |                         .or(dsl::initial_attempt_id.eq(initial_attempt_id.to_owned())), | ||||||
|  |                 ), | ||||||
|             None, |             None, | ||||||
|             None, |             None, | ||||||
|             Some(dsl::created_at.desc()), |             Some(dsl::created_at.desc()), | ||||||
|  | |||||||
| @ -43,31 +43,35 @@ pub async fn list_initial_delivery_attempts( | |||||||
|         (now.date() - time::Duration::days(INITIAL_DELIVERY_ATTEMPTS_LIST_MAX_DAYS)).midnight(); |         (now.date() - time::Duration::days(INITIAL_DELIVERY_ATTEMPTS_LIST_MAX_DAYS)).midnight(); | ||||||
|  |  | ||||||
|     let (events, total_count) = match constraints { |     let (events, total_count) = match constraints { | ||||||
|         api_models::webhook_events::EventListConstraintsInternal::ObjectIdFilter { object_id } => { |         api_models::webhook_events::EventListConstraintsInternal::ObjectIdFilter { | ||||||
|             let events = match account { |             object_id, | ||||||
|                 MerchantAccountOrProfile::MerchantAccount(merchant_account) => { |             event_id, | ||||||
|                     store |         } => { | ||||||
|                         .list_initial_events_by_merchant_id_primary_object_id( |             let events = | ||||||
|  |                 match account { | ||||||
|  |                     MerchantAccountOrProfile::MerchantAccount(merchant_account) => store | ||||||
|  |                         .list_initial_events_by_merchant_id_primary_object_or_initial_attempt_id( | ||||||
|                             key_manager_state, |                             key_manager_state, | ||||||
|                             merchant_account.get_id(), |                             merchant_account.get_id(), | ||||||
|                             &object_id, |                             &object_id, | ||||||
|  |                             &event_id, | ||||||
|                             &key_store, |                             &key_store, | ||||||
|                         ) |                         ) | ||||||
|                         .await |                         .await, | ||||||
|  |                     MerchantAccountOrProfile::Profile(business_profile) => { | ||||||
|  |                         store | ||||||
|  |                             .list_initial_events_by_profile_id_primary_object_or_initial_attempt_id( | ||||||
|  |                                 key_manager_state, | ||||||
|  |                                 business_profile.get_id(), | ||||||
|  |                                 &object_id, | ||||||
|  |                                 &event_id, | ||||||
|  |                                 &key_store, | ||||||
|  |                             ) | ||||||
|  |                             .await | ||||||
|  |                     } | ||||||
|                 } |                 } | ||||||
|                 MerchantAccountOrProfile::Profile(business_profile) => { |                 .change_context(errors::ApiErrorResponse::InternalServerError) | ||||||
|                     store |                 .attach_printable("Failed to list events with specified constraints")?; | ||||||
|                         .list_initial_events_by_profile_id_primary_object_id( |  | ||||||
|                             key_manager_state, |  | ||||||
|                             business_profile.get_id(), |  | ||||||
|                             &object_id, |  | ||||||
|                             &key_store, |  | ||||||
|                         ) |  | ||||||
|                         .await |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             .change_context(errors::ApiErrorResponse::InternalServerError) |  | ||||||
|             .attach_printable("Failed to list events with specified constraints")?; |  | ||||||
|  |  | ||||||
|             let total_count = i64::try_from(events.len()) |             let total_count = i64::try_from(events.len()) | ||||||
|                 .change_context(errors::ApiErrorResponse::InternalServerError) |                 .change_context(errors::ApiErrorResponse::InternalServerError) | ||||||
|  | |||||||
| @ -46,11 +46,12 @@ where | |||||||
|         merchant_key_store: &domain::MerchantKeyStore, |         merchant_key_store: &domain::MerchantKeyStore, | ||||||
|     ) -> CustomResult<domain::Event, errors::StorageError>; |     ) -> CustomResult<domain::Event, errors::StorageError>; | ||||||
|  |  | ||||||
|     async fn list_initial_events_by_merchant_id_primary_object_id( |     async fn list_initial_events_by_merchant_id_primary_object_or_initial_attempt_id( | ||||||
|         &self, |         &self, | ||||||
|         state: &KeyManagerState, |         state: &KeyManagerState, | ||||||
|         merchant_id: &common_utils::id_type::MerchantId, |         merchant_id: &common_utils::id_type::MerchantId, | ||||||
|         primary_object_id: &str, |         primary_object_id: &str, | ||||||
|  |         initial_attempt_id: &str, | ||||||
|         merchant_key_store: &domain::MerchantKeyStore, |         merchant_key_store: &domain::MerchantKeyStore, | ||||||
|     ) -> CustomResult<Vec<domain::Event>, errors::StorageError>; |     ) -> CustomResult<Vec<domain::Event>, errors::StorageError>; | ||||||
|  |  | ||||||
| @ -76,11 +77,12 @@ where | |||||||
|         merchant_key_store: &domain::MerchantKeyStore, |         merchant_key_store: &domain::MerchantKeyStore, | ||||||
|     ) -> CustomResult<Vec<domain::Event>, errors::StorageError>; |     ) -> CustomResult<Vec<domain::Event>, errors::StorageError>; | ||||||
|  |  | ||||||
|     async fn list_initial_events_by_profile_id_primary_object_id( |     async fn list_initial_events_by_profile_id_primary_object_or_initial_attempt_id( | ||||||
|         &self, |         &self, | ||||||
|         state: &KeyManagerState, |         state: &KeyManagerState, | ||||||
|         profile_id: &common_utils::id_type::ProfileId, |         profile_id: &common_utils::id_type::ProfileId, | ||||||
|         primary_object_id: &str, |         primary_object_id: &str, | ||||||
|  |         initial_attempt_id: &str, | ||||||
|         merchant_key_store: &domain::MerchantKeyStore, |         merchant_key_store: &domain::MerchantKeyStore, | ||||||
|     ) -> CustomResult<Vec<domain::Event>, errors::StorageError>; |     ) -> CustomResult<Vec<domain::Event>, errors::StorageError>; | ||||||
|  |  | ||||||
| @ -191,18 +193,20 @@ impl EventInterface for Store { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     #[instrument(skip_all)] |     #[instrument(skip_all)] | ||||||
|     async fn list_initial_events_by_merchant_id_primary_object_id( |     async fn list_initial_events_by_merchant_id_primary_object_or_initial_attempt_id( | ||||||
|         &self, |         &self, | ||||||
|         state: &KeyManagerState, |         state: &KeyManagerState, | ||||||
|         merchant_id: &common_utils::id_type::MerchantId, |         merchant_id: &common_utils::id_type::MerchantId, | ||||||
|         primary_object_id: &str, |         primary_object_id: &str, | ||||||
|  |         initial_attempt_id: &str, | ||||||
|         merchant_key_store: &domain::MerchantKeyStore, |         merchant_key_store: &domain::MerchantKeyStore, | ||||||
|     ) -> CustomResult<Vec<domain::Event>, errors::StorageError> { |     ) -> CustomResult<Vec<domain::Event>, errors::StorageError> { | ||||||
|         let conn = connection::pg_connection_read(self).await?; |         let conn = connection::pg_connection_read(self).await?; | ||||||
|         storage::Event::list_initial_attempts_by_merchant_id_primary_object_id( |         storage::Event::list_initial_attempts_by_merchant_id_primary_object_id_or_initial_attempt_id( | ||||||
|             &conn, |             &conn, | ||||||
|             merchant_id, |             merchant_id, | ||||||
|             primary_object_id, |             primary_object_id, | ||||||
|  |             initial_attempt_id, | ||||||
|         ) |         ) | ||||||
|         .await |         .await | ||||||
|         .map_err(|error| report!(errors::StorageError::from(error))) |         .map_err(|error| report!(errors::StorageError::from(error))) | ||||||
| @ -306,18 +310,20 @@ impl EventInterface for Store { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     #[instrument(skip_all)] |     #[instrument(skip_all)] | ||||||
|     async fn list_initial_events_by_profile_id_primary_object_id( |     async fn list_initial_events_by_profile_id_primary_object_or_initial_attempt_id( | ||||||
|         &self, |         &self, | ||||||
|         state: &KeyManagerState, |         state: &KeyManagerState, | ||||||
|         profile_id: &common_utils::id_type::ProfileId, |         profile_id: &common_utils::id_type::ProfileId, | ||||||
|         primary_object_id: &str, |         primary_object_id: &str, | ||||||
|  |         initial_attempt_id: &str, | ||||||
|         merchant_key_store: &domain::MerchantKeyStore, |         merchant_key_store: &domain::MerchantKeyStore, | ||||||
|     ) -> CustomResult<Vec<domain::Event>, errors::StorageError> { |     ) -> CustomResult<Vec<domain::Event>, errors::StorageError> { | ||||||
|         let conn = connection::pg_connection_read(self).await?; |         let conn = connection::pg_connection_read(self).await?; | ||||||
|         storage::Event::list_initial_attempts_by_profile_id_primary_object_id( |         storage::Event::list_initial_attempts_by_profile_id_primary_object_id_or_initial_attempt_id( | ||||||
|             &conn, |             &conn, | ||||||
|             profile_id, |             profile_id, | ||||||
|             primary_object_id, |             primary_object_id, | ||||||
|  |             initial_attempt_id, | ||||||
|         ) |         ) | ||||||
|         .await |         .await | ||||||
|         .map_err(|error| report!(errors::StorageError::from(error))) |         .map_err(|error| report!(errors::StorageError::from(error))) | ||||||
| @ -527,11 +533,12 @@ impl EventInterface for MockDb { | |||||||
|             ) |             ) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     async fn list_initial_events_by_merchant_id_primary_object_id( |     async fn list_initial_events_by_merchant_id_primary_object_or_initial_attempt_id( | ||||||
|         &self, |         &self, | ||||||
|         state: &KeyManagerState, |         state: &KeyManagerState, | ||||||
|         merchant_id: &common_utils::id_type::MerchantId, |         merchant_id: &common_utils::id_type::MerchantId, | ||||||
|         primary_object_id: &str, |         primary_object_id: &str, | ||||||
|  |         initial_attempt_id: &str, | ||||||
|         merchant_key_store: &domain::MerchantKeyStore, |         merchant_key_store: &domain::MerchantKeyStore, | ||||||
|     ) -> CustomResult<Vec<domain::Event>, errors::StorageError> { |     ) -> CustomResult<Vec<domain::Event>, errors::StorageError> { | ||||||
|         let locked_events = self.events.lock().await; |         let locked_events = self.events.lock().await; | ||||||
| @ -539,8 +546,9 @@ impl EventInterface for MockDb { | |||||||
|             .iter() |             .iter() | ||||||
|             .filter(|event| { |             .filter(|event| { | ||||||
|                 event.merchant_id == Some(merchant_id.to_owned()) |                 event.merchant_id == Some(merchant_id.to_owned()) | ||||||
|                     && event.initial_attempt_id.as_ref() == Some(&event.event_id) |                     && event.initial_attempt_id.as_deref() == Some(&event.event_id) | ||||||
|                     && event.primary_object_id == primary_object_id |                     && (event.primary_object_id == primary_object_id | ||||||
|  |                         || event.initial_attempt_id.as_deref() == Some(initial_attempt_id)) | ||||||
|             }) |             }) | ||||||
|             .cloned() |             .cloned() | ||||||
|             .collect::<Vec<_>>(); |             .collect::<Vec<_>>(); | ||||||
| @ -663,11 +671,12 @@ impl EventInterface for MockDb { | |||||||
|         Ok(domain_events) |         Ok(domain_events) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     async fn list_initial_events_by_profile_id_primary_object_id( |     async fn list_initial_events_by_profile_id_primary_object_or_initial_attempt_id( | ||||||
|         &self, |         &self, | ||||||
|         state: &KeyManagerState, |         state: &KeyManagerState, | ||||||
|         profile_id: &common_utils::id_type::ProfileId, |         profile_id: &common_utils::id_type::ProfileId, | ||||||
|         primary_object_id: &str, |         primary_object_id: &str, | ||||||
|  |         initial_attempt_id: &str, | ||||||
|         merchant_key_store: &domain::MerchantKeyStore, |         merchant_key_store: &domain::MerchantKeyStore, | ||||||
|     ) -> CustomResult<Vec<domain::Event>, errors::StorageError> { |     ) -> CustomResult<Vec<domain::Event>, errors::StorageError> { | ||||||
|         let locked_events = self.events.lock().await; |         let locked_events = self.events.lock().await; | ||||||
| @ -676,7 +685,8 @@ impl EventInterface for MockDb { | |||||||
|             .filter(|event| { |             .filter(|event| { | ||||||
|                 event.business_profile_id == Some(profile_id.to_owned()) |                 event.business_profile_id == Some(profile_id.to_owned()) | ||||||
|                     && event.initial_attempt_id.as_ref() == Some(&event.event_id) |                     && event.initial_attempt_id.as_ref() == Some(&event.event_id) | ||||||
|                     && event.primary_object_id == primary_object_id |                     && (event.primary_object_id == primary_object_id | ||||||
|  |                         || event.initial_attempt_id.as_deref() == Some(initial_attempt_id)) | ||||||
|             }) |             }) | ||||||
|             .cloned() |             .cloned() | ||||||
|             .collect::<Vec<_>>(); |             .collect::<Vec<_>>(); | ||||||
| @ -1310,6 +1320,7 @@ mod tests { | |||||||
|         let event_type = enums::EventType::PaymentSucceeded; |         let event_type = enums::EventType::PaymentSucceeded; | ||||||
|         let event_class = enums::EventClass::Payments; |         let event_class = enums::EventClass::Payments; | ||||||
|         let primary_object_id = Arc::new("concurrent_payment_id".to_string()); |         let primary_object_id = Arc::new("concurrent_payment_id".to_string()); | ||||||
|  |         let initial_attempt_id = Arc::new("initial_attempt_id".to_string()); | ||||||
|         let primary_object_type = enums::EventObjectType::PaymentDetails; |         let primary_object_type = enums::EventObjectType::PaymentDetails; | ||||||
|         let payment_id = common_utils::id_type::PaymentId::try_from(std::borrow::Cow::Borrowed( |         let payment_id = common_utils::id_type::PaymentId::try_from(std::borrow::Cow::Borrowed( | ||||||
|             "pay_mbabizu24mvu3mela5njyhpit10", |             "pay_mbabizu24mvu3mela5njyhpit10", | ||||||
| @ -1462,10 +1473,11 @@ mod tests { | |||||||
|         // Collect all initial-attempt events for this payment |         // Collect all initial-attempt events for this payment | ||||||
|         let events = state |         let events = state | ||||||
|             .store |             .store | ||||||
|             .list_initial_events_by_merchant_id_primary_object_id( |             .list_initial_events_by_merchant_id_primary_object_or_initial_attempt_id( | ||||||
|                 key_manager_state, |                 key_manager_state, | ||||||
|                 &business_profile.merchant_id, |                 &business_profile.merchant_id, | ||||||
|                 &primary_object_id.clone(), |                 &primary_object_id.clone(), | ||||||
|  |                 &initial_attempt_id.clone(), | ||||||
|                 merchant_context.get_merchant_key_store(), |                 merchant_context.get_merchant_key_store(), | ||||||
|             ) |             ) | ||||||
|             .await?; |             .await?; | ||||||
|  | |||||||
| @ -782,18 +782,20 @@ impl EventInterface for KafkaStore { | |||||||
|             .await |             .await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     async fn list_initial_events_by_merchant_id_primary_object_id( |     async fn list_initial_events_by_merchant_id_primary_object_or_initial_attempt_id( | ||||||
|         &self, |         &self, | ||||||
|         state: &KeyManagerState, |         state: &KeyManagerState, | ||||||
|         merchant_id: &id_type::MerchantId, |         merchant_id: &id_type::MerchantId, | ||||||
|         primary_object_id: &str, |         primary_object_id: &str, | ||||||
|  |         initial_attempt_id: &str, | ||||||
|         merchant_key_store: &domain::MerchantKeyStore, |         merchant_key_store: &domain::MerchantKeyStore, | ||||||
|     ) -> CustomResult<Vec<domain::Event>, errors::StorageError> { |     ) -> CustomResult<Vec<domain::Event>, errors::StorageError> { | ||||||
|         self.diesel_store |         self.diesel_store | ||||||
|             .list_initial_events_by_merchant_id_primary_object_id( |             .list_initial_events_by_merchant_id_primary_object_or_initial_attempt_id( | ||||||
|                 state, |                 state, | ||||||
|                 merchant_id, |                 merchant_id, | ||||||
|                 primary_object_id, |                 primary_object_id, | ||||||
|  |                 initial_attempt_id, | ||||||
|                 merchant_key_store, |                 merchant_key_store, | ||||||
|             ) |             ) | ||||||
|             .await |             .await | ||||||
| @ -843,18 +845,20 @@ impl EventInterface for KafkaStore { | |||||||
|             .await |             .await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     async fn list_initial_events_by_profile_id_primary_object_id( |     async fn list_initial_events_by_profile_id_primary_object_or_initial_attempt_id( | ||||||
|         &self, |         &self, | ||||||
|         state: &KeyManagerState, |         state: &KeyManagerState, | ||||||
|         profile_id: &id_type::ProfileId, |         profile_id: &id_type::ProfileId, | ||||||
|         primary_object_id: &str, |         primary_object_id: &str, | ||||||
|  |         initial_attempt_id: &str, | ||||||
|         merchant_key_store: &domain::MerchantKeyStore, |         merchant_key_store: &domain::MerchantKeyStore, | ||||||
|     ) -> CustomResult<Vec<domain::Event>, errors::StorageError> { |     ) -> CustomResult<Vec<domain::Event>, errors::StorageError> { | ||||||
|         self.diesel_store |         self.diesel_store | ||||||
|             .list_initial_events_by_profile_id_primary_object_id( |             .list_initial_events_by_profile_id_primary_object_or_initial_attempt_id( | ||||||
|                 state, |                 state, | ||||||
|                 profile_id, |                 profile_id, | ||||||
|                 primary_object_id, |                 primary_object_id, | ||||||
|  |                 initial_attempt_id, | ||||||
|                 merchant_key_store, |                 merchant_key_store, | ||||||
|             ) |             ) | ||||||
|             .await |             .await | ||||||
|  | |||||||
| @ -1798,7 +1798,7 @@ impl ForeignTryFrom<api_types::webhook_events::EventListConstraints> | |||||||
|     fn foreign_try_from( |     fn foreign_try_from( | ||||||
|         item: api_types::webhook_events::EventListConstraints, |         item: api_types::webhook_events::EventListConstraints, | ||||||
|     ) -> Result<Self, Self::Error> { |     ) -> Result<Self, Self::Error> { | ||||||
|         if item.object_id.is_some() |         if (item.object_id.is_some() || item.event_id.is_some()) | ||||||
|             && (item.created_after.is_some() |             && (item.created_after.is_some() | ||||||
|                 || item.created_before.is_some() |                 || item.created_before.is_some() | ||||||
|                 || item.limit.is_some() |                 || item.limit.is_some() | ||||||
| @ -1808,15 +1808,29 @@ impl ForeignTryFrom<api_types::webhook_events::EventListConstraints> | |||||||
|         { |         { | ||||||
|             return Err(report!(errors::ApiErrorResponse::PreconditionFailed { |             return Err(report!(errors::ApiErrorResponse::PreconditionFailed { | ||||||
|                 message: |                 message: | ||||||
|                     "Either only `object_id` must be specified, or one or more of \ |                      "Either only `object_id` or `event_id` must be specified, or one or more of \ | ||||||
|                           `created_after`, `created_before`, `limit`, `offset`, `event_classes` and `event_types` must be specified" |                                 `created_after`, `created_before`, `limit`, `offset`, `event_classes` and `event_types` must be specified" | ||||||
|                         .to_string() |                         .to_string() | ||||||
|             })); |             })); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         match item.object_id { |         match (item.object_id.clone(), item.event_id.clone()) { | ||||||
|             Some(object_id) => Ok(Self::ObjectIdFilter { object_id }), |             (Some(object_id), Some(event_id)) => Ok(Self::ObjectIdFilter { | ||||||
|             None => Ok(Self::GenericFilter { |                 object_id, | ||||||
|  |                 event_id, | ||||||
|  |             }), | ||||||
|  |  | ||||||
|  |             (Some(object_id), None) => Ok(Self::ObjectIdFilter { | ||||||
|  |                 event_id: object_id.clone(), | ||||||
|  |                 object_id, | ||||||
|  |             }), | ||||||
|  |  | ||||||
|  |             (None, Some(event_id)) => Ok(Self::ObjectIdFilter { | ||||||
|  |                 object_id: event_id.clone(), | ||||||
|  |                 event_id, | ||||||
|  |             }), | ||||||
|  |  | ||||||
|  |             (None, None) => Ok(Self::GenericFilter { | ||||||
|                 created_after: item.created_after, |                 created_after: item.created_after, | ||||||
|                 created_before: item.created_before, |                 created_before: item.created_before, | ||||||
|                 limit: item.limit.map(i64::from), |                 limit: item.limit.map(i64::from), | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user