-
Notifications
You must be signed in to change notification settings - Fork 12
/
get.go
63 lines (50 loc) · 1.64 KB
/
get.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
package jsc
import (
"fmt"
"net/http"
"net/url"
"github.com/derekdowling/go-json-spec-handler"
)
// Fetch performs an outbound GET /resourceTypes/:id request
func Fetch(baseURL string, resourceType string, id string) (*jsh.Document, *http.Response, error) {
request, err := FetchRequest(baseURL, resourceType, id)
if err != nil {
return nil, nil, err
}
return Do(request, jsh.ObjectMode)
}
/*
FetchRequest returns a fully formatted JSONAPI Fetch request. Useful if you need to
set custom headers before proceeding. Otherwise just use "jsh.Fetch".
*/
func FetchRequest(baseURL string, resourceType, id string) (*http.Request, error) {
if id == "" {
return nil, jsh.SpecificationError("ID cannot be empty for GetObject request type")
}
u, urlErr := url.Parse(baseURL)
if urlErr != nil {
return nil, jsh.ISE(fmt.Sprintf("Error parsing URL: %s", urlErr.Error()))
}
setIDPath(u, resourceType, id)
return NewRequest("GET", u.String(), nil)
}
// List prepares an outbound GET /resourceTypes request
func List(baseURL string, resourceType string) (*jsh.Document, *http.Response, error) {
request, err := ListRequest(baseURL, resourceType)
if err != nil {
return nil, nil, err
}
return Do(request, jsh.ListMode)
}
/*
ListRequest returns a fully formatted JSONAPI List request. Useful if you need to
set custom headers before proceeding. Otherwise just use "jsh.List".
*/
func ListRequest(baseURL string, resourceType string) (*http.Request, error) {
u, urlErr := url.Parse(baseURL)
if urlErr != nil {
return nil, jsh.ISE(fmt.Sprintf("Error parsing URL: %s", urlErr.Error()))
}
setPath(u, resourceType)
return NewRequest("GET", u.String(), nil)
}