-
Notifications
You must be signed in to change notification settings - Fork 204
/
journalindex.go
71 lines (54 loc) · 1.58 KB
/
journalindex.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
package wrapper
import (
"encoding/json"
v2 "github.com/SpectoLabs/hoverfly/core/handlers/v2"
"github.com/SpectoLabs/hoverfly/hoverctl/configuration"
)
func GetAllJournalIndexes(target configuration.Target) ([]v2.JournalIndexView, error) {
response, err := doRequest(target, "GET", v2JournalIndex, "", nil)
if err != nil {
return []v2.JournalIndexView{}, err
}
defer response.Body.Close()
err = handleResponseError(response, "Could not retrieve all journal indexes")
if err != nil {
return []v2.JournalIndexView{}, err
}
var journalIndexes []v2.JournalIndexView
err = UnmarshalToInterface(response, &journalIndexes)
if err != nil {
return []v2.JournalIndexView{}, err
}
return journalIndexes, nil
}
func SetJournalIndex(indexName string, target configuration.Target) error {
journalIndexRequestView := v2.JournalIndexRequestView{
Name: indexName,
}
journalIndexRequestViewData, err := json.Marshal(journalIndexRequestView)
if err != nil {
return err
}
response, err := doRequest(target, "POST", v2JournalIndex, string(journalIndexRequestViewData), nil)
if err != nil {
return err
}
defer response.Body.Close()
err = handleResponseError(response, "Could not set journal index")
if err != nil {
return err
}
return nil
}
func DeleteJournalIndex(indexName string, target configuration.Target) error {
response, err := doRequest(target, "DELETE", v2JournalIndex+"/"+indexName, "", nil)
if err != nil {
return err
}
defer response.Body.Close()
err = handleResponseError(response, "Could not delete journal index")
if err != nil {
return err
}
return nil
}