mirror of
https://github.com/bpg/terraform-provider-proxmox.git
synced 2025-06-30 02:31:10 +00:00
move `types` back from `internal` to `proxmox` and adjust a few other types, to make sure `proxmox` package is not dependent on anything else, and therefore can be extracted to a separate repo (#423)
101 lines
2.4 KiB
Go
101 lines
2.4 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 access
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"net/http"
|
|
"net/url"
|
|
"sort"
|
|
|
|
"github.com/bpg/terraform-provider-proxmox/proxmox/api"
|
|
"github.com/bpg/terraform-provider-proxmox/proxmox/types"
|
|
)
|
|
|
|
func (c *Client) rolesPath() string {
|
|
return c.ExpandPath("roles")
|
|
}
|
|
|
|
func (c *Client) rolePath(id string) string {
|
|
return fmt.Sprintf("%s/%s", c.rolesPath(), url.PathEscape(id))
|
|
}
|
|
|
|
// CreateRole creates an access role.
|
|
func (c *Client) CreateRole(ctx context.Context, d *RoleCreateRequestBody) error {
|
|
err := c.DoRequest(ctx, http.MethodPost, c.rolesPath(), d, nil)
|
|
if err != nil {
|
|
return fmt.Errorf("error creating role: %w", err)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// DeleteRole deletes an access role.
|
|
func (c *Client) DeleteRole(ctx context.Context, id string) error {
|
|
err := c.DoRequest(ctx, http.MethodDelete, c.rolePath(id), nil, nil)
|
|
if err != nil {
|
|
return fmt.Errorf("error deleting role: %w", err)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// GetRole retrieves an access role.
|
|
func (c *Client) GetRole(ctx context.Context, id string) (*types.CustomPrivileges, error) {
|
|
resBody := &RoleGetResponseBody{}
|
|
|
|
err := c.DoRequest(ctx, http.MethodGet, c.rolePath(id), nil, resBody)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("error getting role: %w", err)
|
|
}
|
|
|
|
if resBody.Data == nil {
|
|
return nil, api.ErrNoDataObjectInResponse
|
|
}
|
|
|
|
sort.Strings(*resBody.Data)
|
|
|
|
return resBody.Data, nil
|
|
}
|
|
|
|
// ListRoles retrieves a list of access roles.
|
|
func (c *Client) ListRoles(ctx context.Context) ([]*RoleListResponseData, error) {
|
|
resBody := &RoleListResponseBody{}
|
|
|
|
err := c.DoRequest(ctx, http.MethodGet, c.rolesPath(), nil, resBody)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("error listing roles: %w", err)
|
|
}
|
|
|
|
if resBody.Data == nil {
|
|
return nil, api.ErrNoDataObjectInResponse
|
|
}
|
|
|
|
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 *Client) UpdateRole(ctx context.Context, id string, d *RoleUpdateRequestBody) error {
|
|
err := c.DoRequest(ctx, http.MethodPut, c.rolePath(id), d, nil)
|
|
if err != nil {
|
|
return fmt.Errorf("error updating role: %w", err)
|
|
}
|
|
|
|
return nil
|
|
}
|