-
Notifications
You must be signed in to change notification settings - Fork 63
/
files_list_files.go
148 lines (110 loc) · 3.28 KB
/
files_list_files.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
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
package pubnub
import (
"bytes"
"encoding/json"
"fmt"
"io/ioutil"
"net/http"
"net/url"
"strconv"
"github.com/pubnub/go/v7/pnerr"
)
var emptyListFilesResponse *PNListFilesResponse
const listFilesPath = "/v1/files/%s/channels/%s/files"
const listFilesLimit = 100
type listFilesBuilder struct {
opts *listFilesOpts
}
func newListFilesBuilder(pubnub *PubNub) *listFilesBuilder {
return newListFilesBuilderWithContext(pubnub, pubnub.ctx)
}
func newListFilesOpts(pubnub *PubNub, ctx Context) *listFilesOpts {
return &listFilesOpts{
endpointOpts: endpointOpts{pubnub: pubnub, ctx: ctx},
Limit: listFilesLimit,
}
}
func newListFilesBuilderWithContext(pubnub *PubNub,
context Context) *listFilesBuilder {
builder := listFilesBuilder{
opts: newListFilesOpts(pubnub, context)}
return &builder
}
func (b *listFilesBuilder) Limit(limit int) *listFilesBuilder {
b.opts.Limit = limit
return b
}
func (b *listFilesBuilder) Next(next string) *listFilesBuilder {
b.opts.Next = next
return b
}
func (b *listFilesBuilder) Channel(channel string) *listFilesBuilder {
b.opts.Channel = channel
return b
}
// QueryParam accepts a map, the keys and values of the map are passed as the query string parameters of the URL called by the API.
func (b *listFilesBuilder) QueryParam(queryParam map[string]string) *listFilesBuilder {
b.opts.QueryParam = queryParam
return b
}
// Transport sets the Transport for the listFiles request.
func (b *listFilesBuilder) Transport(tr http.RoundTripper) *listFilesBuilder {
b.opts.Transport = tr
return b
}
// Execute runs the listFiles request.
func (b *listFilesBuilder) Execute() (*PNListFilesResponse, StatusResponse, error) {
rawJSON, status, err := executeRequest(b.opts)
if err != nil {
return emptyListFilesResponse, status, err
}
return newPNListFilesResponse(rawJSON, b.opts, status)
}
type listFilesOpts struct {
endpointOpts
Limit int
Next string
Channel string
QueryParam map[string]string
Transport http.RoundTripper
}
func (o *listFilesOpts) validate() error {
if o.config().SubscribeKey == "" {
return newValidationError(o, StrMissingSubKey)
}
return nil
}
func (o *listFilesOpts) buildPath() (string, error) {
return fmt.Sprintf(listFilesPath,
o.pubnub.Config.SubscribeKey, o.Channel), nil
}
func (o *listFilesOpts) buildQuery() (*url.Values, error) {
q := defaultQuery(o.pubnub.Config.UUID, o.pubnub.telemetryManager)
q.Set("limit", strconv.Itoa(o.Limit))
if o.Next != "" {
q.Set("next", o.Next)
}
SetQueryParam(q, o.QueryParam)
return q, nil
}
func (o *listFilesOpts) operationType() OperationType {
return PNListFilesOperation
}
// PNListFilesResponse is the File Upload API Response for Get Spaces
type PNListFilesResponse struct {
status int `json:"status"`
Data []PNFileInfo `json:"data"`
Count int `json:"count"`
Next string `json:"next"`
}
func newPNListFilesResponse(jsonBytes []byte, o *listFilesOpts,
status StatusResponse) (*PNListFilesResponse, StatusResponse, error) {
resp := &PNListFilesResponse{}
err := json.Unmarshal(jsonBytes, &resp)
if err != nil {
e := pnerr.NewResponseParsingError("Error unmarshalling response",
ioutil.NopCloser(bytes.NewBufferString(string(jsonBytes))), err)
return emptyListFilesResponse, status, e
}
return resp, status, nil
}