-
Notifications
You must be signed in to change notification settings - Fork 542
/
v1blob.go
45 lines (38 loc) · 1.72 KB
/
v1blob.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
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
package images
import (
"context"
"fmt"
"net/http"
"github.com/cloudflare/cloudflare-go/v2/internal/param"
"github.com/cloudflare/cloudflare-go/v2/internal/requestconfig"
"github.com/cloudflare/cloudflare-go/v2/option"
)
// V1BlobService 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 [NewV1BlobService] method instead.
type V1BlobService struct {
Options []option.RequestOption
}
// NewV1BlobService 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 NewV1BlobService(opts ...option.RequestOption) (r *V1BlobService) {
r = &V1BlobService{}
r.Options = opts
return
}
// Fetch base image. For most images this will be the originally uploaded file. For
// larger images it can be a near-lossless version of the original.
func (r *V1BlobService) Get(ctx context.Context, imageID string, query V1BlobGetParams, opts ...option.RequestOption) (res *http.Response, err error) {
opts = append(r.Options[:], opts...)
opts = append([]option.RequestOption{option.WithHeader("Accept", "image/*")}, opts...)
path := fmt.Sprintf("accounts/%s/images/v1/%s/blob", query.AccountID, imageID)
err = requestconfig.ExecuteNewRequest(ctx, http.MethodGet, path, nil, &res, opts...)
return
}
type V1BlobGetParams struct {
// Account identifier tag.
AccountID param.Field[string] `path:"account_id,required"`
}