/*
* Stadar Esports Data API
*
* Read-only, betting-friendly esports data across all major competitive titles. Flat-tier pricing (no per-game gates), Polar- billed subscriptions (Merchant of Record), sandbox keys for evaluation. See https://stadar.net for tier pricing. All endpoints under `/v1/...`. The version in `info.version` matches the URL prefix; non-breaking field additions ship in `/v1`, breaking changes get a `/v2`. We commit to 24 months of `/v1` support after `/v2` ships. Times are UTC end-to-end (RFC 3339). Localization is the client's problem. Cursors are opaque base64 strings; treat them as such.
*
* The version of the OpenAPI document: v1
* Contact: api@stadar.net
* Generated by: https://openapi-generator.tech
*/
use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct WebhookSubscription {
#[serde(rename = "id")]
pub id: i64,
#[serde(rename = "url")]
pub url: String,
#[serde(rename = "events")]
pub events: Vec<String>,
#[serde(rename = "filter_game", skip_serializing_if = "Option::is_none")]
pub filter_game: Option<String>,
#[serde(rename = "filter_league", skip_serializing_if = "Option::is_none")]
pub filter_league: Option<String>,
#[serde(rename = "filter_tournament", skip_serializing_if = "Option::is_none")]
pub filter_tournament: Option<String>,
#[serde(rename = "created_at")]
pub created_at: chrono::DateTime<chrono::FixedOffset>,
#[serde(rename = "last_delivered_at", skip_serializing_if = "Option::is_none")]
pub last_delivered_at: Option<chrono::DateTime<chrono::FixedOffset>>,
#[serde(rename = "last_status", skip_serializing_if = "Option::is_none")]
pub last_status: Option<i32>,
}
impl WebhookSubscription {
pub fn new(id: i64, url: String, events: Vec<String>, created_at: chrono::DateTime<chrono::FixedOffset>) -> WebhookSubscription {
WebhookSubscription {
id,
url,
events,
filter_game: None,
filter_league: None,
filter_tournament: None,
created_at,
last_delivered_at: None,
last_status: None,
}
}
}