1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
use anyhow::Result;

use crate::Client;

pub struct AdminUsergroups {
    pub client: Client,
}

impl AdminUsergroups {
    #[doc(hidden)]
    pub fn new(client: Client) -> Self {
        AdminUsergroups { client }
    }

    /**
     * This function performs a `POST` to the `/admin.usergroups.addChannels` endpoint.
     *
     * Add one or more default channels to an IDP group.
     *
     * FROM: <https://api.slack.com/methods/admin.usergroups.addChannels>
     *
     * **Parameters:**
     *
     * * `token: &str` -- Authentication token. Requires scope: `admin.usergroups:write`.
     */
    pub async fn add_channels(&self) -> Result<crate::types::DndEndSchema> {
        let url = self.client.url("/admin.usergroups.addChannels", None);
        self.client
            .post(
                &url,
                crate::Message {
                    body: None,
                    content_type: Some("application/x-www-form-urlencoded".to_string()),
                },
            )
            .await
    }
    /**
     * This function performs a `POST` to the `/admin.usergroups.addTeams` endpoint.
     *
     * Associate one or more default workspaces with an organization-wide IDP group.
     *
     * FROM: <https://api.slack.com/methods/admin.usergroups.addTeams>
     *
     * **Parameters:**
     *
     * * `token: &str` -- Authentication token. Requires scope: `admin.teams:write`.
     */
    pub async fn add_teams(&self) -> Result<crate::types::DndEndSchema> {
        let url = self.client.url("/admin.usergroups.addTeams", None);
        self.client
            .post(
                &url,
                crate::Message {
                    body: None,
                    content_type: Some("application/x-www-form-urlencoded".to_string()),
                },
            )
            .await
    }
    /**
     * This function performs a `GET` to the `/admin.usergroups.listChannels` endpoint.
     *
     * List the channels linked to an org-level IDP group (user group).
     *
     * FROM: <https://api.slack.com/methods/admin.usergroups.listChannels>
     *
     * **Parameters:**
     *
     * * `token: &str` -- Authentication token. Requires scope: `admin.usergroups:read`.
     * * `usergroup_id: &str` -- ID of the IDP group to list default channels for.
     * * `team_id: &str` -- ID of the the workspace.
     * * `include_num_members: bool` -- Flag to include or exclude the count of members per channel.
     */
    pub async fn list_channel(
        &self,
        usergroup_id: &str,
        team_id: &str,
        include_num_members: bool,
    ) -> Result<crate::types::DndEndSchema> {
        let mut query_args: Vec<(String, String)> = Default::default();
        if include_num_members {
            query_args.push((
                "include_num_members".to_string(),
                include_num_members.to_string(),
            ));
        }
        if !team_id.is_empty() {
            query_args.push(("team_id".to_string(), team_id.to_string()));
        }
        if !usergroup_id.is_empty() {
            query_args.push(("usergroup_id".to_string(), usergroup_id.to_string()));
        }
        let query_ = serde_urlencoded::to_string(&query_args).unwrap();
        let url = self
            .client
            .url(&format!("/admin.usergroups.listChannels?{}", query_), None);
        self.client
            .get(
                &url,
                crate::Message {
                    body: None,
                    content_type: None,
                },
            )
            .await
    }
    /**
     * This function performs a `POST` to the `/admin.usergroups.removeChannels` endpoint.
     *
     * Remove one or more default channels from an org-level IDP group (user group).
     *
     * FROM: <https://api.slack.com/methods/admin.usergroups.removeChannels>
     *
     * **Parameters:**
     *
     * * `token: &str` -- Authentication token. Requires scope: `admin.usergroups:write`.
     */
    pub async fn remove_channels(&self) -> Result<crate::types::DndEndSchema> {
        let url = self.client.url("/admin.usergroups.removeChannels", None);
        self.client
            .post(
                &url,
                crate::Message {
                    body: None,
                    content_type: Some("application/x-www-form-urlencoded".to_string()),
                },
            )
            .await
    }
}