fix: moved authenticated requests to helper
Some checks failed
CI / build (push) Failing after 3m19s
CI / lint (push) Failing after 2m50s
CI / pkl-validate (push) Successful in 10s
CI / integration-tests (push) Has been skipped
CI / conformance-tests (latest) (push) Has been skipped

This commit is contained in:
2026-02-03 22:44:23 +01:00
parent ca99733c9c
commit 35a789d5d9
3 changed files with 38 additions and 94 deletions

View File

@@ -3,6 +3,9 @@ package main
import ( import (
"encoding/json" "encoding/json"
"fmt" "fmt"
"io"
"log"
"net/http"
"os" "os"
) )
@@ -45,3 +48,31 @@ func parseLXCProperties(data json.RawMessage) (*LXCProperties, error) {
} }
return &props, nil return &props, nil
} }
func createAuthorizationString(username, token string) string {
return "PVEAPIToken=" + username + "=" + token
}
func authenticatedRequest(method, url, authorization string, body io.Reader) ([]byte, error) {
client := &http.Client{}
request, err := http.NewRequest(method, url, body)
if err != nil {
return nil, err
}
request.Header.Set("Authorization", authorization)
resp, err := client.Do(request)
if err != nil {
return nil, err
}
data, err := io.ReadAll(resp.Body)
if err != nil {
return nil, err
}
log.Println("URL: ", method, "Status Code:", resp.Status, "Body: ", string(data))
return data, nil
}

View File

@@ -10,7 +10,6 @@ import (
"encoding/json" "encoding/json"
"errors" "errors"
"fmt" "fmt"
"io"
"log" "log"
"net/http" "net/http"
"strconv" "strconv"
@@ -122,17 +121,12 @@ func (p *Plugin) Create(ctx context.Context, req *resource.CreateRequest) (*reso
}, err }, err
} }
client := &http.Client{}
arguments := "vmid=" + props.VMID + "&ostemplate=" + props.OSTemplate + "&hostname=" + props.Hostname + "&cores=" + strconv.Itoa(props.Cores) + "&memory=" + strconv.Itoa(props.Memory) arguments := "vmid=" + props.VMID + "&ostemplate=" + props.OSTemplate + "&hostname=" + props.Hostname + "&cores=" + strconv.Itoa(props.Cores) + "&memory=" + strconv.Itoa(props.Memory)
if props.Description != "" { if props.Description != "" {
arguments += "&description=" + props.Description arguments += "&description=" + props.Description
} }
request, err := http.NewRequest("POST", config.URL+"/api2/json/nodes/"+config.NODE+"/lxc", bytes.NewBuffer([]byte(arguments))) _, err = authenticatedRequest(http.MethodPost, config.URL+"/api2/json/nodes/"+config.NODE+"/lxc", createAuthorizationString(username, token), bytes.NewBuffer([]byte(arguments)))
request.Header.Set("Authorization", "PVEAPIToken="+username+"="+token)
resp, err := client.Do(request)
if err != nil { if err != nil {
return &resource.CreateResult{ return &resource.CreateResult{
@@ -145,21 +139,6 @@ func (p *Plugin) Create(ctx context.Context, req *resource.CreateRequest) (*reso
}, err }, err
} }
body, err := io.ReadAll(resp.Body)
if err != nil {
return &resource.CreateResult{
ProgressResult: &resource.ProgressResult{
Operation: resource.OperationCreate,
OperationStatus: resource.OperationStatusFailure,
ErrorCode: resource.OperationErrorCodeInternalFailure,
StatusMessage: err.Error(),
},
}, err
}
log.Println("Response StatusCode: ", resp.Status)
log.Println("Response Body: ", string(body))
return &resource.CreateResult{ return &resource.CreateResult{
ProgressResult: &resource.ProgressResult{ ProgressResult: &resource.ProgressResult{
Operation: resource.OperationCreate, Operation: resource.OperationCreate,
@@ -182,19 +161,12 @@ func (p *Plugin) Read(ctx context.Context, req *resource.ReadRequest) (*resource
return &resource.ReadResult{}, nil return &resource.ReadResult{}, nil
} }
client := &http.Client{} data, err := authenticatedRequest(http.MethodGet, config.URL+"/api2/json/nodes/"+config.NODE+"/lxc/"+req.NativeID+"/config", createAuthorizationString(username, token), nil)
request, err := http.NewRequest("GET", config.URL+"/api2/json/nodes/"+config.NODE+"/lxc/"+req.NativeID+"/config", nil)
if err != nil { if err != nil {
return &resource.ReadResult{ return &resource.ReadResult{
ErrorCode: resource.OperationErrorCodeNetworkFailure, ErrorCode: resource.OperationErrorCodeNetworkFailure,
}, err }, err
} }
request.Header.Set("Authorization", "PVEAPIToken="+username+"="+token)
resp, err := client.Do(request)
data, err := io.ReadAll(resp.Body)
var props StatusLXCConfigResponse var props StatusLXCConfigResponse
@@ -300,16 +272,11 @@ func (p *Plugin) Update(ctx context.Context, req *resource.UpdateRequest) (*reso
}, err }, err
} }
client := &http.Client{}
url := config.URL + "/api2/json/nodes/" + config.NODE + "/lxc/" + desir.VMID + "/config"
arguments := "vmid=" + desir.VMID + "&hostname=" + desir.Hostname + "&description=" + desir.Description + "&cores=" + strconv.Itoa(desir.Cores) + "&memory=" + strconv.Itoa(desir.Memory) arguments := "vmid=" + desir.VMID + "&hostname=" + desir.Hostname + "&description=" + desir.Description + "&cores=" + strconv.Itoa(desir.Cores) + "&memory=" + strconv.Itoa(desir.Memory)
argumentBuffer := bytes.NewBuffer([]byte(arguments)) argumentBuffer := bytes.NewBuffer([]byte(arguments))
request, err := http.NewRequest("PUT", url, argumentBuffer) _, err = authenticatedRequest(http.MethodPut, config.URL+"/api2/json/nodes/"+config.NODE+"/lxc/"+desir.VMID+"/config", createAuthorizationString(username, token), argumentBuffer)
request.Header.Set("Authorization", "PVEAPIToken="+username+"="+token)
resp, err := client.Do(request)
if err != nil { if err != nil {
return &resource.UpdateResult{ return &resource.UpdateResult{
ProgressResult: &resource.ProgressResult{ ProgressResult: &resource.ProgressResult{
@@ -320,8 +287,6 @@ func (p *Plugin) Update(ctx context.Context, req *resource.UpdateRequest) (*reso
}, },
}, err }, err
} }
log.Println("Response StatusCode: ", resp.Status)
} }
result, err := p.Read(ctx, &resource.ReadRequest{ result, err := p.Read(ctx, &resource.ReadRequest{
@@ -368,14 +333,7 @@ func (p *Plugin) Delete(ctx context.Context, req *resource.DeleteRequest) (*reso
}, err }, err
} }
client := &http.Client{} _, err = authenticatedRequest(http.MethodDelete, config.URL+"/api2/json/nodes/"+config.NODE+"/lxc/"+req.NativeID, createAuthorizationString(username, token), nil)
url := config.URL + "/api2/json/nodes/" + config.NODE + "/lxc/" + req.NativeID
request, err := http.NewRequest("DELETE", url, nil)
request.Header.Set("Authorization", "PVEAPIToken="+username+"="+token)
resp, err := client.Do(request)
if err != nil { if err != nil {
return &resource.DeleteResult{ return &resource.DeleteResult{
@@ -388,21 +346,6 @@ func (p *Plugin) Delete(ctx context.Context, req *resource.DeleteRequest) (*reso
}, err }, err
} }
body, err := io.ReadAll(resp.Body)
if err != nil {
return &resource.DeleteResult{
ProgressResult: &resource.ProgressResult{
Operation: resource.OperationCreate,
OperationStatus: resource.OperationStatusFailure,
ErrorCode: resource.OperationErrorCodeInternalFailure,
StatusMessage: err.Error(),
},
}, err
}
log.Println("Response StatusCode: ", resp.Status)
log.Println("Response Body: ", string(body))
return &resource.DeleteResult{ return &resource.DeleteResult{
ProgressResult: &resource.ProgressResult{ ProgressResult: &resource.ProgressResult{
Operation: resource.OperationCreate, Operation: resource.OperationCreate,
@@ -452,21 +395,14 @@ func (p *Plugin) List(ctx context.Context, req *resource.ListRequest) (*resource
}, err }, err
} }
client := &http.Client{}
var props StatusGeneralResponse var props StatusGeneralResponse
request, err := http.NewRequest("GET", config.URL+"/api2/json/nodes/"+config.NODE+"/lxc", nil) data, err := authenticatedRequest(http.MethodGet, config.URL+"/api2/json/nodes/"+config.NODE+"/lxc", createAuthorizationString(username, token), nil)
if err != nil { if err != nil {
return &resource.ListResult{ return &resource.ListResult{
NativeIDs: []string{}, NativeIDs: []string{},
}, err }, err
} }
request.Header.Set("Authorization", "PVEAPIToken="+username+"="+token)
resp, err := client.Do(request)
data, err := io.ReadAll(resp.Body)
json.Unmarshal(data, &props) json.Unmarshal(data, &props)

View File

@@ -3,7 +3,6 @@ package main
import ( import (
"context" "context"
"encoding/json" "encoding/json"
"io"
"log" "log"
"net/http" "net/http"
"strconv" "strconv"
@@ -55,20 +54,9 @@ func TestCreate(t *testing.T) {
require.NotNil(t, result.ProgressResult, "Create should return ProgressResult") require.NotNil(t, result.ProgressResult, "Create should return ProgressResult")
require.Eventually(t, func() bool { require.Eventually(t, func() bool {
client := &http.Client{}
var props StatusGeneralResponse var props StatusGeneralResponse
request, err := http.NewRequest("GET", config.URL+"/api2/json/nodes/"+config.NODE+"/lxc", nil) data, _ := authenticatedRequest(http.MethodGet, config.URL+"/api2/json/nodes/"+config.NODE+"/lxc", createAuthorizationString(username, token), nil)
if err != nil {
t.Logf("Something unexpected happened")
return false
}
request.Header.Set("Authorization", "PVEAPIToken="+username+"="+token)
resp, err := client.Do(request)
data, err := io.ReadAll(resp.Body)
json.Unmarshal(data, &props) json.Unmarshal(data, &props)
@@ -206,20 +194,9 @@ func TestDelete(t *testing.T) {
require.NotNil(t, result.ProgressResult, "Create should return ProgressResult") require.NotNil(t, result.ProgressResult, "Create should return ProgressResult")
require.Eventually(t, func() bool { require.Eventually(t, func() bool {
client := &http.Client{}
var props StatusGeneralResponse var props StatusGeneralResponse
request, err := http.NewRequest("GET", config.URL+"/api2/json/nodes/"+config.NODE+"/lxc", nil) data, _ := authenticatedRequest(http.MethodGet, config.URL+"/api2/json/nodes/"+config.NODE+"/lxc", createAuthorizationString(username, token), nil)
if err != nil {
t.Logf("Something unexpected happened")
return false
}
request.Header.Set("Authorization", "PVEAPIToken="+username+"="+token)
resp, err := client.Do(request)
data, err := io.ReadAll(resp.Body)
json.Unmarshal(data, &props) json.Unmarshal(data, &props)