-
Notifications
You must be signed in to change notification settings - Fork 5
/
classicapi_allowed_file_extensions.go
132 lines (101 loc) · 4.07 KB
/
classicapi_allowed_file_extensions.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
// classicapi_allowed_file_extensions.go
// Jamf Pro Classic Api - Allowed File Extensions
// api reference: https://developer.jamf.com/jamf-pro/reference/allowedfileextensions
// Classic API requires the structs to support an XML data structure.
package jamfpro
import (
"encoding/xml"
"fmt"
)
const uriAPIAllowedFileExtensions = "/JSSResource/allowedfileextensions"
// List
// Response structure for the list of allowed file extensions
type ResponseAllowedFileExtensionsList struct {
Size int `xml:"size"`
AllowedFileExtensions []ResourceAllowedFileExtension `xml:"allowed_file_extension"`
}
// Resource
type ResourceAllowedFileExtension struct {
ID int `xml:"id"`
Extension string `xml:"extension"`
}
// CRUD
// GetAllowedFileExtensions retrieves all allowed file extensions
func (c *Client) GetAllowedFileExtensions() (*ResponseAllowedFileExtensionsList, error) {
endpoint := uriAPIAllowedFileExtensions
var allowedExtensionsList ResponseAllowedFileExtensionsList
resp, err := c.HTTP.DoRequest("GET", endpoint, nil, &allowedExtensionsList)
if err != nil {
return nil, fmt.Errorf(errMsgFailedGet, "allowed file extension", err)
}
if resp != nil && resp.Body != nil {
defer resp.Body.Close()
}
return &allowedExtensionsList, nil
}
// GetAllowedFileExtensionByID retrieves the allowed file extension by its ID
func (c *Client) GetAllowedFileExtensionByID(id int) (*ResourceAllowedFileExtension, error) {
endpoint := fmt.Sprintf("%s/id/%d", uriAPIAllowedFileExtensions, id)
var extension ResourceAllowedFileExtension
resp, err := c.HTTP.DoRequest("GET", endpoint, nil, &extension)
if err != nil {
return nil, fmt.Errorf(errMsgFailedGetByID, "allowed file extension", id, err)
}
if resp != nil && resp.Body != nil {
defer resp.Body.Close()
}
return &extension, nil
}
// GetAllowedFileExtensionByName retrieves the allowed file extension by its name
func (c *Client) GetAllowedFileExtensionByName(name string) (*ResourceAllowedFileExtension, error) {
endpoint := fmt.Sprintf("%s/extension/%s", uriAPIAllowedFileExtensions, name)
var extension ResourceAllowedFileExtension
resp, err := c.HTTP.DoRequest("GET", endpoint, nil, &extension)
if err != nil {
return nil, fmt.Errorf(errMsgFailedGetByName, "allowed file extension", name, err)
}
if resp != nil && resp.Body != nil {
defer resp.Body.Close()
}
return &extension, nil
}
// CreateAllowedFileExtension creates a new allowed file extension on the Jamf Pro server.
func (c *Client) CreateAllowedFileExtension(extension *ResourceAllowedFileExtension) (*ResourceAllowedFileExtension, error) {
endpoint := fmt.Sprintf("%s/id/0", uriAPIAllowedFileExtensions)
// Wrap the extension with the desired XML name using an anonymous struct
requestBody := struct {
XMLName xml.Name `xml:"allowed_file_extension"`
*ResourceAllowedFileExtension
}{
ResourceAllowedFileExtension: extension,
}
var responseExtension ResourceAllowedFileExtension
resp, err := c.HTTP.DoRequest("POST", endpoint, &requestBody, &responseExtension)
if err != nil {
return nil, fmt.Errorf(errMsgFailedCreate, "allowed file extension", err)
}
if resp != nil && resp.Body != nil {
defer resp.Body.Close()
}
return &responseExtension, nil
}
// DeleteAllowedFileExtensionByID deletes an existing allowed file extension by ID
func (c *Client) DeleteAllowedFileExtensionByID(id int) error {
endpoint := fmt.Sprintf("%s/id/%d", uriAPIAllowedFileExtensions, id)
resp, err := c.HTTP.DoRequest("DELETE", endpoint, nil, nil)
if err != nil {
return fmt.Errorf(errMsgFailedDeleteByID, "allowed file extension", id, err)
}
if resp != nil && resp.Body != nil {
defer resp.Body.Close()
}
return nil
}
// DeleteAllowedFileExtensionByNameByID deletes an existing allowed file extension by resolving its name to an ID
func (c *Client) DeleteAllowedFileExtensionByName(name string) error {
extensionDetail, err := c.GetAllowedFileExtensionByName(name)
if err != nil {
return fmt.Errorf(errMsgFailedDeleteByName, "allowed file extension", name, err)
}
return c.DeleteAllowedFileExtensionByID(extensionDetail.ID)
}