mirror of
https://github.com/bpg/terraform-provider-proxmox.git
synced 2025-06-30 02:31:10 +00:00
* cleanup 1
* continue refactoring
* more refactoring
* move VMs under nodes
* move container and other apis under nodes
* cleanups
* enabled revive.exported linter & add comments to exported stuff
* enable godot linter
* enable wsl linter
* enable thelper linter
* enable govet linter
* cleanup after rebase
* cleanup after rebase
* extract SSH ops into a separate interface
* fix linter error
* move ssh code to its own package
* cleaning up VirtualEnvironmentClient receivers
* on the finish line
* not sure what else I forgot... 🤔
* fix ssh connection and upload
* renaming client interfaces
* final cleanups
147 lines
3.6 KiB
Go
147 lines
3.6 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/.
|
|
*/
|
|
|
|
/**
|
|
* Reference: https://pve.proxmox.com/pve-docs/api-viewer/#/cluster/firewall/ipset
|
|
*/
|
|
|
|
package firewall
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"net/http"
|
|
"net/url"
|
|
"sort"
|
|
|
|
"github.com/bpg/terraform-provider-proxmox/proxmox/api"
|
|
)
|
|
|
|
// IPSet is an interface for managing IP sets.
|
|
type IPSet interface {
|
|
CreateIPSet(ctx context.Context, d *IPSetCreateRequestBody) error
|
|
AddCIDRToIPSet(ctx context.Context, id string, d IPSetGetResponseData) error
|
|
UpdateIPSet(ctx context.Context, d *IPSetUpdateRequestBody) error
|
|
DeleteIPSet(ctx context.Context, id string) error
|
|
DeleteIPSetContent(ctx context.Context, id string, cidr string) error
|
|
GetIPSetContent(ctx context.Context, id string) ([]*IPSetGetResponseData, error)
|
|
ListIPSets(ctx context.Context) ([]*IPSetListResponseData, error)
|
|
}
|
|
|
|
func (c *Client) ipsetPath() string {
|
|
return c.ExpandPath("firewall/ipset")
|
|
}
|
|
|
|
// CreateIPSet create an IPSet.
|
|
func (c *Client) CreateIPSet(ctx context.Context, d *IPSetCreateRequestBody) error {
|
|
err := c.DoRequest(ctx, http.MethodPost, c.ipsetPath(), d, nil)
|
|
if err != nil {
|
|
return fmt.Errorf("error creating IPSet: %w", err)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// AddCIDRToIPSet adds IP or Network to IPSet.
|
|
func (c *Client) AddCIDRToIPSet(ctx context.Context, id string, d IPSetGetResponseData) error {
|
|
err := c.DoRequest(
|
|
ctx,
|
|
http.MethodPost,
|
|
fmt.Sprintf("%s/%s", c.ipsetPath(), url.PathEscape(id)),
|
|
&d,
|
|
nil,
|
|
)
|
|
if err != nil {
|
|
return fmt.Errorf("error adding CIDR to IPSet: %w", err)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// UpdateIPSet updates an IPSet.
|
|
func (c *Client) UpdateIPSet(ctx context.Context, d *IPSetUpdateRequestBody) error {
|
|
err := c.DoRequest(ctx, http.MethodPost, c.ipsetPath(), d, nil)
|
|
if err != nil {
|
|
return fmt.Errorf("error updating IPSet: %w", err)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// DeleteIPSet delete an IPSet.
|
|
func (c *Client) DeleteIPSet(ctx context.Context, id string) error {
|
|
err := c.DoRequest(
|
|
ctx,
|
|
http.MethodDelete,
|
|
fmt.Sprintf("%s/%s", c.ipsetPath(), url.PathEscape(id)),
|
|
nil,
|
|
nil,
|
|
)
|
|
if err != nil {
|
|
return fmt.Errorf("error deleting IPSet %s: %w", id, err)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// DeleteIPSetContent remove IP or Network from IPSet.
|
|
func (c *Client) DeleteIPSetContent(ctx context.Context, id string, cidr string) error {
|
|
err := c.DoRequest(
|
|
ctx,
|
|
http.MethodDelete,
|
|
fmt.Sprintf("%s/%s/%s", c.ipsetPath(), url.PathEscape(id), url.PathEscape(cidr)),
|
|
nil,
|
|
nil,
|
|
)
|
|
if err != nil {
|
|
return fmt.Errorf("error deleting IPSet content %s: %w", id, err)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// GetIPSetContent retrieve a list of IPSet content.
|
|
func (c *Client) GetIPSetContent(ctx context.Context, id string) ([]*IPSetGetResponseData, error) {
|
|
resBody := &IPSetGetResponseBody{}
|
|
|
|
err := c.DoRequest(
|
|
ctx,
|
|
http.MethodGet,
|
|
fmt.Sprintf("%s/%s", c.ipsetPath(), url.PathEscape(id)),
|
|
nil,
|
|
resBody,
|
|
)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("error getting IPSet content: %w", err)
|
|
}
|
|
|
|
if resBody.Data == nil {
|
|
return nil, api.ErrNoDataObjectInResponse
|
|
}
|
|
|
|
return resBody.Data, nil
|
|
}
|
|
|
|
// ListIPSets retrieves list of IPSets.
|
|
func (c *Client) ListIPSets(ctx context.Context) ([]*IPSetListResponseData, error) {
|
|
resBody := &IPSetListResponseBody{}
|
|
|
|
err := c.DoRequest(ctx, http.MethodGet, c.ipsetPath(), nil, resBody)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("error getting IPSet list: %w", err)
|
|
}
|
|
|
|
if resBody.Data == nil {
|
|
return nil, api.ErrNoDataObjectInResponse
|
|
}
|
|
|
|
sort.Slice(resBody.Data, func(i, j int) bool {
|
|
return resBody.Data[i].Name < resBody.Data[j].Name
|
|
})
|
|
|
|
return resBody.Data, nil
|
|
}
|