mirror of
https://github.com/juspay/hyperswitch.git
synced 2025-10-30 09:38:33 +08:00
Co-authored-by: hyperswitch-bot[bot] <148525504+hyperswitch-bot[bot]@users.noreply.github.com>
152 lines
3.5 KiB
Rust
152 lines
3.5 KiB
Rust
use std::{
|
|
collections::hash_map::DefaultHasher,
|
|
hash::{Hash, Hasher},
|
|
};
|
|
|
|
use super::{NameDescription, TimeRange};
|
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
|
pub struct ApiLogsRequest {
|
|
#[serde(flatten)]
|
|
pub query_param: QueryType,
|
|
}
|
|
|
|
pub enum FilterType {
|
|
ApiCountFilter,
|
|
LatencyFilter,
|
|
StatusCodeFilter,
|
|
}
|
|
|
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
|
#[serde(tag = "type")]
|
|
pub enum QueryType {
|
|
Payment {
|
|
payment_id: common_utils::id_type::PaymentId,
|
|
},
|
|
Refund {
|
|
payment_id: common_utils::id_type::PaymentId,
|
|
refund_id: String,
|
|
},
|
|
Dispute {
|
|
payment_id: common_utils::id_type::PaymentId,
|
|
dispute_id: String,
|
|
},
|
|
}
|
|
|
|
#[derive(
|
|
Debug,
|
|
serde::Serialize,
|
|
serde::Deserialize,
|
|
strum::AsRefStr,
|
|
PartialEq,
|
|
PartialOrd,
|
|
Eq,
|
|
Ord,
|
|
strum::Display,
|
|
strum::EnumIter,
|
|
Clone,
|
|
Copy,
|
|
)]
|
|
#[serde(rename_all = "snake_case")]
|
|
#[strum(serialize_all = "snake_case")]
|
|
pub enum ApiEventDimensions {
|
|
// Do not change the order of these enums
|
|
// Consult the Dashboard FE folks since these also affects the order of metrics on FE
|
|
StatusCode,
|
|
FlowType,
|
|
ApiFlow,
|
|
}
|
|
|
|
impl From<ApiEventDimensions> for NameDescription {
|
|
fn from(value: ApiEventDimensions) -> Self {
|
|
Self {
|
|
name: value.to_string(),
|
|
desc: String::new(),
|
|
}
|
|
}
|
|
}
|
|
#[derive(Clone, Debug, Default, serde::Deserialize, serde::Serialize)]
|
|
pub struct ApiEventFilters {
|
|
pub status_code: Vec<u64>,
|
|
pub flow_type: Vec<String>,
|
|
pub api_flow: Vec<String>,
|
|
}
|
|
|
|
#[derive(
|
|
Clone,
|
|
Debug,
|
|
Hash,
|
|
PartialEq,
|
|
Eq,
|
|
serde::Serialize,
|
|
serde::Deserialize,
|
|
strum::Display,
|
|
strum::EnumIter,
|
|
strum::AsRefStr,
|
|
)]
|
|
#[strum(serialize_all = "snake_case")]
|
|
#[serde(rename_all = "snake_case")]
|
|
pub enum ApiEventMetrics {
|
|
Latency,
|
|
ApiCount,
|
|
StatusCodeCount,
|
|
}
|
|
|
|
impl From<ApiEventMetrics> for NameDescription {
|
|
fn from(value: ApiEventMetrics) -> Self {
|
|
Self {
|
|
name: value.to_string(),
|
|
desc: String::new(),
|
|
}
|
|
}
|
|
}
|
|
|
|
#[derive(Debug, serde::Serialize, Eq)]
|
|
pub struct ApiEventMetricsBucketIdentifier {
|
|
#[serde(rename = "time_range")]
|
|
pub time_bucket: TimeRange,
|
|
// Coz FE sucks
|
|
#[serde(rename = "time_bucket")]
|
|
#[serde(with = "common_utils::custom_serde::iso8601custom")]
|
|
pub start_time: time::PrimitiveDateTime,
|
|
}
|
|
|
|
impl ApiEventMetricsBucketIdentifier {
|
|
pub fn new(normalized_time_range: TimeRange) -> Self {
|
|
Self {
|
|
time_bucket: normalized_time_range,
|
|
start_time: normalized_time_range.start_time,
|
|
}
|
|
}
|
|
}
|
|
|
|
impl Hash for ApiEventMetricsBucketIdentifier {
|
|
fn hash<H: Hasher>(&self, state: &mut H) {
|
|
self.time_bucket.hash(state);
|
|
}
|
|
}
|
|
|
|
impl PartialEq for ApiEventMetricsBucketIdentifier {
|
|
fn eq(&self, other: &Self) -> bool {
|
|
let mut left = DefaultHasher::new();
|
|
self.hash(&mut left);
|
|
let mut right = DefaultHasher::new();
|
|
other.hash(&mut right);
|
|
left.finish() == right.finish()
|
|
}
|
|
}
|
|
|
|
#[derive(Debug, serde::Serialize)]
|
|
pub struct ApiEventMetricsBucketValue {
|
|
pub latency: Option<u64>,
|
|
pub api_count: Option<u64>,
|
|
pub status_code_count: Option<u64>,
|
|
}
|
|
|
|
#[derive(Debug, serde::Serialize)]
|
|
pub struct ApiMetricsBucketResponse {
|
|
#[serde(flatten)]
|
|
pub values: ApiEventMetricsBucketValue,
|
|
#[serde(flatten)]
|
|
pub dimensions: ApiEventMetricsBucketIdentifier,
|
|
}
|