/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at https://mozilla.org/MPL/2.0/. */ package proxmox import ( "errors" "fmt" "net/url" "sort" ) // VirtualEnvironmentAccessGroupCreateRequestBody contains the data for an access group create request. type VirtualEnvironmentAccessGroupCreateRequestBody struct { Comment string `json:"comment" url:"comment"` ID string `json:"groupid" url:"groupid"` } // VirtualEnvironmentAccessGroupGetResponseBody contains the body from an access group get response. type VirtualEnvironmentAccessGroupGetResponseBody struct { Data *VirtualEnvironmentAccessGroupGetResponseData `json:"data,omitempty"` } // VirtualEnvironmentAccessGroupGetResponseData contains the data from an access group get response. type VirtualEnvironmentAccessGroupGetResponseData struct { Comment string `json:"comment"` Members []string `json:"members"` } // VirtualEnvironmentAccessGroupListResponseBody contains the body from an access group list response. type VirtualEnvironmentAccessGroupListResponseBody struct { Data []*VirtualEnvironmentAccessGroupListResponseData `json:"data,omitempty"` } // VirtualEnvironmentAccessGroupListResponseData contains the data from an access group list response. type VirtualEnvironmentAccessGroupListResponseData struct { Comment string `json:"comment"` ID string `json:"groupid"` } // VirtualEnvironmentAccessGroupUpdateRequestBody contains the data for an access group update request. type VirtualEnvironmentAccessGroupUpdateRequestBody struct { Comment string `json:"comment" url:"comment"` } // CreateAccessGroup creates an access group. func (c *VirtualEnvironmentClient) CreateAccessGroup(d *VirtualEnvironmentAccessGroupCreateRequestBody) error { return c.DoRequest(hmPOST, "access/groups", d, nil) } // DeleteAccessGroup deletes an access group. func (c *VirtualEnvironmentClient) DeleteAccessGroup(id string) error { return c.DoRequest(hmDELETE, fmt.Sprintf("access/groups/%s", id), nil, nil) } // GetAccessGroup retrieves an access group. func (c *VirtualEnvironmentClient) GetAccessGroup(id string) (*VirtualEnvironmentAccessGroupGetResponseData, error) { resBody := &VirtualEnvironmentAccessGroupGetResponseBody{} err := c.DoRequest(hmGET, fmt.Sprintf("access/groups/%s", url.PathEscape(id)), nil, resBody) if err != nil { return nil, err } if resBody.Data == nil { return nil, errors.New("The server did not include a data object in the response") } sort.Strings(resBody.Data.Members) return resBody.Data, nil } // ListAccessGroups retrieves a list of access groups. func (c *VirtualEnvironmentClient) ListAccessGroups() ([]*VirtualEnvironmentAccessGroupListResponseData, error) { resBody := &VirtualEnvironmentAccessGroupListResponseBody{} err := c.DoRequest(hmGET, "access/groups", nil, resBody) if err != nil { return nil, err } if resBody.Data == nil { return nil, errors.New("The server did not include a data object in the response") } sort.Slice(resBody.Data, func(i, j int) bool { return resBody.Data[i].ID < resBody.Data[j].ID }) return resBody.Data, nil } // UpdateAccessGroup updates an access group. func (c *VirtualEnvironmentClient) UpdateAccessGroup(id string, d *VirtualEnvironmentAccessGroupUpdateRequestBody) error { return c.DoRequest(hmPUT, fmt.Sprintf("access/groups/%s", id), d, nil) }