bbgo_origin/pkg/datasource/wise/rate_request_requestgen.go

230 lines
4.9 KiB
Go
Raw Permalink Normal View History

2023-11-11 02:16:55 +00:00
// Code generated by "requestgen -method GET -url /v1/rates -type RateRequest -responseType []Rate"; DO NOT EDIT.
package wise
import (
"context"
"encoding/json"
"fmt"
"net/url"
"reflect"
"regexp"
"time"
)
func (r *RateRequest) Source(source string) *RateRequest {
r.source = source
return r
}
func (r *RateRequest) Target(target string) *RateRequest {
r.target = target
return r
}
func (r *RateRequest) Time(time time.Time) *RateRequest {
r.time = &time
return r
}
func (r *RateRequest) From(from time.Time) *RateRequest {
r.from = &from
return r
}
func (r *RateRequest) To(to time.Time) *RateRequest {
r.to = &to
return r
}
func (r *RateRequest) Group(group Group) *RateRequest {
r.group = &group
return r
}
// GetQueryParameters builds and checks the query parameters and returns url.Values
func (r *RateRequest) GetQueryParameters() (url.Values, error) {
var params = map[string]interface{}{}
query := url.Values{}
for _k, _v := range params {
query.Add(_k, fmt.Sprintf("%v", _v))
}
return query, nil
}
// GetParameters builds and checks the parameters and return the result in a map object
func (r *RateRequest) GetParameters() (map[string]interface{}, error) {
var params = map[string]interface{}{}
// check source field -> json key source
source := r.source
// assign parameter of source
params["source"] = source
// check target field -> json key target
target := r.target
// assign parameter of target
params["target"] = target
// check time field -> json key time
if r.time != nil {
time := *r.time
// assign parameter of time
params["time"] = time.Format("2006-01-02T15:04:05-0700")
} else {
}
// check from field -> json key from
if r.from != nil {
from := *r.from
// assign parameter of from
params["from"] = from.Format("2006-01-02T15:04:05-0700")
} else {
}
// check to field -> json key to
if r.to != nil {
to := *r.to
// assign parameter of to
params["to"] = to.Format("2006-01-02T15:04:05-0700")
} else {
}
// check group field -> json key group
if r.group != nil {
group := *r.group
// assign parameter of group
params["group"] = group
} else {
}
return params, nil
}
// GetParametersQuery converts the parameters from GetParameters into the url.Values format
func (r *RateRequest) GetParametersQuery() (url.Values, error) {
query := url.Values{}
params, err := r.GetParameters()
if err != nil {
return query, err
}
for _k, _v := range params {
if r.isVarSlice(_v) {
r.iterateSlice(_v, func(it interface{}) {
query.Add(_k+"[]", fmt.Sprintf("%v", it))
})
} else {
query.Add(_k, fmt.Sprintf("%v", _v))
}
}
return query, nil
}
// GetParametersJSON converts the parameters from GetParameters into the JSON format
func (r *RateRequest) GetParametersJSON() ([]byte, error) {
params, err := r.GetParameters()
if err != nil {
return nil, err
}
return json.Marshal(params)
}
// GetSlugParameters builds and checks the slug parameters and return the result in a map object
func (r *RateRequest) GetSlugParameters() (map[string]interface{}, error) {
var params = map[string]interface{}{}
return params, nil
}
func (r *RateRequest) applySlugsToUrl(url string, slugs map[string]string) string {
for _k, _v := range slugs {
needleRE := regexp.MustCompile(":" + _k + "\\b")
url = needleRE.ReplaceAllString(url, _v)
}
return url
}
func (r *RateRequest) iterateSlice(slice interface{}, _f func(it interface{})) {
sliceValue := reflect.ValueOf(slice)
for _i := 0; _i < sliceValue.Len(); _i++ {
it := sliceValue.Index(_i).Interface()
_f(it)
}
}
func (r *RateRequest) isVarSlice(_v interface{}) bool {
rt := reflect.TypeOf(_v)
switch rt.Kind() {
case reflect.Slice:
return true
}
return false
}
func (r *RateRequest) GetSlugsMap() (map[string]string, error) {
slugs := map[string]string{}
params, err := r.GetSlugParameters()
if err != nil {
return slugs, nil
}
for _k, _v := range params {
slugs[_k] = fmt.Sprintf("%v", _v)
}
return slugs, nil
}
// GetPath returns the request path of the API
func (r *RateRequest) GetPath() string {
return "/v1/rates"
}
// Do generates the request object and send the request object to the API endpoint
func (r *RateRequest) Do(ctx context.Context) ([]Rate, error) {
// empty params for GET operation
var params interface{}
query, err := r.GetParametersQuery()
if err != nil {
return nil, err
}
var apiURL string
apiURL = r.GetPath()
req, err := r.client.NewAuthenticatedRequest(ctx, "GET", apiURL, query, params)
if err != nil {
return nil, err
}
response, err := r.client.SendRequest(req)
if err != nil {
return nil, err
}
var apiResponse []Rate
if err := response.DecodeJSON(&apiResponse); err != nil {
return nil, err
}
type responseValidator interface {
Validate() error
}
validator, ok := interface{}(apiResponse).(responseValidator)
if ok {
if err := validator.Validate(); err != nil {
return nil, err
}
}
return apiResponse, nil
}