Skip to content

Commit

Permalink
Merge branch 'log-masked-incoming-wh-payload' into log-incoming-webho…
Browse files Browse the repository at this point in the history
…ok-payload
  • Loading branch information
prasunna09 committed Nov 13, 2023
2 parents 5638542 + de60989 commit e7fd445
Show file tree
Hide file tree
Showing 60 changed files with 164 additions and 196 deletions.
1 change: 1 addition & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion connector-template/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -485,7 +485,7 @@ impl api::IncomingWebhook for {{project-name | downcase | pascal_case}} {
fn get_webhook_resource_object(
&self,
_request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
Err(errors::ConnectorError::WebhooksNotImplemented).into_report()
}
}
1 change: 1 addition & 0 deletions crates/common_utils/src/ext_traits.rs
Original file line number Diff line number Diff line change
Expand Up @@ -223,6 +223,7 @@ pub trait ByteSliceExt {
}

impl ByteSliceExt for [u8] {
#[track_caller]
fn parse_struct<'de, T>(
&'de self,
type_name: &'static str,
Expand Down
1 change: 1 addition & 0 deletions crates/router/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,7 @@ scheduler = { version = "0.1.0", path = "../scheduler", default-features = false
data_models = { version = "0.1.0", path = "../data_models", default-features = false }
kgraph_utils = { version = "0.1.0", path = "../kgraph_utils" }
storage_impl = { version = "0.1.0", path = "../storage_impl", default-features = false }
erased-serde = "0.3.31"

[target.'cfg(not(target_os = "windows"))'.dependencies]
signal-hook-tokio = { version = "0.3.1", features = ["futures-v0_3"] }
Expand Down
2 changes: 1 addition & 1 deletion crates/router/src/connector/aci.rs
Original file line number Diff line number Diff line change
Expand Up @@ -572,7 +572,7 @@ impl api::IncomingWebhook for Aci {
fn get_webhook_resource_object(
&self,
_request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
Err(errors::ConnectorError::WebhooksNotImplemented).into_report()
}
}
8 changes: 2 additions & 6 deletions crates/router/src/connector/adyen.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1600,17 +1600,13 @@ impl api::IncomingWebhook for Adyen {
fn get_webhook_resource_object(
&self,
request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
let notif = get_webhook_object_from_body(request.body)
.change_context(errors::ConnectorError::WebhookEventTypeNotFound)?;

let response: adyen::Response = notif.into();

let res_json = serde_json::to_value(response)
.into_report()
.change_context(errors::ConnectorError::WebhookResourceObjectNotFound)?;

Ok(res_json)
Ok(Box::new(response))
}

fn get_webhook_api_response(
Expand Down
4 changes: 2 additions & 2 deletions crates/router/src/connector/airwallex.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1081,13 +1081,13 @@ impl api::IncomingWebhook for Airwallex {
fn get_webhook_resource_object(
&self,
request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
let details: airwallex::AirwallexWebhookObjectResource = request
.body
.parse_struct("AirwallexWebhookObjectResource")
.change_context(errors::ConnectorError::WebhookResourceObjectNotFound)?;

Ok(details.data.object)
Ok(Box::new(details.data.object))
}

fn get_dispute_details(
Expand Down
3 changes: 2 additions & 1 deletion crates/router/src/connector/airwallex/transformers.rs
Original file line number Diff line number Diff line change
Expand Up @@ -824,7 +824,8 @@ pub enum AirwallexDisputeStage {

#[derive(Debug, Deserialize)]
pub struct AirwallexWebhookDataResource {
pub object: serde_json::Value,
// Should this be a secret by default since it represents webhook payload
pub object: Secret<serde_json::Value>,
}

#[derive(Debug, Deserialize)]
Expand Down
10 changes: 4 additions & 6 deletions crates/router/src/connector/authorizedotnet.rs
Original file line number Diff line number Diff line change
Expand Up @@ -875,17 +875,15 @@ impl api::IncomingWebhook for Authorizedotnet {
fn get_webhook_resource_object(
&self,
request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
let payload: authorizedotnet::AuthorizedotnetWebhookObjectId = request
.body
.parse_struct("AuthorizedotnetWebhookObjectId")
.change_context(errors::ConnectorError::WebhookResourceObjectNotFound)?;
let sync_payload = serde_json::to_value(

Ok(Box::new(
authorizedotnet::AuthorizedotnetSyncResponse::try_from(payload)?,
)
.into_report()
.change_context(errors::ConnectorError::ResponseHandlingFailed)?;
Ok(sync_payload)
))
}
}

Expand Down
2 changes: 1 addition & 1 deletion crates/router/src/connector/bambora.rs
Original file line number Diff line number Diff line change
Expand Up @@ -685,7 +685,7 @@ impl api::IncomingWebhook for Bambora {
fn get_webhook_resource_object(
&self,
_request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
Err(errors::ConnectorError::WebhooksNotImplemented).into_report()
}
}
Expand Down
2 changes: 1 addition & 1 deletion crates/router/src/connector/bankofamerica.rs
Original file line number Diff line number Diff line change
Expand Up @@ -542,7 +542,7 @@ impl api::IncomingWebhook for Bankofamerica {
fn get_webhook_resource_object(
&self,
_request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
Err(errors::ConnectorError::WebhooksNotImplemented).into_report()
}
}
7 changes: 3 additions & 4 deletions crates/router/src/connector/bitpay.rs
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ use crate::{
api::{self, ConnectorCommon, ConnectorCommonExt},
ErrorResponse, Response,
},
utils::{self, BytesExt, Encode},
utils::{self, BytesExt},
};

#[derive(Debug, Clone)]
Expand Down Expand Up @@ -393,12 +393,11 @@ impl api::IncomingWebhook for Bitpay {
fn get_webhook_resource_object(
&self,
request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
let notif: BitpayWebhookDetails = request
.body
.parse_struct("BitpayWebhookDetails")
.change_context(errors::ConnectorError::WebhookEventTypeNotFound)?;
Encode::<BitpayWebhookDetails>::encode_to_value(&notif)
.change_context(errors::ConnectorError::WebhookBodyDecodingFailed)
Ok(Box::new(notif))
}
}
6 changes: 2 additions & 4 deletions crates/router/src/connector/bluesnap.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1119,15 +1119,13 @@ impl api::IncomingWebhook for Bluesnap {
fn get_webhook_resource_object(
&self,
request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
let resource: bluesnap::BluesnapWebhookObjectResource =
serde_urlencoded::from_bytes(request.body)
.into_report()
.change_context(errors::ConnectorError::WebhookResourceObjectNotFound)?;

let res_json = serde_json::Value::try_from(resource)?;

Ok(res_json)
Ok(Box::new(resource))
}
}

Expand Down
2 changes: 1 addition & 1 deletion crates/router/src/connector/boku.rs
Original file line number Diff line number Diff line change
Expand Up @@ -627,7 +627,7 @@ impl api::IncomingWebhook for Boku {
fn get_webhook_resource_object(
&self,
_request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
Err(errors::ConnectorError::WebhooksNotImplemented).into_report()
}
}
Expand Down
8 changes: 2 additions & 6 deletions crates/router/src/connector/braintree.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1418,17 +1418,13 @@ impl api::IncomingWebhook for Braintree {
fn get_webhook_resource_object(
&self,
request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
let notif = get_webhook_object_from_body(request.body)
.change_context(errors::ConnectorError::WebhookBodyDecodingFailed)?;

let response = decode_webhook_payload(notif.bt_payload.replace('\n', "").as_bytes())?;

let res_json = serde_json::to_value(response)
.into_report()
.change_context(errors::ConnectorError::WebhookResourceObjectNotFound)?;

Ok(res_json)
Ok(Box::new(response))
}

fn get_webhook_api_response(
Expand Down
7 changes: 2 additions & 5 deletions crates/router/src/connector/cashtocode.rs
Original file line number Diff line number Diff line change
Expand Up @@ -391,16 +391,13 @@ impl api::IncomingWebhook for Cashtocode {
fn get_webhook_resource_object(
&self,
request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
let webhook: transformers::CashtocodeIncomingWebhook = request
.body
.parse_struct("CashtocodeIncomingWebhook")
.change_context(errors::ConnectorError::WebhookBodyDecodingFailed)?;
let res_json =
utils::Encode::<transformers::CashtocodeIncomingWebhook>::encode_to_value(&webhook)
.change_context(errors::ConnectorError::WebhookBodyDecodingFailed)?;

Ok(res_json)
Ok(Box::new(webhook))
}

fn get_webhook_api_response(
Expand Down
7 changes: 5 additions & 2 deletions crates/router/src/connector/checkout.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1261,7 +1261,7 @@ impl api::IncomingWebhook for Checkout {
fn get_webhook_resource_object(
&self,
request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
let event_type_data: checkout::CheckoutWebhookEventTypeBody = request
.body
.parse_struct("CheckoutWebhookBody")
Expand All @@ -1281,7 +1281,10 @@ impl api::IncomingWebhook for Checkout {
utils::Encode::<checkout::PaymentsResponse>::encode_to_value(&payment_response)
.change_context(errors::ConnectorError::WebhookResourceObjectNotFound)?
};
Ok(resource_object)
// Ideally this should be a strict type that has type information
// PII information is likely being logged here when this response will be logged.

Ok(Box::new(resource_object))
}

fn get_dispute_details(
Expand Down
6 changes: 3 additions & 3 deletions crates/router/src/connector/coinbase.rs
Original file line number Diff line number Diff line change
Expand Up @@ -426,12 +426,12 @@ impl api::IncomingWebhook for Coinbase {
fn get_webhook_resource_object(
&self,
request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
let notif: CoinbaseWebhookDetails = request
.body
.parse_struct("CoinbaseWebhookDetails")
.change_context(errors::ConnectorError::WebhookBodyDecodingFailed)?;
Encode::<CoinbaseWebhookDetails>::encode_to_value(&notif.event)
.change_context(errors::ConnectorError::WebhookBodyDecodingFailed)

Ok(Box::new(notif.event))
}
}
6 changes: 3 additions & 3 deletions crates/router/src/connector/cryptopay.rs
Original file line number Diff line number Diff line change
Expand Up @@ -455,13 +455,13 @@ impl api::IncomingWebhook for Cryptopay {
fn get_webhook_resource_object(
&self,
request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
let notif: CryptopayWebhookDetails =
request
.body
.parse_struct("CryptopayWebhookDetails")
.change_context(errors::ConnectorError::WebhookBodyDecodingFailed)?;
Encode::<CryptopayWebhookDetails>::encode_to_value(&notif)
.change_context(errors::ConnectorError::WebhookBodyDecodingFailed)

Ok(Box::new(notif))
}
}
2 changes: 1 addition & 1 deletion crates/router/src/connector/cybersource.rs
Original file line number Diff line number Diff line change
Expand Up @@ -805,7 +805,7 @@ impl api::IncomingWebhook for Cybersource {
fn get_webhook_resource_object(
&self,
_request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
Err(errors::ConnectorError::WebhooksNotImplemented).into_report()
}
}
2 changes: 1 addition & 1 deletion crates/router/src/connector/dlocal.rs
Original file line number Diff line number Diff line change
Expand Up @@ -674,7 +674,7 @@ impl api::IncomingWebhook for Dlocal {
fn get_webhook_resource_object(
&self,
_request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
Err(errors::ConnectorError::WebhooksNotImplemented).into_report()
}
}
2 changes: 1 addition & 1 deletion crates/router/src/connector/dummyconnector.rs
Original file line number Diff line number Diff line change
Expand Up @@ -579,7 +579,7 @@ impl<const T: u8> api::IncomingWebhook for DummyConnector<T> {
fn get_webhook_resource_object(
&self,
_request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
Err(errors::ConnectorError::WebhooksNotImplemented).into_report()
}
}
2 changes: 1 addition & 1 deletion crates/router/src/connector/fiserv.rs
Original file line number Diff line number Diff line change
Expand Up @@ -787,7 +787,7 @@ impl api::IncomingWebhook for Fiserv {
fn get_webhook_resource_object(
&self,
_request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
Err(errors::ConnectorError::WebhooksNotImplemented).into_report()
}
}
2 changes: 1 addition & 1 deletion crates/router/src/connector/forte.rs
Original file line number Diff line number Diff line change
Expand Up @@ -669,7 +669,7 @@ impl api::IncomingWebhook for Forte {
fn get_webhook_resource_object(
&self,
_request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
Err(errors::ConnectorError::WebhooksNotImplemented).into_report()
}
}
11 changes: 6 additions & 5 deletions crates/router/src/connector/globalpay.rs
Original file line number Diff line number Diff line change
Expand Up @@ -932,14 +932,15 @@ impl api::IncomingWebhook for Globalpay {
fn get_webhook_resource_object(
&self,
request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
let details = std::str::from_utf8(request.body)
.into_report()
.change_context(errors::ConnectorError::WebhookBodyDecodingFailed)?;
let res_json = serde_json::from_str(details)
.into_report()
.change_context(errors::ConnectorError::WebhookResourceObjectNotFound)?;
Ok(res_json)
Ok(Box::new(
serde_json::from_str(details)
.into_report()
.change_context(errors::ConnectorError::WebhookResourceObjectNotFound)?,
))
}
}

Expand Down
2 changes: 1 addition & 1 deletion crates/router/src/connector/globepay.rs
Original file line number Diff line number Diff line change
Expand Up @@ -508,7 +508,7 @@ impl api::IncomingWebhook for Globepay {
fn get_webhook_resource_object(
&self,
_request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
Err(errors::ConnectorError::WebhooksNotImplemented).into_report()
}
}
21 changes: 8 additions & 13 deletions crates/router/src/connector/gocardless.rs
Original file line number Diff line number Diff line change
Expand Up @@ -843,27 +843,22 @@ impl api::IncomingWebhook for Gocardless {
fn get_webhook_resource_object(
&self,
request: &api::IncomingWebhookRequestDetails<'_>,
) -> CustomResult<serde_json::Value, errors::ConnectorError> {
) -> CustomResult<Box<dyn erased_serde::Serialize>, errors::ConnectorError> {
let details: gocardless::GocardlessWebhookEvent = request
.body
.parse_struct("GocardlessWebhookEvent")
.change_context(errors::ConnectorError::WebhookBodyDecodingFailed)?;
let first_event = details
.events
.first()
.ok_or_else(|| errors::ConnectorError::WebhookReferenceIdNotFound)?;
.ok_or_else(|| errors::ConnectorError::WebhookReferenceIdNotFound)?
.clone();
match first_event.resource_type {
transformers::WebhookResourceType::Payments => serde_json::to_value(
gocardless::GocardlessPaymentsResponse::try_from(first_event)?,
)
.into_report()
.change_context(errors::ConnectorError::WebhookBodyDecodingFailed),
transformers::WebhookResourceType::Refunds => serde_json::to_value(first_event)
.into_report()
.change_context(errors::ConnectorError::WebhookBodyDecodingFailed),
transformers::WebhookResourceType::Mandates => serde_json::to_value(first_event)
.into_report()
.change_context(errors::ConnectorError::WebhookBodyDecodingFailed),
transformers::WebhookResourceType::Payments => Ok(Box::new(
gocardless::GocardlessPaymentsResponse::try_from(&first_event)?,
)),
transformers::WebhookResourceType::Refunds
| transformers::WebhookResourceType::Mandates => Ok(Box::new(first_event)),
}
}
}
Loading

0 comments on commit e7fd445

Please sign in to comment.