forked from go-swagger/go-swagger
-
Notifications
You must be signed in to change notification settings - Fork 0
/
list_tasks_urlbuilder.go
150 lines (122 loc) · 3.2 KB
/
list_tasks_urlbuilder.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
// Code generated by go-swagger; DO NOT EDIT.
package tasks
// This file was generated by the swagger tool.
// Editing this file might prove futile when you re-run the generate command
import (
"errors"
"net/url"
golangswaggerpaths "path"
"github.com/go-openapi/swag"
)
// ListTasksURL generates an URL for the list tasks operation
type ListTasksURL struct {
PageSize *int32
SinceID *int64
Status []string
Tags []string
_basePath string
// avoid unkeyed usage
_ struct{}
}
// WithBasePath sets the base path for this url builder, only required when it's different from the
// base path specified in the swagger spec.
// When the value of the base path is an empty string
func (o *ListTasksURL) WithBasePath(bp string) *ListTasksURL {
o.SetBasePath(bp)
return o
}
// SetBasePath sets the base path for this url builder, only required when it's different from the
// base path specified in the swagger spec.
// When the value of the base path is an empty string
func (o *ListTasksURL) SetBasePath(bp string) {
o._basePath = bp
}
// Build a url path and query string
func (o *ListTasksURL) Build() (*url.URL, error) {
var _result url.URL
var _path = "/tasks"
_basePath := o._basePath
if _basePath == "" {
_basePath = "/api"
}
_result.Path = golangswaggerpaths.Join(_basePath, _path)
qs := make(url.Values)
var pageSize string
if o.PageSize != nil {
pageSize = swag.FormatInt32(*o.PageSize)
}
if pageSize != "" {
qs.Set("pageSize", pageSize)
}
var sinceID string
if o.SinceID != nil {
sinceID = swag.FormatInt64(*o.SinceID)
}
if sinceID != "" {
qs.Set("sinceId", sinceID)
}
var statusIR []string
for _, statusI := range o.Status {
statusIS := statusI
if statusIS != "" {
statusIR = append(statusIR, statusIS)
}
}
status := swag.JoinByFormat(statusIR, "pipes")
if len(status) > 0 {
qsv := status[0]
if qsv != "" {
qs.Set("status", qsv)
}
}
var tagsIR []string
for _, tagsI := range o.Tags {
tagsIS := tagsI
if tagsIS != "" {
tagsIR = append(tagsIR, tagsIS)
}
}
tags := swag.JoinByFormat(tagsIR, "")
if len(tags) > 0 {
qsv := tags[0]
if qsv != "" {
qs.Set("tags", qsv)
}
}
_result.RawQuery = qs.Encode()
return &_result, nil
}
// Must is a helper function to panic when the url builder returns an error
func (o *ListTasksURL) Must(u *url.URL, err error) *url.URL {
if err != nil {
panic(err)
}
if u == nil {
panic("url can't be nil")
}
return u
}
// String returns the string representation of the path with query string
func (o *ListTasksURL) String() string {
return o.Must(o.Build()).String()
}
// BuildFull builds a full url with scheme, host, path and query string
func (o *ListTasksURL) BuildFull(scheme, host string) (*url.URL, error) {
if scheme == "" {
return nil, errors.New("scheme is required for a full url on ListTasksURL")
}
if host == "" {
return nil, errors.New("host is required for a full url on ListTasksURL")
}
base, err := o.Build()
if err != nil {
return nil, err
}
base.Scheme = scheme
base.Host = host
return base, nil
}
// StringFull returns the string representation of a complete url
func (o *ListTasksURL) StringFull(scheme, host string) string {
return o.Must(o.BuildFull(scheme, host)).String()
}