#[allow(unused_imports)]
mod prelude {
pub use k8s_openapi::apimachinery::pkg::apis::meta::v1::Condition;
pub use k8s_openapi::apimachinery::pkg::util::intstr::IntOrString;
pub use kube::CustomResource;
pub use schemars::JsonSchema;
pub use serde::{Deserialize, Serialize};
pub use std::collections::BTreeMap;
}
use self::prelude::*;
#[derive(CustomResource, Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
#[kube(
group = "cluster.x-k8s.io",
version = "v1beta2",
kind = "Cluster",
plural = "clusters"
)]
#[kube(namespaced)]
#[kube(status = "ClusterStatus")]
#[kube(derive = "Default")]
#[kube(derive = "PartialEq")]
pub struct ClusterSpec {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "availabilityGates"
)]
pub availability_gates: Option<Vec<ClusterAvailabilityGates>>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "clusterNetwork"
)]
pub cluster_network: Option<ClusterClusterNetwork>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "controlPlaneEndpoint"
)]
pub control_plane_endpoint: Option<ClusterControlPlaneEndpoint>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "controlPlaneRef"
)]
pub control_plane_ref: Option<ClusterControlPlaneRef>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "infrastructureRef"
)]
pub infrastructure_ref: Option<ClusterInfrastructureRef>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub paused: Option<bool>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub topology: Option<ClusterTopology>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterAvailabilityGates {
#[serde(rename = "conditionType")]
pub condition_type: String,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub polarity: Option<ClusterAvailabilityGatesPolarity>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterAvailabilityGatesPolarity {
Positive,
Negative,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterClusterNetwork {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "apiServerPort"
)]
pub api_server_port: Option<i32>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub pods: Option<ClusterClusterNetworkPods>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "serviceDomain"
)]
pub service_domain: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub services: Option<ClusterClusterNetworkServices>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterClusterNetworkPods {
#[serde(rename = "cidrBlocks")]
pub cidr_blocks: Vec<String>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterClusterNetworkServices {
#[serde(rename = "cidrBlocks")]
pub cidr_blocks: Vec<String>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterControlPlaneEndpoint {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub host: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub port: Option<i32>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterControlPlaneRef {
#[serde(rename = "apiGroup")]
pub api_group: String,
pub kind: String,
pub name: String,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterInfrastructureRef {
#[serde(rename = "apiGroup")]
pub api_group: String,
pub kind: String,
pub name: String,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopology {
#[serde(rename = "classRef")]
pub class_ref: ClusterTopologyClassRef,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "controlPlane"
)]
pub control_plane: Option<ClusterTopologyControlPlane>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub variables: Option<Vec<ClusterTopologyVariables>>,
pub version: String,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub workers: Option<ClusterTopologyWorkers>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyClassRef {
pub name: String,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub namespace: Option<String>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlane {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub deletion: Option<ClusterTopologyControlPlaneDeletion>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "healthCheck"
)]
pub health_check: Option<ClusterTopologyControlPlaneHealthCheck>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub metadata: Option<ClusterTopologyControlPlaneMetadata>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "readinessGates"
)]
pub readiness_gates: Option<Vec<ClusterTopologyControlPlaneReadinessGates>>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub replicas: Option<i32>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub rollout: Option<ClusterTopologyControlPlaneRollout>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub taints: Option<Vec<ClusterTopologyControlPlaneTaints>>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub variables: Option<ClusterTopologyControlPlaneVariables>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneDeletion {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "nodeDeletionTimeoutSeconds"
)]
pub node_deletion_timeout_seconds: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "nodeDrainTimeoutSeconds"
)]
pub node_drain_timeout_seconds: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "nodeVolumeDetachTimeoutSeconds"
)]
pub node_volume_detach_timeout_seconds: Option<i32>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneHealthCheck {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub checks: Option<ClusterTopologyControlPlaneHealthCheckChecks>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub enabled: Option<bool>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub remediation: Option<ClusterTopologyControlPlaneHealthCheckRemediation>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneHealthCheckChecks {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "nodeStartupTimeoutSeconds"
)]
pub node_startup_timeout_seconds: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "unhealthyMachineConditions"
)]
pub unhealthy_machine_conditions:
Option<Vec<ClusterTopologyControlPlaneHealthCheckChecksUnhealthyMachineConditions>>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "unhealthyNodeConditions"
)]
pub unhealthy_node_conditions:
Option<Vec<ClusterTopologyControlPlaneHealthCheckChecksUnhealthyNodeConditions>>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneHealthCheckChecksUnhealthyMachineConditions {
pub status: ClusterTopologyControlPlaneHealthCheckChecksUnhealthyMachineConditionsStatus,
#[serde(rename = "timeoutSeconds")]
pub timeout_seconds: i32,
#[serde(rename = "type")]
pub r#type: String,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterTopologyControlPlaneHealthCheckChecksUnhealthyMachineConditionsStatus {
True,
False,
Unknown,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneHealthCheckChecksUnhealthyNodeConditions {
pub status: String,
#[serde(rename = "timeoutSeconds")]
pub timeout_seconds: i32,
#[serde(rename = "type")]
pub r#type: String,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneHealthCheckRemediation {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "templateRef"
)]
pub template_ref: Option<ClusterTopologyControlPlaneHealthCheckRemediationTemplateRef>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "triggerIf")]
pub trigger_if: Option<ClusterTopologyControlPlaneHealthCheckRemediationTriggerIf>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneHealthCheckRemediationTemplateRef {
#[serde(rename = "apiVersion")]
pub api_version: String,
pub kind: String,
pub name: String,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneHealthCheckRemediationTriggerIf {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "unhealthyInRange"
)]
pub unhealthy_in_range: Option<String>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "unhealthyLessThanOrEqualTo"
)]
pub unhealthy_less_than_or_equal_to: Option<IntOrString>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneMetadata {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub annotations: Option<BTreeMap<String, String>>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub labels: Option<BTreeMap<String, String>>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneReadinessGates {
#[serde(rename = "conditionType")]
pub condition_type: String,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub polarity: Option<ClusterTopologyControlPlaneReadinessGatesPolarity>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterTopologyControlPlaneReadinessGatesPolarity {
Positive,
Negative,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneRollout {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub after: Option<String>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneTaints {
pub effect: ClusterTopologyControlPlaneTaintsEffect,
pub key: String,
pub propagation: ClusterTopologyControlPlaneTaintsPropagation,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub value: Option<String>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterTopologyControlPlaneTaintsEffect {
NoSchedule,
PreferNoSchedule,
NoExecute,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterTopologyControlPlaneTaintsPropagation {
Always,
OnInitialization,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneVariables {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub overrides: Option<Vec<ClusterTopologyControlPlaneVariablesOverrides>>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyControlPlaneVariablesOverrides {
pub name: String,
pub value: serde_json::Value,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyVariables {
pub name: String,
pub value: serde_json::Value,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkers {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "machineDeployments"
)]
pub machine_deployments: Option<Vec<ClusterTopologyWorkersMachineDeployments>>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "machinePools"
)]
pub machine_pools: Option<Vec<ClusterTopologyWorkersMachinePools>>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeployments {
pub class: String,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub deletion: Option<ClusterTopologyWorkersMachineDeploymentsDeletion>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "failureDomain"
)]
pub failure_domain: Option<String>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "healthCheck"
)]
pub health_check: Option<ClusterTopologyWorkersMachineDeploymentsHealthCheck>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub metadata: Option<ClusterTopologyWorkersMachineDeploymentsMetadata>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "minReadySeconds"
)]
pub min_ready_seconds: Option<i32>,
pub name: String,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "readinessGates"
)]
pub readiness_gates: Option<Vec<ClusterTopologyWorkersMachineDeploymentsReadinessGates>>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub replicas: Option<i32>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub rollout: Option<ClusterTopologyWorkersMachineDeploymentsRollout>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub taints: Option<Vec<ClusterTopologyWorkersMachineDeploymentsTaints>>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub variables: Option<ClusterTopologyWorkersMachineDeploymentsVariables>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsDeletion {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "nodeDeletionTimeoutSeconds"
)]
pub node_deletion_timeout_seconds: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "nodeDrainTimeoutSeconds"
)]
pub node_drain_timeout_seconds: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "nodeVolumeDetachTimeoutSeconds"
)]
pub node_volume_detach_timeout_seconds: Option<i32>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub order: Option<ClusterTopologyWorkersMachineDeploymentsDeletionOrder>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterTopologyWorkersMachineDeploymentsDeletionOrder {
Random,
Newest,
Oldest,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsHealthCheck {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub checks: Option<ClusterTopologyWorkersMachineDeploymentsHealthCheckChecks>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub enabled: Option<bool>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub remediation: Option<ClusterTopologyWorkersMachineDeploymentsHealthCheckRemediation>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsHealthCheckChecks {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "nodeStartupTimeoutSeconds"
)]
pub node_startup_timeout_seconds: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "unhealthyMachineConditions"
)]
pub unhealthy_machine_conditions: Option<
Vec<ClusterTopologyWorkersMachineDeploymentsHealthCheckChecksUnhealthyMachineConditions>,
>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "unhealthyNodeConditions"
)]
pub unhealthy_node_conditions: Option<
Vec<ClusterTopologyWorkersMachineDeploymentsHealthCheckChecksUnhealthyNodeConditions>,
>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsHealthCheckChecksUnhealthyMachineConditions {
pub status:
ClusterTopologyWorkersMachineDeploymentsHealthCheckChecksUnhealthyMachineConditionsStatus,
#[serde(rename = "timeoutSeconds")]
pub timeout_seconds: i32,
#[serde(rename = "type")]
pub r#type: String,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterTopologyWorkersMachineDeploymentsHealthCheckChecksUnhealthyMachineConditionsStatus {
True,
False,
Unknown,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsHealthCheckChecksUnhealthyNodeConditions {
pub status: String,
#[serde(rename = "timeoutSeconds")]
pub timeout_seconds: i32,
#[serde(rename = "type")]
pub r#type: String,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsHealthCheckRemediation {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "maxInFlight"
)]
pub max_in_flight: Option<IntOrString>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "templateRef"
)]
pub template_ref:
Option<ClusterTopologyWorkersMachineDeploymentsHealthCheckRemediationTemplateRef>,
#[serde(default, skip_serializing_if = "Option::is_none", rename = "triggerIf")]
pub trigger_if: Option<ClusterTopologyWorkersMachineDeploymentsHealthCheckRemediationTriggerIf>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsHealthCheckRemediationTemplateRef {
#[serde(rename = "apiVersion")]
pub api_version: String,
pub kind: String,
pub name: String,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsHealthCheckRemediationTriggerIf {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "unhealthyInRange"
)]
pub unhealthy_in_range: Option<String>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "unhealthyLessThanOrEqualTo"
)]
pub unhealthy_less_than_or_equal_to: Option<IntOrString>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsMetadata {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub annotations: Option<BTreeMap<String, String>>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub labels: Option<BTreeMap<String, String>>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsReadinessGates {
#[serde(rename = "conditionType")]
pub condition_type: String,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub polarity: Option<ClusterTopologyWorkersMachineDeploymentsReadinessGatesPolarity>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterTopologyWorkersMachineDeploymentsReadinessGatesPolarity {
Positive,
Negative,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsRollout {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub after: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub strategy: Option<ClusterTopologyWorkersMachineDeploymentsRolloutStrategy>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsRolloutStrategy {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "rollingUpdate"
)]
pub rolling_update:
Option<ClusterTopologyWorkersMachineDeploymentsRolloutStrategyRollingUpdate>,
#[serde(rename = "type")]
pub r#type: ClusterTopologyWorkersMachineDeploymentsRolloutStrategyType,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsRolloutStrategyRollingUpdate {
#[serde(default, skip_serializing_if = "Option::is_none", rename = "maxSurge")]
pub max_surge: Option<IntOrString>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "maxUnavailable"
)]
pub max_unavailable: Option<IntOrString>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterTopologyWorkersMachineDeploymentsRolloutStrategyType {
RollingUpdate,
OnDelete,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsTaints {
pub effect: ClusterTopologyWorkersMachineDeploymentsTaintsEffect,
pub key: String,
pub propagation: ClusterTopologyWorkersMachineDeploymentsTaintsPropagation,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub value: Option<String>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterTopologyWorkersMachineDeploymentsTaintsEffect {
NoSchedule,
PreferNoSchedule,
NoExecute,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterTopologyWorkersMachineDeploymentsTaintsPropagation {
Always,
OnInitialization,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsVariables {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub overrides: Option<Vec<ClusterTopologyWorkersMachineDeploymentsVariablesOverrides>>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachineDeploymentsVariablesOverrides {
pub name: String,
pub value: serde_json::Value,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachinePools {
pub class: String,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub deletion: Option<ClusterTopologyWorkersMachinePoolsDeletion>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "failureDomains"
)]
pub failure_domains: Option<Vec<String>>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub metadata: Option<ClusterTopologyWorkersMachinePoolsMetadata>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "minReadySeconds"
)]
pub min_ready_seconds: Option<i32>,
pub name: String,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub replicas: Option<i32>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub taints: Option<Vec<ClusterTopologyWorkersMachinePoolsTaints>>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub variables: Option<ClusterTopologyWorkersMachinePoolsVariables>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachinePoolsDeletion {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "nodeDeletionTimeoutSeconds"
)]
pub node_deletion_timeout_seconds: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "nodeDrainTimeoutSeconds"
)]
pub node_drain_timeout_seconds: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "nodeVolumeDetachTimeoutSeconds"
)]
pub node_volume_detach_timeout_seconds: Option<i32>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachinePoolsMetadata {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub annotations: Option<BTreeMap<String, String>>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub labels: Option<BTreeMap<String, String>>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachinePoolsTaints {
pub effect: ClusterTopologyWorkersMachinePoolsTaintsEffect,
pub key: String,
pub propagation: ClusterTopologyWorkersMachinePoolsTaintsPropagation,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub value: Option<String>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterTopologyWorkersMachinePoolsTaintsEffect {
NoSchedule,
PreferNoSchedule,
NoExecute,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterTopologyWorkersMachinePoolsTaintsPropagation {
Always,
OnInitialization,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachinePoolsVariables {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub overrides: Option<Vec<ClusterTopologyWorkersMachinePoolsVariablesOverrides>>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterTopologyWorkersMachinePoolsVariablesOverrides {
pub name: String,
pub value: serde_json::Value,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterStatus {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub conditions: Option<Vec<Condition>>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "controlPlane"
)]
pub control_plane: Option<ClusterStatusControlPlane>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub deprecated: Option<ClusterStatusDeprecated>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "failureDomains"
)]
pub failure_domains: Option<Vec<ClusterStatusFailureDomains>>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub initialization: Option<ClusterStatusInitialization>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "observedGeneration"
)]
pub observed_generation: Option<i64>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub phase: Option<ClusterStatusPhase>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub workers: Option<ClusterStatusWorkers>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterStatusControlPlane {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "availableReplicas"
)]
pub available_replicas: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "desiredReplicas"
)]
pub desired_replicas: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "readyReplicas"
)]
pub ready_replicas: Option<i32>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub replicas: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "upToDateReplicas"
)]
pub up_to_date_replicas: Option<i32>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterStatusDeprecated {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub v1beta1: Option<ClusterStatusDeprecatedV1beta1>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterStatusDeprecatedV1beta1 {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub conditions: Option<Vec<Condition>>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "failureMessage"
)]
pub failure_message: Option<String>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "failureReason"
)]
pub failure_reason: Option<String>,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterStatusFailureDomains {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub attributes: Option<BTreeMap<String, String>>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "controlPlane"
)]
pub control_plane: Option<bool>,
pub name: String,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterStatusInitialization {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "controlPlaneInitialized"
)]
pub control_plane_initialized: Option<bool>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "infrastructureProvisioned"
)]
pub infrastructure_provisioned: Option<bool>,
}
#[derive(Serialize, Deserialize, Clone, Debug, PartialEq, JsonSchema)]
pub enum ClusterStatusPhase {
Pending,
Provisioning,
Provisioned,
Deleting,
Failed,
Unknown,
}
#[derive(Serialize, Deserialize, Clone, Debug, Default, PartialEq, JsonSchema)]
pub struct ClusterStatusWorkers {
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "availableReplicas"
)]
pub available_replicas: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "desiredReplicas"
)]
pub desired_replicas: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "readyReplicas"
)]
pub ready_replicas: Option<i32>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub replicas: Option<i32>,
#[serde(
default,
skip_serializing_if = "Option::is_none",
rename = "upToDateReplicas"
)]
pub up_to_date_replicas: Option<i32>,
}