feat: working delete
This commit is contained in:
76
proxmox.go
76
proxmox.go
@@ -340,21 +340,75 @@ func (p *Plugin) Update(ctx context.Context, req *resource.UpdateRequest) (*reso
|
|||||||
|
|
||||||
// Delete removes a resource.
|
// Delete removes a resource.
|
||||||
func (p *Plugin) Delete(ctx context.Context, req *resource.DeleteRequest) (*resource.DeleteResult, error) {
|
func (p *Plugin) Delete(ctx context.Context, req *resource.DeleteRequest) (*resource.DeleteResult, error) {
|
||||||
// TODO: Implement resource deletion
|
config, err := parseTargetConfig(req.TargetConfig)
|
||||||
//
|
if err != nil {
|
||||||
// 1. Use req.NativeID to identify the resource
|
log.Println(err.Error())
|
||||||
// 2. Parse req.TargetConfig for provider credentials
|
return &resource.DeleteResult{
|
||||||
// 3. Call your provider's API to delete the resource
|
ProgressResult: &resource.ProgressResult{
|
||||||
// 4. Return ProgressResult with status
|
Operation: resource.OperationCreate,
|
||||||
|
OperationStatus: resource.OperationStatusFailure,
|
||||||
|
ErrorCode: resource.OperationErrorCodeInternalFailure,
|
||||||
|
StatusMessage: err.Error(),
|
||||||
|
},
|
||||||
|
}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
username, token, err := getCredentials()
|
||||||
|
if err != nil {
|
||||||
|
log.Println(err.Error())
|
||||||
|
return &resource.DeleteResult{
|
||||||
|
ProgressResult: &resource.ProgressResult{
|
||||||
|
Operation: resource.OperationCreate,
|
||||||
|
OperationStatus: resource.OperationStatusFailure,
|
||||||
|
ErrorCode: resource.OperationErrorCodeInternalFailure,
|
||||||
|
StatusMessage: err.Error(),
|
||||||
|
},
|
||||||
|
}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
client := &http.Client{}
|
||||||
|
|
||||||
|
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 {
|
||||||
|
return &resource.DeleteResult{
|
||||||
|
ProgressResult: &resource.ProgressResult{
|
||||||
|
Operation: resource.OperationCreate,
|
||||||
|
OperationStatus: resource.OperationStatusFailure,
|
||||||
|
ErrorCode: resource.OperationErrorCodeInternalFailure,
|
||||||
|
StatusMessage: err.Error(),
|
||||||
|
},
|
||||||
|
}, 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.OperationDelete,
|
Operation: resource.OperationCreate,
|
||||||
OperationStatus: resource.OperationStatusFailure,
|
OperationStatus: resource.OperationStatusSuccess,
|
||||||
ErrorCode: resource.OperationErrorCodeInternalFailure,
|
NativeID: req.NativeID,
|
||||||
StatusMessage: "Delete not implemented",
|
|
||||||
},
|
},
|
||||||
}, ErrNotImplemented
|
}, nil
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Status checks the progress of an async operation.
|
// Status checks the progress of an async operation.
|
||||||
|
|||||||
@@ -152,3 +152,55 @@ func TestUpdate(t *testing.T) {
|
|||||||
require.Equal(t, "testlxc-updated", props["hostname"], "hostname should have changed")
|
require.Equal(t, "testlxc-updated", props["hostname"], "hostname should have changed")
|
||||||
// test if update has happened
|
// test if update has happened
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestDelete(t *testing.T) {
|
||||||
|
ctx := context.Background()
|
||||||
|
plugin := &Plugin{}
|
||||||
|
|
||||||
|
username, token, err := getCredentials()
|
||||||
|
if err != nil {
|
||||||
|
t.Skip(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
config, err := parseTargetConfig(testTargetConfig())
|
||||||
|
if err != nil {
|
||||||
|
t.Skip(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
result, err := plugin.Delete(ctx, &resource.DeleteRequest{
|
||||||
|
ResourceType: "PROXMOX::Service::LXC",
|
||||||
|
TargetConfig: testTargetConfig(),
|
||||||
|
NativeID: "200",
|
||||||
|
})
|
||||||
|
|
||||||
|
require.NoError(t, err, "Create should not return error")
|
||||||
|
require.NotNil(t, result.ProgressResult, "Create should return ProgressResult")
|
||||||
|
|
||||||
|
require.Eventually(t, func() bool {
|
||||||
|
client := &http.Client{}
|
||||||
|
|
||||||
|
var props StatusGeneralResponse
|
||||||
|
|
||||||
|
request, err := http.NewRequest("GET", config.URL+"/api2/json/nodes/"+config.NODE+"/lxc", 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)
|
||||||
|
|
||||||
|
for i := 0; i < len(props.Data); i++ {
|
||||||
|
lxccontainer := props.Data[i]
|
||||||
|
if lxccontainer.VMID == 200 {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true
|
||||||
|
}, 10*time.Second, time.Second, "Create operation should complete successfully")
|
||||||
|
}
|
||||||
|
|||||||
6
types.go
6
types.go
@@ -28,6 +28,12 @@ type UpdateRequest struct {
|
|||||||
TargetConfig json.RawMessage
|
TargetConfig json.RawMessage
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type DeleteRequest struct {
|
||||||
|
NativeID string
|
||||||
|
ResourceType string
|
||||||
|
TargetConfig json.RawMessage
|
||||||
|
}
|
||||||
|
|
||||||
type StatusLXCGeneral struct {
|
type StatusLXCGeneral struct {
|
||||||
Status string `json:"status"`
|
Status string `json:"status"`
|
||||||
NetIn int `json:"netin"`
|
NetIn int `json:"netin"`
|
||||||
|
|||||||
Reference in New Issue
Block a user