#[allow(unused_imports)]
mod prelude {
pub use kube::CustomResource;
pub use serde::{Serialize, Deserialize};
pub use k8s_openapi::apimachinery::pkg::apis::meta::v1::Condition;
}
use self::prelude::*;
#[derive(CustomResource, Serialize, Deserialize, Clone, Debug, Default, PartialEq)]
#[kube(group = "jetstream.nats.io", version = "v1beta1", kind = "Stream", plural = "streams")]
#[kube(namespaced)]
#[kube(status = "StreamStatus")]
#[kube(schema = "disabled")]
#[kube(derive="Default")]
#[kube(derive="PartialEq")]
pub struct StreamSpec {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub description: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub discard: Option<StreamDiscard>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "duplicateWindow")]
pub duplicate_window: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "maxAge")]
pub max_age: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "maxBytes")]
pub max_bytes: Option<i64>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "maxConsumers")]
pub max_consumers: Option<i64>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "maxMsgSize")]
pub max_msg_size: Option<i64>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "maxMsgs")]
pub max_msgs: Option<i64>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "maxMsgsPerSubject")]
pub max_msgs_per_subject: Option<i64>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub mirror: Option<StreamMirror>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub name: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "noAck")]
pub no_ack: Option<bool>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub placement: Option<StreamPlacement>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub replicas: Option<i64>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub retention: Option<StreamRetention>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub sources: Option<Vec<StreamSources>>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub storage: Option<StreamStorage>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub subjects: Option<Vec<String>>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq)]
pub enum StreamDiscard {
#[serde(rename = "old")]
Old,
#[serde(rename = "new")]
New,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq)]
pub struct StreamMirror {
#[serde(default, skip_serializing_if = "Option::is_none", rename = "externalApiPrefix")]
pub external_api_prefix: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "externalDeliverPrefix")]
pub external_deliver_prefix: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "filterSubject")]
pub filter_subject: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub name: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "optStartSeq")]
pub opt_start_seq: Option<i64>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "optStartTime")]
pub opt_start_time: Option<String>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq)]
pub struct StreamPlacement {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub cluster: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub tags: Option<Vec<String>>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq)]
pub enum StreamRetention {
#[serde(rename = "limits")]
Limits,
#[serde(rename = "interest")]
Interest,
#[serde(rename = "workqueue")]
Workqueue,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq)]
pub struct StreamSources {
#[serde(default, skip_serializing_if = "Option::is_none", rename = "externalApiPrefix")]
pub external_api_prefix: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "externalDeliverPrefix")]
pub external_deliver_prefix: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "filterSubject")]
pub filter_subject: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub name: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "optStartSeq")]
pub opt_start_seq: Option<i64>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "optStartTime")]
pub opt_start_time: Option<String>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq)]
pub enum StreamStorage {
#[serde(rename = "file")]
File,
#[serde(rename = "memory")]
Memory,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq)]
pub struct StreamStatus {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub conditions: Option<Vec<Condition>>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "observedGeneration")]
pub observed_generation: Option<i64>,
}