-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathindices_candles.go
292 lines (270 loc) · 12.9 KB
/
indices_candles.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
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
// Package client includes types and methods to access the Index Candles endpoint. Get historical price candles for any supported stock index.
//
// # Making Requests
//
// Use [IndicesCandlesRequest] to make requests to the endpoint using any of the three supported execution methods:
//
// | Method | Execution | Return Type | Description |
// |------------|---------------|-----------------------------|------------------------------------------------------------------------------------------------------------|
// | **Get** | Direct | `[]Candle` | Directly returns a slice of `[]Candle`, making it straightforward to access each candle individually. |
// | **Packed** | Intermediate | `*IndicesCandlesResponse` | Returns a packed `*IndicesCandlesResponse` object. Must be unpacked to access the `[]Candle` slice. |
// | **Raw** | Low-level | `*resty.Response` | Provides the raw `*resty.Response` for maximum flexibility. Direct access to raw JSON or `*http.Response`. |
package client
import (
"context"
"fmt"
"github.com/MarketDataApp/sdk-go/helpers/parameters"
"github.com/MarketDataApp/sdk-go/models"
"github.com/go-resty/resty/v2"
)
// IndicesCandlesRequest represents a request to the [/v1/indices/candles/] endpoint.
// It encapsulates parameters for resolution, symbol, and dates to be used in the request.
//
// # Generated By
//
// - IndexCandles() *IndicesCandlesRequest: IndexCandles creates a new *IndicesCandlesRequest and returns a pointer to the request allowing for method chaining.
//
// # Setter Methods
//
// These methods are used to set the parameters of the request. They allow for method chaining
// by returning a pointer to the *IndicesCandlesRequest instance they modify.
//
// - Resolution(string) *IndicesCandlesRequest: Sets the resolution parameter for the request.
// - Symbol(string) *IndicesCandlesRequest: Sets the symbol parameter for the request.
// - Date(interface{}) *IndicesCandlesRequest: Sets the date parameter for the request.
// - From(interface{}) *IndicesCandlesRequest: Sets the 'from' date parameter for the request.
//
// # Execution Methods
//
// These methods are used to send the request in different formats or retrieve the data.
// They handle the actual communication with the API endpoint.
//
// - Get) ([]Candle, error): Sends the request, unpacks the response, and returns the data in a user-friendly format.
// - Packed) (*IndicesCandlesResponse, error): Returns a struct that contains equal-length slices of primitives. This packed response mirrors Market Data's JSON response.
// - Raw) (*resty.Response, error): Sends the request as is and returns the raw HTTP response.
//
// [/v1/indices/candles/]: https://www.marketdata.app/docs/api/indices/candles
type IndicesCandlesRequest struct {
*baseRequest
resolutionParams *parameters.ResolutionParams // Holds the resolution parameter of the request.
symbolParams *parameters.SymbolParams // Holds the symbol parameter of the request.
dateParams *parameters.DateParams // Holds the date parameters of the request.
}
// Resolution sets the resolution parameter for the [IndicesCandlesRequest].
// This method is used to specify the granularity of the candle data to be retrieved.
// It modifies the resolutionParams field of the IndicesCandlesRequest instance to store the resolution value.
//
// # Parameters
//
// - string: A string representing the resolution to be set. Valid resolutions may include values like "D", "5", "1h", etc. See the API's supported resolutions.
//
// # Returns
//
// - *IndicesCandlesRequest: This method returns a pointer to the *IndicesCandlesRequest instance it was called on. This allows for method chaining, where multiple setter methods can be called in a single statement. If the receiver (*IndicesCandlesRequest) is nil, it returns nil to prevent a panic.
//
// # Notes
//
// - If an error occurs while setting the resolution (e.g., if the resolution value is not supported), the Error field of the *IndicesCandlesRequest is set with the encountered error, but the method still returns the IndicesCandlesRequest instance to allow for further method calls by the caller.
func (icr *IndicesCandlesRequest) Resolution(q string) *IndicesCandlesRequest {
if icr == nil {
return nil
}
err := icr.resolutionParams.SetResolution(q)
if err != nil {
icr.Error = err
}
return icr
}
// Symbol sets the symbol parameter for the [IndicesCandlesRequest].
// This method is used to specify the index symbol for which the candle data is requested.
//
// # Parameters
//
// - string: A string representing the index symbol to be set.
//
// # Returns
//
// - *IndicesCandlesRequest: This method returns a pointer to the *IndicesCandlesRequest instance it was called on. This allows for method chaining, where multiple setter methods can be called in a single statement. If the receiver (*IndicesCandlesRequest) is nil, it returns nil to prevent a panic.
//
// # Notes
//
// - If an error occurs while setting the symbol (e.g., if the symbol value is not supported), the Error field of the IndicesCandlesRequest is set with the encountered error, but the method still returns the IndicesCandlesRequest instance to allow for further method calls or error handling by the caller.
func (icr *IndicesCandlesRequest) Symbol(q string) *IndicesCandlesRequest {
if icr == nil {
return nil
}
err := icr.symbolParams.SetSymbol(q)
if err != nil {
icr.Error = err
}
return icr
}
// Date sets the date parameter for the IndicesCandlesRequest.
// This method is used to specify the date for which the candle data is requested.
// It modifies the 'date' field of the IndicesCandlesRequest instance to store the date value.
//
// # Parameters
//
// - interface{}: An interface{} representing the date to be set. It can be a string, a time.Time object, a Unix int, or any other type that the underlying dates package method can process.
//
// # Returns
//
// - *IndicesCandlesRequest: This method returns a pointer to the *IndicesCandlesRequest instance it was called on. This allows for method chaining, where multiple setter methods can be called in a single statement.
//
// # Notes
//
// - If an error occurs while setting the date (e.g., if the date value is not supported), the Error field of the request is set with the encountered error, but the method still returns the *IndicesCandlesRequest instance to allow for further method calls.
func (icr *IndicesCandlesRequest) Date(q interface{}) *IndicesCandlesRequest {
err := icr.dateParams.SetDate(q)
if err != nil {
icr.baseRequest.Error = err
}
return icr
}
// From sets the 'from' date parameter for the IndicesCandlesRequest. It configures the starting point of the date range for which the candle data is requested.
//
// # Parameters
//
// - interface{}: An interface{} that represents the starting date. It can be a string, a time.Time object, a Unix timestamp or any other type that the underlying dates package can process.
//
// # Returns
//
// - *IndicesCandlesRequest: A pointer to the *IndicesCandlesRequest instance to allow for method chaining.
func (icr *IndicesCandlesRequest) From(q interface{}) *IndicesCandlesRequest {
err := icr.dateParams.SetFrom(q)
if err != nil {
icr.baseRequest.Error = err
}
return icr
}
// To sets the 'to' date parameter for the IndicesCandlesRequest. It configures the ending point of the date range for which the candle data is requested.
//
// # Parameters
//
// - interface{}: An interface{} that represents the ending date. It can be a string, a time.Time object, or any other type that the underlying SetTo method can process.
//
// # Returns
//
// - *IndicesCandlesRequest: A pointer to the *IndicesCandlesRequest instance to allow for method chaining.
func (icr *IndicesCandlesRequest) To(q interface{}) *IndicesCandlesRequest {
err := icr.dateParams.SetTo(q)
if err != nil {
icr.baseRequest.Error = err
}
return icr
}
// Countback sets the countback parameter for the IndicesCandlesRequest. It specifies the number of candles to return, counting backwards from the 'to' date.
//
// # Parameters
//
// - int: An int representing the number of candles to return.
//
// # Returns
//
// - *IndicesCandlesRequest: A pointer to the *IndicesCandlesRequest instance to allow for method chaining.
func (icr *IndicesCandlesRequest) Countback(q int) *IndicesCandlesRequest {
err := icr.dateParams.SetCountback(q)
if err != nil {
icr.baseRequest.Error = err
}
return icr
}
// getParams packs the IndicesCandlesRequest struct into a slice of interface{} and returns it.
// This method is used to gather all the parameters set in the IndicesCandlesRequest into a single slice
// for easier manipulation and usage in subsequent requests.
//
// # Returns
//
// - []parameters.MarketDataParam: A slice containing all the parameters set in the IndicesCandlesRequest.
// - error: An error object indicating failure to pack the parameters, nil if successful.
func (icr *IndicesCandlesRequest) getParams() ([]parameters.MarketDataParam, error) {
if icr == nil {
return nil, fmt.Errorf("IndicesCandlesRequest is nil")
}
params := []parameters.MarketDataParam{icr.dateParams, icr.symbolParams, icr.resolutionParams}
return params, nil
}
// Raw executes the IndicesCandlesRequest with the provided context and returns the raw *resty.Response.
// The *resty.Response can be directly used to access the raw JSON or *http.Response for further processing.
//
// # Parameters
//
// - ctx context.Context: The context to use for the request execution.
//
// # Returns
//
// - *resty.Response: The raw HTTP response from the executed IndicesCandlesRequest.
// - error: An error object if the IndicesCandlesRequest is nil or if an error occurs during the request execution.
func (icr *IndicesCandlesRequest) Raw(ctx context.Context) (*resty.Response, error) {
return icr.baseRequest.Raw(ctx)
}
// Packed sends the IndicesCandlesRequest with the provided context and returns the IndicesCandlesResponse.
// This method checks if the IndicesCandlesRequest receiver is nil, returning an error if true.
// It proceeds to send the request and returns the IndicesCandlesResponse along with any error encountered during the request.
//
// # Parameters
//
// - ctx context.Context: The context to use for the request execution.
//
// # Returns
//
// - *models.IndicesCandlesResponse: A pointer to the *IndicesCandlesResponse obtained from the request.
// - error: An error object that indicates a failure in sending the request.
func (icr *IndicesCandlesRequest) Packed(ctx context.Context) (*models.IndicesCandlesResponse, error) {
if icr == nil {
return nil, fmt.Errorf("IndicesCandlesRequest is nil")
}
var icrResp models.IndicesCandlesResponse
_, err := icr.baseRequest.client.getFromRequest(ctx, icr.baseRequest, &icrResp)
if err != nil {
return nil, err
}
return &icrResp, nil
}
// Get sends the IndicesCandlesRequest with the provided context, unpacks the IndicesCandlesResponse, and returns a slice of IndexCandle.
// It returns an error if the request or unpacking fails. This method is crucial for obtaining the actual candle data
// from the indices candles request. The method first checks if the IndicesCandlesRequest receiver is nil, which would
// result in an error as the request cannot be sent. It then proceeds to send the request using the Packed method.
// Upon receiving the response, it unpacks the data into a slice of IndexCandle using the Unpack method from the response.
//
// # Parameters
//
// - ctx context.Context: The context to use for the request execution.
//
// # Returns
//
// - []models.Candle: A slice of []models.Candle containing the unpacked candle data from the response.
// - error: An error object that indicates a failure in sending the request or unpacking the response.
func (icr *IndicesCandlesRequest) Get(ctx context.Context) ([]models.Candle, error) {
if icr == nil {
return nil, fmt.Errorf("IndicesCandlesRequest is nil")
}
icrResp, err := icr.Packed(ctx)
if err != nil {
return nil, err
}
data, err := icrResp.Unpack()
if err != nil {
return nil, err
}
return data, nil
}
// IndexCandles creates a new IndicesCandlesRequest and associates it with the default client.
// This function initializes the request with default parameters for date, resolution, and symbol, and sets the request path based on
// the predefined endpoints for indices candles.
//
// # Returns
//
// - *IndicesCandlesRequest: A pointer to the newly created *IndicesCandlesRequest with default parameters and associated client.
func IndexCandles() *IndicesCandlesRequest {
baseReq := newBaseRequest()
baseReq.path = endpoints[1]["indices"]["candles"]
icr := &IndicesCandlesRequest{
baseRequest: baseReq,
dateParams: ¶meters.DateParams{},
resolutionParams: ¶meters.ResolutionParams{},
symbolParams: ¶meters.SymbolParams{},
}
baseReq.child = icr
return icr
}