hcloud 0.25.0

Unofficial Rust crate for accessing the Hetzner Cloud API
Documentation
/*
 * Hetzner Cloud API
 *
 * Copied from the official API documentation for the Public Hetzner Cloud.
 *
 * The version of the OpenAPI document: 0.28.0
 *
 * Generated by: https://openapi-generator.tech
 */

use crate::models;
use serde::{Deserialize, Serialize};

/// AttachLoadBalancerToNetworkRequest : Request for POST https://api.hetzner.cloud/v1/load_balancers/{id}/actions/attach_to_network
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct AttachLoadBalancerToNetworkRequest {
    /// IP to request to be assigned to this Load Balancer; if you do not provide this then you will be auto assigned an IP address.
    #[serde(rename = "ip", skip_serializing_if = "Option::is_none")]
    pub ip: Option<String>,
    /// IP range in CIDR block notation of the subnet to attach to.  This allows for auto assigning an IP address for a specific subnet. Providing `ip` that is not part of `ip_range` will result in an error.
    #[serde(rename = "ip_range", skip_serializing_if = "Option::is_none")]
    pub ip_range: Option<String>,
    /// ID of an existing network to attach the Load Balancer to.
    #[serde(rename = "network")]
    pub network: i64,
}

impl AttachLoadBalancerToNetworkRequest {
    /// Request for POST https://api.hetzner.cloud/v1/load_balancers/{id}/actions/attach_to_network
    pub fn new(network: i64) -> AttachLoadBalancerToNetworkRequest {
        AttachLoadBalancerToNetworkRequest {
            ip: None,
            ip_range: None,
            network,
        }
    }
}