github.com/stripe/stripe-go/v76@v76.25.0/forwarding/request/client.go (about) 1 // 2 // 3 // File generated from our OpenAPI spec 4 // 5 // 6 7 // Package request provides the /forwarding/requests APIs 8 package request 9 10 import ( 11 "net/http" 12 13 stripe "github.com/stripe/stripe-go/v76" 14 "github.com/stripe/stripe-go/v76/form" 15 ) 16 17 // Client is used to invoke /forwarding/requests APIs. 18 type Client struct { 19 B stripe.Backend 20 Key string 21 } 22 23 // New creates a new forwarding request. 24 func New(params *stripe.ForwardingRequestParams) (*stripe.ForwardingRequest, error) { 25 return getC().New(params) 26 } 27 28 // New creates a new forwarding request. 29 func (c Client) New(params *stripe.ForwardingRequestParams) (*stripe.ForwardingRequest, error) { 30 request := &stripe.ForwardingRequest{} 31 err := c.B.Call( 32 http.MethodPost, 33 "/v1/forwarding/requests", 34 c.Key, 35 params, 36 request, 37 ) 38 return request, err 39 } 40 41 // Get returns the details of a forwarding request. 42 func Get(id string, params *stripe.ForwardingRequestParams) (*stripe.ForwardingRequest, error) { 43 return getC().Get(id, params) 44 } 45 46 // Get returns the details of a forwarding request. 47 func (c Client) Get(id string, params *stripe.ForwardingRequestParams) (*stripe.ForwardingRequest, error) { 48 path := stripe.FormatURLPath("/v1/forwarding/requests/%s", id) 49 request := &stripe.ForwardingRequest{} 50 err := c.B.Call(http.MethodGet, path, c.Key, params, request) 51 return request, err 52 } 53 54 // List returns a list of forwarding requests. 55 func List(params *stripe.ForwardingRequestListParams) *Iter { 56 return getC().List(params) 57 } 58 59 // List returns a list of forwarding requests. 60 func (c Client) List(listParams *stripe.ForwardingRequestListParams) *Iter { 61 return &Iter{ 62 Iter: stripe.GetIter(listParams, func(p *stripe.Params, b *form.Values) ([]interface{}, stripe.ListContainer, error) { 63 list := &stripe.ForwardingRequestList{} 64 err := c.B.CallRaw(http.MethodGet, "/v1/forwarding/requests", c.Key, b, p, list) 65 66 ret := make([]interface{}, len(list.Data)) 67 for i, v := range list.Data { 68 ret[i] = v 69 } 70 71 return ret, list, err 72 }), 73 } 74 } 75 76 // Iter is an iterator for forwarding requests. 77 type Iter struct { 78 *stripe.Iter 79 } 80 81 // ForwardingRequest returns the forwarding request which the iterator is currently pointing to. 82 func (i *Iter) ForwardingRequest() *stripe.ForwardingRequest { 83 return i.Current().(*stripe.ForwardingRequest) 84 } 85 86 // ForwardingRequestList returns the current list object which the iterator is 87 // currently using. List objects will change as new API calls are made to 88 // continue pagination. 89 func (i *Iter) ForwardingRequestList() *stripe.ForwardingRequestList { 90 return i.List().(*stripe.ForwardingRequestList) 91 } 92 93 func getC() Client { 94 return Client{stripe.GetBackend(stripe.APIBackend), stripe.Key} 95 }