mirror of
https://github.com/bpg/terraform-provider-proxmox.git
synced 2025-06-30 18:42:58 +00:00
100 lines
3.2 KiB
Go
100 lines
3.2 KiB
Go
/* 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"
|
|
)
|
|
|
|
// VirtualEnvironmentRoleCreateRequestBody contains the data for an access group create request.
|
|
type VirtualEnvironmentRoleCreateRequestBody struct {
|
|
ID string `json:"roleid" url:"roleid"`
|
|
Privileges CustomPrivileges `json:"privs" url:"privs,comma"`
|
|
}
|
|
|
|
// VirtualEnvironmentRoleGetResponseBody contains the body from an access group get response.
|
|
type VirtualEnvironmentRoleGetResponseBody struct {
|
|
Data *CustomPrivileges `json:"data,omitempty"`
|
|
}
|
|
|
|
// VirtualEnvironmentRoleListResponseBody contains the body from an access group list response.
|
|
type VirtualEnvironmentRoleListResponseBody struct {
|
|
Data []*VirtualEnvironmentRoleListResponseData `json:"data,omitempty"`
|
|
}
|
|
|
|
// VirtualEnvironmentRoleListResponseData contains the data from an access group list response.
|
|
type VirtualEnvironmentRoleListResponseData struct {
|
|
ID string `json:"roleid"`
|
|
Privileges *CustomPrivileges `json:"privs,omitempty"`
|
|
Special *CustomBool `json:"special,omitempty"`
|
|
}
|
|
|
|
// VirtualEnvironmentRoleUpdateRequestBody contains the data for an access group update request.
|
|
type VirtualEnvironmentRoleUpdateRequestBody struct {
|
|
Privileges CustomPrivileges `json:"privs" url:"privs,comma"`
|
|
}
|
|
|
|
// CreateRole creates an access role.
|
|
func (c *VirtualEnvironmentClient) CreateRole(d *VirtualEnvironmentRoleCreateRequestBody) error {
|
|
return c.DoRequest(hmPOST, "access/roles", d, nil)
|
|
}
|
|
|
|
// DeleteRole deletes an access role.
|
|
func (c *VirtualEnvironmentClient) DeleteRole(id string) error {
|
|
return c.DoRequest(hmDELETE, fmt.Sprintf("access/roles/%s", url.PathEscape(id)), nil, nil)
|
|
}
|
|
|
|
// GetRole retrieves an access role.
|
|
func (c *VirtualEnvironmentClient) GetRole(id string) (*CustomPrivileges, error) {
|
|
resBody := &VirtualEnvironmentRoleGetResponseBody{}
|
|
err := c.DoRequest(hmGET, fmt.Sprintf("access/roles/%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)
|
|
|
|
return resBody.Data, nil
|
|
}
|
|
|
|
// ListRoles retrieves a list of access roles.
|
|
func (c *VirtualEnvironmentClient) ListRoles() ([]*VirtualEnvironmentRoleListResponseData, error) {
|
|
resBody := &VirtualEnvironmentRoleListResponseBody{}
|
|
err := c.DoRequest(hmGET, "access/roles", 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
|
|
})
|
|
|
|
for i := range resBody.Data {
|
|
if resBody.Data[i].Privileges != nil {
|
|
sort.Strings(*resBody.Data[i].Privileges)
|
|
}
|
|
}
|
|
|
|
return resBody.Data, nil
|
|
}
|
|
|
|
// UpdateRole updates an access role.
|
|
func (c *VirtualEnvironmentClient) UpdateRole(id string, d *VirtualEnvironmentRoleUpdateRequestBody) error {
|
|
return c.DoRequest(hmPUT, fmt.Sprintf("access/roles/%s", url.PathEscape(id)), d, nil)
|
|
}
|