github.com/twilio/twilio-go@v1.20.1/rest/verify/v2/services_rate_limits_buckets.go (about) 1 /* 2 * This code was generated by 3 * ___ _ _ _ _ _ _ ____ ____ ____ _ ____ ____ _ _ ____ ____ ____ ___ __ __ 4 * | | | | | | | | | __ | | |__| | __ | __ |___ |\ | |___ |__/ |__| | | | |__/ 5 * | |_|_| | |___ | |__| |__| | | | |__] |___ | \| |___ | \ | | | |__| | \ 6 * 7 * Twilio - Verify 8 * This is the public Twilio REST API. 9 * 10 * NOTE: This class is auto generated by OpenAPI Generator. 11 * https://openapi-generator.tech 12 * Do not edit the class manually. 13 */ 14 15 package openapi 16 17 import ( 18 "encoding/json" 19 "fmt" 20 "net/url" 21 "strings" 22 23 "github.com/twilio/twilio-go/client" 24 ) 25 26 // Optional parameters for the method 'CreateBucket' 27 type CreateBucketParams struct { 28 // Maximum number of requests permitted in during the interval. 29 Max *int `json:"Max,omitempty"` 30 // Number of seconds that the rate limit will be enforced over. 31 Interval *int `json:"Interval,omitempty"` 32 } 33 34 func (params *CreateBucketParams) SetMax(Max int) *CreateBucketParams { 35 params.Max = &Max 36 return params 37 } 38 func (params *CreateBucketParams) SetInterval(Interval int) *CreateBucketParams { 39 params.Interval = &Interval 40 return params 41 } 42 43 // Create a new Bucket for a Rate Limit 44 func (c *ApiService) CreateBucket(ServiceSid string, RateLimitSid string, params *CreateBucketParams) (*VerifyV2Bucket, error) { 45 path := "/v2/Services/{ServiceSid}/RateLimits/{RateLimitSid}/Buckets" 46 path = strings.Replace(path, "{"+"ServiceSid"+"}", ServiceSid, -1) 47 path = strings.Replace(path, "{"+"RateLimitSid"+"}", RateLimitSid, -1) 48 49 data := url.Values{} 50 headers := make(map[string]interface{}) 51 52 if params != nil && params.Max != nil { 53 data.Set("Max", fmt.Sprint(*params.Max)) 54 } 55 if params != nil && params.Interval != nil { 56 data.Set("Interval", fmt.Sprint(*params.Interval)) 57 } 58 59 resp, err := c.requestHandler.Post(c.baseURL+path, data, headers) 60 if err != nil { 61 return nil, err 62 } 63 64 defer resp.Body.Close() 65 66 ps := &VerifyV2Bucket{} 67 if err := json.NewDecoder(resp.Body).Decode(ps); err != nil { 68 return nil, err 69 } 70 71 return ps, err 72 } 73 74 // Delete a specific Bucket. 75 func (c *ApiService) DeleteBucket(ServiceSid string, RateLimitSid string, Sid string) error { 76 path := "/v2/Services/{ServiceSid}/RateLimits/{RateLimitSid}/Buckets/{Sid}" 77 path = strings.Replace(path, "{"+"ServiceSid"+"}", ServiceSid, -1) 78 path = strings.Replace(path, "{"+"RateLimitSid"+"}", RateLimitSid, -1) 79 path = strings.Replace(path, "{"+"Sid"+"}", Sid, -1) 80 81 data := url.Values{} 82 headers := make(map[string]interface{}) 83 84 resp, err := c.requestHandler.Delete(c.baseURL+path, data, headers) 85 if err != nil { 86 return err 87 } 88 89 defer resp.Body.Close() 90 91 return nil 92 } 93 94 // Fetch a specific Bucket. 95 func (c *ApiService) FetchBucket(ServiceSid string, RateLimitSid string, Sid string) (*VerifyV2Bucket, error) { 96 path := "/v2/Services/{ServiceSid}/RateLimits/{RateLimitSid}/Buckets/{Sid}" 97 path = strings.Replace(path, "{"+"ServiceSid"+"}", ServiceSid, -1) 98 path = strings.Replace(path, "{"+"RateLimitSid"+"}", RateLimitSid, -1) 99 path = strings.Replace(path, "{"+"Sid"+"}", Sid, -1) 100 101 data := url.Values{} 102 headers := make(map[string]interface{}) 103 104 resp, err := c.requestHandler.Get(c.baseURL+path, data, headers) 105 if err != nil { 106 return nil, err 107 } 108 109 defer resp.Body.Close() 110 111 ps := &VerifyV2Bucket{} 112 if err := json.NewDecoder(resp.Body).Decode(ps); err != nil { 113 return nil, err 114 } 115 116 return ps, err 117 } 118 119 // Optional parameters for the method 'ListBucket' 120 type ListBucketParams struct { 121 // How many resources to return in each list page. The default is 50, and the maximum is 1000. 122 PageSize *int `json:"PageSize,omitempty"` 123 // Max number of records to return. 124 Limit *int `json:"limit,omitempty"` 125 } 126 127 func (params *ListBucketParams) SetPageSize(PageSize int) *ListBucketParams { 128 params.PageSize = &PageSize 129 return params 130 } 131 func (params *ListBucketParams) SetLimit(Limit int) *ListBucketParams { 132 params.Limit = &Limit 133 return params 134 } 135 136 // Retrieve a single page of Bucket records from the API. Request is executed immediately. 137 func (c *ApiService) PageBucket(ServiceSid string, RateLimitSid string, params *ListBucketParams, pageToken, pageNumber string) (*ListBucketResponse, error) { 138 path := "/v2/Services/{ServiceSid}/RateLimits/{RateLimitSid}/Buckets" 139 140 path = strings.Replace(path, "{"+"ServiceSid"+"}", ServiceSid, -1) 141 path = strings.Replace(path, "{"+"RateLimitSid"+"}", RateLimitSid, -1) 142 143 data := url.Values{} 144 headers := make(map[string]interface{}) 145 146 if params != nil && params.PageSize != nil { 147 data.Set("PageSize", fmt.Sprint(*params.PageSize)) 148 } 149 150 if pageToken != "" { 151 data.Set("PageToken", pageToken) 152 } 153 if pageNumber != "" { 154 data.Set("Page", pageNumber) 155 } 156 157 resp, err := c.requestHandler.Get(c.baseURL+path, data, headers) 158 if err != nil { 159 return nil, err 160 } 161 162 defer resp.Body.Close() 163 164 ps := &ListBucketResponse{} 165 if err := json.NewDecoder(resp.Body).Decode(ps); err != nil { 166 return nil, err 167 } 168 169 return ps, err 170 } 171 172 // Lists Bucket records from the API as a list. Unlike stream, this operation is eager and loads 'limit' records into memory before returning. 173 func (c *ApiService) ListBucket(ServiceSid string, RateLimitSid string, params *ListBucketParams) ([]VerifyV2Bucket, error) { 174 response, errors := c.StreamBucket(ServiceSid, RateLimitSid, params) 175 176 records := make([]VerifyV2Bucket, 0) 177 for record := range response { 178 records = append(records, record) 179 } 180 181 if err := <-errors; err != nil { 182 return nil, err 183 } 184 185 return records, nil 186 } 187 188 // Streams Bucket records from the API as a channel stream. This operation lazily loads records as efficiently as possible until the limit is reached. 189 func (c *ApiService) StreamBucket(ServiceSid string, RateLimitSid string, params *ListBucketParams) (chan VerifyV2Bucket, chan error) { 190 if params == nil { 191 params = &ListBucketParams{} 192 } 193 params.SetPageSize(client.ReadLimits(params.PageSize, params.Limit)) 194 195 recordChannel := make(chan VerifyV2Bucket, 1) 196 errorChannel := make(chan error, 1) 197 198 response, err := c.PageBucket(ServiceSid, RateLimitSid, params, "", "") 199 if err != nil { 200 errorChannel <- err 201 close(recordChannel) 202 close(errorChannel) 203 } else { 204 go c.streamBucket(response, params, recordChannel, errorChannel) 205 } 206 207 return recordChannel, errorChannel 208 } 209 210 func (c *ApiService) streamBucket(response *ListBucketResponse, params *ListBucketParams, recordChannel chan VerifyV2Bucket, errorChannel chan error) { 211 curRecord := 1 212 213 for response != nil { 214 responseRecords := response.Buckets 215 for item := range responseRecords { 216 recordChannel <- responseRecords[item] 217 curRecord += 1 218 if params.Limit != nil && *params.Limit < curRecord { 219 close(recordChannel) 220 close(errorChannel) 221 return 222 } 223 } 224 225 record, err := client.GetNext(c.baseURL, response, c.getNextListBucketResponse) 226 if err != nil { 227 errorChannel <- err 228 break 229 } else if record == nil { 230 break 231 } 232 233 response = record.(*ListBucketResponse) 234 } 235 236 close(recordChannel) 237 close(errorChannel) 238 } 239 240 func (c *ApiService) getNextListBucketResponse(nextPageUrl string) (interface{}, error) { 241 if nextPageUrl == "" { 242 return nil, nil 243 } 244 resp, err := c.requestHandler.Get(nextPageUrl, nil, nil) 245 if err != nil { 246 return nil, err 247 } 248 249 defer resp.Body.Close() 250 251 ps := &ListBucketResponse{} 252 if err := json.NewDecoder(resp.Body).Decode(ps); err != nil { 253 return nil, err 254 } 255 return ps, nil 256 } 257 258 // Optional parameters for the method 'UpdateBucket' 259 type UpdateBucketParams struct { 260 // Maximum number of requests permitted in during the interval. 261 Max *int `json:"Max,omitempty"` 262 // Number of seconds that the rate limit will be enforced over. 263 Interval *int `json:"Interval,omitempty"` 264 } 265 266 func (params *UpdateBucketParams) SetMax(Max int) *UpdateBucketParams { 267 params.Max = &Max 268 return params 269 } 270 func (params *UpdateBucketParams) SetInterval(Interval int) *UpdateBucketParams { 271 params.Interval = &Interval 272 return params 273 } 274 275 // Update a specific Bucket. 276 func (c *ApiService) UpdateBucket(ServiceSid string, RateLimitSid string, Sid string, params *UpdateBucketParams) (*VerifyV2Bucket, error) { 277 path := "/v2/Services/{ServiceSid}/RateLimits/{RateLimitSid}/Buckets/{Sid}" 278 path = strings.Replace(path, "{"+"ServiceSid"+"}", ServiceSid, -1) 279 path = strings.Replace(path, "{"+"RateLimitSid"+"}", RateLimitSid, -1) 280 path = strings.Replace(path, "{"+"Sid"+"}", Sid, -1) 281 282 data := url.Values{} 283 headers := make(map[string]interface{}) 284 285 if params != nil && params.Max != nil { 286 data.Set("Max", fmt.Sprint(*params.Max)) 287 } 288 if params != nil && params.Interval != nil { 289 data.Set("Interval", fmt.Sprint(*params.Interval)) 290 } 291 292 resp, err := c.requestHandler.Post(c.baseURL+path, data, headers) 293 if err != nil { 294 return nil, err 295 } 296 297 defer resp.Body.Close() 298 299 ps := &VerifyV2Bucket{} 300 if err := json.NewDecoder(resp.Body).Decode(ps); err != nil { 301 return nil, err 302 } 303 304 return ps, err 305 }