/
dispatchnamespacescripttag.go
192 lines (164 loc) · 7.57 KB
/
dispatchnamespacescripttag.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
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
package workers_for_platforms
import (
"context"
"fmt"
"net/http"
"github.com/cloudflare/cloudflare-go/v2/internal/apijson"
"github.com/cloudflare/cloudflare-go/v2/internal/pagination"
"github.com/cloudflare/cloudflare-go/v2/internal/param"
"github.com/cloudflare/cloudflare-go/v2/internal/requestconfig"
"github.com/cloudflare/cloudflare-go/v2/option"
"github.com/cloudflare/cloudflare-go/v2/shared"
)
// DispatchNamespaceScriptTagService contains methods and other services that help
// with interacting with the cloudflare API. Note, unlike clients, this service
// does not read variables from the environment automatically. You should not
// instantiate this service directly, and instead use the
// [NewDispatchNamespaceScriptTagService] method instead.
type DispatchNamespaceScriptTagService struct {
Options []option.RequestOption
}
// NewDispatchNamespaceScriptTagService generates a new service that applies the
// given options to each request. These options are applied after the parent
// client's options (if there is one), and before any request-specific options.
func NewDispatchNamespaceScriptTagService(opts ...option.RequestOption) (r *DispatchNamespaceScriptTagService) {
r = &DispatchNamespaceScriptTagService{}
r.Options = opts
return
}
// Put script tags for a script uploaded to a Workers for Platforms namespace.
func (r *DispatchNamespaceScriptTagService) Update(ctx context.Context, dispatchNamespace string, scriptName string, params DispatchNamespaceScriptTagUpdateParams, opts ...option.RequestOption) (res *[]string, err error) {
opts = append(r.Options[:], opts...)
var env DispatchNamespaceScriptTagUpdateResponseEnvelope
path := fmt.Sprintf("accounts/%s/workers/dispatch/namespaces/%s/scripts/%s/tags", params.AccountID, dispatchNamespace, scriptName)
err = requestconfig.ExecuteNewRequest(ctx, http.MethodPut, path, params, &env, opts...)
if err != nil {
return
}
res = &env.Result
return
}
// Fetch tags from a script uploaded to a Workers for Platforms namespace.
func (r *DispatchNamespaceScriptTagService) List(ctx context.Context, dispatchNamespace string, scriptName string, query DispatchNamespaceScriptTagListParams, opts ...option.RequestOption) (res *pagination.SinglePage[string], err error) {
var raw *http.Response
opts = append(r.Options, opts...)
opts = append([]option.RequestOption{option.WithResponseInto(&raw)}, opts...)
path := fmt.Sprintf("accounts/%s/workers/dispatch/namespaces/%s/scripts/%s/tags", query.AccountID, dispatchNamespace, scriptName)
cfg, err := requestconfig.NewRequestConfig(ctx, http.MethodGet, path, nil, &res, opts...)
if err != nil {
return nil, err
}
err = cfg.Execute()
if err != nil {
return nil, err
}
res.SetPageConfig(cfg, raw)
return res, nil
}
// Fetch tags from a script uploaded to a Workers for Platforms namespace.
func (r *DispatchNamespaceScriptTagService) ListAutoPaging(ctx context.Context, dispatchNamespace string, scriptName string, query DispatchNamespaceScriptTagListParams, opts ...option.RequestOption) *pagination.SinglePageAutoPager[string] {
return pagination.NewSinglePageAutoPager(r.List(ctx, dispatchNamespace, scriptName, query, opts...))
}
// Delete script tag for a script uploaded to a Workers for Platforms namespace.
func (r *DispatchNamespaceScriptTagService) Delete(ctx context.Context, dispatchNamespace string, scriptName string, tag string, body DispatchNamespaceScriptTagDeleteParams, opts ...option.RequestOption) (res *DispatchNamespaceScriptTagDeleteResponse, err error) {
opts = append(r.Options[:], opts...)
var env DispatchNamespaceScriptTagDeleteResponseEnvelope
path := fmt.Sprintf("accounts/%s/workers/dispatch/namespaces/%s/scripts/%s/tags/%s", body.AccountID, dispatchNamespace, scriptName, tag)
err = requestconfig.ExecuteNewRequest(ctx, http.MethodDelete, path, nil, &env, opts...)
if err != nil {
return
}
res = &env.Result
return
}
type DispatchNamespaceScriptTagDeleteResponse = interface{}
type DispatchNamespaceScriptTagUpdateParams struct {
// Identifier
AccountID param.Field[string] `path:"account_id,required"`
// Tags to help you manage your Workers
Body []string `json:"body,required"`
}
func (r DispatchNamespaceScriptTagUpdateParams) MarshalJSON() (data []byte, err error) {
return apijson.MarshalRoot(r.Body)
}
type DispatchNamespaceScriptTagUpdateResponseEnvelope struct {
Errors []shared.ResponseInfo `json:"errors,required"`
Messages []shared.ResponseInfo `json:"messages,required"`
// Whether the API call was successful
Success DispatchNamespaceScriptTagUpdateResponseEnvelopeSuccess `json:"success,required"`
Result []string `json:"result"`
JSON dispatchNamespaceScriptTagUpdateResponseEnvelopeJSON `json:"-"`
}
// dispatchNamespaceScriptTagUpdateResponseEnvelopeJSON contains the JSON metadata
// for the struct [DispatchNamespaceScriptTagUpdateResponseEnvelope]
type dispatchNamespaceScriptTagUpdateResponseEnvelopeJSON struct {
Errors apijson.Field
Messages apijson.Field
Success apijson.Field
Result apijson.Field
raw string
ExtraFields map[string]apijson.Field
}
func (r *DispatchNamespaceScriptTagUpdateResponseEnvelope) UnmarshalJSON(data []byte) (err error) {
return apijson.UnmarshalRoot(data, r)
}
func (r dispatchNamespaceScriptTagUpdateResponseEnvelopeJSON) RawJSON() string {
return r.raw
}
// Whether the API call was successful
type DispatchNamespaceScriptTagUpdateResponseEnvelopeSuccess bool
const (
DispatchNamespaceScriptTagUpdateResponseEnvelopeSuccessTrue DispatchNamespaceScriptTagUpdateResponseEnvelopeSuccess = true
)
func (r DispatchNamespaceScriptTagUpdateResponseEnvelopeSuccess) IsKnown() bool {
switch r {
case DispatchNamespaceScriptTagUpdateResponseEnvelopeSuccessTrue:
return true
}
return false
}
type DispatchNamespaceScriptTagListParams struct {
// Identifier
AccountID param.Field[string] `path:"account_id,required"`
}
type DispatchNamespaceScriptTagDeleteParams struct {
// Identifier
AccountID param.Field[string] `path:"account_id,required"`
}
type DispatchNamespaceScriptTagDeleteResponseEnvelope struct {
Errors []shared.ResponseInfo `json:"errors,required"`
Messages []shared.ResponseInfo `json:"messages,required"`
// Whether the API call was successful
Success DispatchNamespaceScriptTagDeleteResponseEnvelopeSuccess `json:"success,required"`
Result DispatchNamespaceScriptTagDeleteResponse `json:"result,nullable"`
JSON dispatchNamespaceScriptTagDeleteResponseEnvelopeJSON `json:"-"`
}
// dispatchNamespaceScriptTagDeleteResponseEnvelopeJSON contains the JSON metadata
// for the struct [DispatchNamespaceScriptTagDeleteResponseEnvelope]
type dispatchNamespaceScriptTagDeleteResponseEnvelopeJSON struct {
Errors apijson.Field
Messages apijson.Field
Success apijson.Field
Result apijson.Field
raw string
ExtraFields map[string]apijson.Field
}
func (r *DispatchNamespaceScriptTagDeleteResponseEnvelope) UnmarshalJSON(data []byte) (err error) {
return apijson.UnmarshalRoot(data, r)
}
func (r dispatchNamespaceScriptTagDeleteResponseEnvelopeJSON) RawJSON() string {
return r.raw
}
// Whether the API call was successful
type DispatchNamespaceScriptTagDeleteResponseEnvelopeSuccess bool
const (
DispatchNamespaceScriptTagDeleteResponseEnvelopeSuccessTrue DispatchNamespaceScriptTagDeleteResponseEnvelopeSuccess = true
)
func (r DispatchNamespaceScriptTagDeleteResponseEnvelopeSuccess) IsKnown() bool {
switch r {
case DispatchNamespaceScriptTagDeleteResponseEnvelopeSuccessTrue:
return true
}
return false
}