mirror of
https://github.com/bpg/terraform-provider-proxmox.git
synced 2025-06-30 10:33:46 +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
52 lines
1.5 KiB
Go
52 lines
1.5 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 nodes
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"net/http"
|
|
|
|
"github.com/bpg/terraform-provider-proxmox/proxmox/api"
|
|
)
|
|
|
|
// DeleteCertificate deletes the custom certificate for a node.
|
|
func (c *Client) DeleteCertificate(ctx context.Context, d *CertificateDeleteRequestBody) error {
|
|
err := c.DoRequest(ctx, http.MethodDelete, c.ExpandPath("certificates/custom"), d, nil)
|
|
if err != nil {
|
|
return fmt.Errorf("error deleting certificate: %w", err)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// ListCertificates retrieves the list of certificates for a node.
|
|
func (c *Client) ListCertificates(ctx context.Context) (*[]CertificateListResponseData, error) {
|
|
resBody := &CertificateListResponseBody{}
|
|
|
|
err := c.DoRequest(ctx, http.MethodGet, c.ExpandPath("certificates/info"), nil, resBody)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("error retrieving certificate list: %w", err)
|
|
}
|
|
|
|
if resBody.Data == nil {
|
|
return nil, api.ErrNoDataObjectInResponse
|
|
}
|
|
|
|
return resBody.Data, nil
|
|
}
|
|
|
|
// UpdateCertificate updates the custom certificate for a node.
|
|
func (c *Client) UpdateCertificate(ctx context.Context, d *CertificateUpdateRequestBody) error {
|
|
err := c.DoRequest(ctx, http.MethodPost, c.ExpandPath("certificates/custom"), d, nil)
|
|
if err != nil {
|
|
return fmt.Errorf("error updating certificate: %w", err)
|
|
}
|
|
|
|
return nil
|
|
}
|