nautobot-openapi 0.4.0

low level nautobot bindings (generated by openapi-generator)
Documentation
/*
 * API Documentation
 *
 * Source of truth and network automation platform
 *
 * The version of the OpenAPI document: 3.1.0 (3.1)
 *
 * Generated by: https://openapi-generator.tech
 */

/// RadioProfileRequest : Base class to use for serializers based on OrganizationalModel or PrimaryModel.  Can also be used for models derived from BaseModel, so long as they support custom fields, notes, and relationships.

#[derive(Clone, Debug, PartialEq, Default, Serialize, Deserialize)]
pub struct RadioProfileRequest {
    #[serde(rename = "id", skip_serializing_if = "Option::is_none")]
    pub id: Option<uuid::Uuid>,
    #[serde(rename = "channel_width", skip_serializing_if = "Option::is_none")]
    pub channel_width: Option<Vec<i32>>,
    #[serde(
        rename = "allowed_channel_list",
        skip_serializing_if = "Option::is_none"
    )]
    pub allowed_channel_list: Option<Vec<i32>>,
    #[serde(rename = "name")]
    pub name: String,
    #[serde(rename = "frequency", skip_serializing_if = "Option::is_none")]
    pub frequency: Option<Box<crate::models::BulkWritableRadioProfileRequestFrequency>>,
    #[serde(
        rename = "tx_power_min",
        default,
        with = "::serde_with::rust::double_option",
        skip_serializing_if = "Option::is_none"
    )]
    pub tx_power_min: Option<Option<i32>>,
    #[serde(
        rename = "tx_power_max",
        default,
        with = "::serde_with::rust::double_option",
        skip_serializing_if = "Option::is_none"
    )]
    pub tx_power_max: Option<Option<i32>>,
    #[serde(rename = "regulatory_domain")]
    pub regulatory_domain: crate::models::RegulatoryDomainEnum,
    #[serde(
        rename = "rx_power_min",
        default,
        with = "::serde_with::rust::double_option",
        skip_serializing_if = "Option::is_none"
    )]
    pub rx_power_min: Option<Option<i32>>,
    #[serde(
        rename = "supported_data_rates",
        skip_serializing_if = "Option::is_none"
    )]
    pub supported_data_rates:
        Option<Vec<crate::models::ApprovalWorkflowStageResponseApprovalWorkflowStage>>,
    #[serde(rename = "custom_fields", skip_serializing_if = "Option::is_none")]
    pub custom_fields: Option<::std::collections::HashMap<String, serde_json::Value>>,
    #[serde(rename = "relationships", skip_serializing_if = "Option::is_none")]
    pub relationships: Option<
        ::std::collections::HashMap<
            String,
            crate::models::ApprovalWorkflowDefinitionRequestRelationshipsValue,
        >,
    >,
    #[serde(rename = "tags", skip_serializing_if = "Option::is_none")]
    pub tags: Option<Vec<crate::models::ApprovalWorkflowStageResponseApprovalWorkflowStage>>,
}

impl RadioProfileRequest {
    /// Base class to use for serializers based on OrganizationalModel or PrimaryModel.  Can also be used for models derived from BaseModel, so long as they support custom fields, notes, and relationships.
    pub fn new(
        name: String,
        regulatory_domain: crate::models::RegulatoryDomainEnum,
    ) -> RadioProfileRequest {
        RadioProfileRequest {
            id: None,
            channel_width: None,
            allowed_channel_list: None,
            name,
            frequency: None,
            tx_power_min: None,
            tx_power_max: None,
            regulatory_domain,
            rx_power_min: None,
            supported_data_rates: None,
            custom_fields: None,
            relationships: None,
            tags: None,
        }
    }
}