Skip to main content

nautobot_openapi/models/
dynamic_group.rs

1/*
2 * API Documentation
3 *
4 * Source of truth and network automation platform
5 *
6 * The version of the OpenAPI document: 3.1.0 (3.1)
7 *
8 * Generated by: https://openapi-generator.tech
9 */
10
11/// DynamicGroup : 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.
12
13#[derive(Clone, Debug, PartialEq, Default, Serialize, Deserialize)]
14pub struct DynamicGroup {
15    #[serde(rename = "id", skip_serializing_if = "Option::is_none")]
16    pub id: Option<uuid::Uuid>,
17    #[serde(rename = "object_type", skip_serializing_if = "Option::is_none")]
18    pub object_type: Option<String>,
19    /// Human friendly display value
20    #[serde(rename = "display", skip_serializing_if = "Option::is_none")]
21    pub display: Option<String>,
22    #[serde(rename = "url", skip_serializing_if = "Option::is_none")]
23    pub url: Option<String>,
24    #[serde(rename = "natural_slug", skip_serializing_if = "Option::is_none")]
25    pub natural_slug: Option<String>,
26    #[serde(rename = "content_type")]
27    pub content_type: String,
28    #[serde(rename = "name")]
29    pub name: String,
30    #[serde(rename = "description", skip_serializing_if = "Option::is_none")]
31    pub description: Option<String>,
32    #[serde(rename = "group_type", skip_serializing_if = "Option::is_none")]
33    pub group_type: Option<crate::models::GroupTypeEnum>,
34    /// A JSON-encoded dictionary of filter parameters defining membership of this group
35    #[serde(
36        rename = "filter",
37        default,
38        with = "::serde_with::rust::double_option",
39        skip_serializing_if = "Option::is_none"
40    )]
41    pub filter: Option<Option<serde_json::Value>>,
42    #[serde(
43        rename = "tenant",
44        default,
45        with = "::serde_with::rust::double_option",
46        skip_serializing_if = "Option::is_none"
47    )]
48    pub tenant: Option<Option<Box<crate::models::ApprovalWorkflowUser>>>,
49    #[serde(
50        rename = "created",
51        default,
52        with = "::serde_with::rust::double_option",
53        skip_serializing_if = "Option::is_none"
54    )]
55    pub created: Option<Option<String>>,
56    #[serde(
57        rename = "last_updated",
58        default,
59        with = "::serde_with::rust::double_option",
60        skip_serializing_if = "Option::is_none"
61    )]
62    pub last_updated: Option<Option<String>>,
63    #[serde(rename = "notes_url", skip_serializing_if = "Option::is_none")]
64    pub notes_url: Option<String>,
65    #[serde(rename = "custom_fields", skip_serializing_if = "Option::is_none")]
66    pub custom_fields: Option<::std::collections::HashMap<String, serde_json::Value>>,
67    #[serde(rename = "tags", skip_serializing_if = "Option::is_none")]
68    pub tags: Option<Vec<crate::models::ApprovalWorkflowStageResponseApprovalWorkflowStage>>,
69}
70
71impl DynamicGroup {
72    /// 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.
73    pub fn new(content_type: String, name: String) -> DynamicGroup {
74        DynamicGroup {
75            id: None,
76            object_type: None,
77            display: None,
78            url: None,
79            natural_slug: None,
80            content_type,
81            name,
82            description: None,
83            group_type: None,
84            filter: None,
85            tenant: None,
86            created: None,
87            last_updated: None,
88            notes_url: None,
89            custom_fields: None,
90            tags: None,
91        }
92    }
93}