/* * 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 firewall import ( "context" "fmt" "net/http" "net/url" "sort" "github.com/bpg/terraform-provider-proxmox/proxmox/api" ) // SecurityGroup is an interface for the Proxmox security group API. type SecurityGroup interface { CreateGroup(ctx context.Context, d *GroupCreateRequestBody) error ListGroups(ctx context.Context) ([]*GroupListResponseData, error) UpdateGroup(ctx context.Context, d *GroupUpdateRequestBody) error DeleteGroup(ctx context.Context, group string) error } func (c *Client) securityGroupsPath() string { return "cluster/firewall/groups" } // CreateGroup create new security group. func (c *Client) CreateGroup(ctx context.Context, d *GroupCreateRequestBody) error { err := c.DoRequest(ctx, http.MethodPost, c.securityGroupsPath(), d, nil) if err != nil { return fmt.Errorf("error creating security group: %w", err) } return nil } // ListGroups retrieve list of security groups. func (c *Client) ListGroups(ctx context.Context) ([]*GroupListResponseData, error) { resBody := &GroupListResponseBody{} err := c.DoRequest(ctx, http.MethodGet, c.securityGroupsPath(), nil, resBody) if err != nil { return nil, fmt.Errorf("error retrieving security groups: %w", err) } if resBody.Data == nil { return nil, api.ErrNoDataObjectInResponse } sort.Slice(resBody.Data, func(i, j int) bool { return resBody.Data[i].Group < resBody.Data[j].Group }) return resBody.Data, nil } // UpdateGroup update security group. func (c *Client) UpdateGroup(ctx context.Context, d *GroupUpdateRequestBody) error { err := c.DoRequest( ctx, http.MethodPost, c.securityGroupsPath(), d, nil, ) if err != nil { return fmt.Errorf("error updating security group: %w", err) } return nil } // DeleteGroup delete security group. func (c *Client) DeleteGroup(ctx context.Context, group string) error { err := c.DoRequest( ctx, http.MethodDelete, fmt.Sprintf("%s/%s", c.securityGroupsPath(), url.PathEscape(group)), nil, nil, ) if err != nil { return fmt.Errorf("error deleting security group '%s': %w", group, err) } return nil }