-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpexecstatus.go
93 lines (82 loc) · 3.38 KB
/
pexecstatus.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
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
package nvidiacloudfunctions
import (
"context"
"errors"
"fmt"
"net/http"
"github.com/brevdev/nvcf-go/internal/apijson"
"github.com/brevdev/nvcf-go/internal/param"
"github.com/brevdev/nvcf-go/internal/requestconfig"
"github.com/brevdev/nvcf-go/option"
)
// PexecStatusService contains methods and other services that help with
// interacting with the nvidia-cloud-functions 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 [NewPexecStatusService] method instead.
type PexecStatusService struct {
Options []option.RequestOption
}
// NewPexecStatusService 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 NewPexecStatusService(opts ...option.RequestOption) (r *PexecStatusService) {
r = &PexecStatusService{}
r.Options = opts
return
}
// Retrieves the status of an in-progress or pending request using its unique
// invocation request ID. If the result is available, it will be included in the
// response, marking the request as fulfilled. Conversely, if the result is not yet
// available, the request is deemed pending. Access to this endpoint mandates
// inclusion of either a bearer token or an api-key with 'invoke_function' scope in
// the HTTP Authorization header. In-progress responses are returned in order. If
// no in-progress response is received during polling you will receive the most
// recent in-progress response. Only the first 256 unread in-progress messages are
// kept.
func (r *PexecStatusService) Get(ctx context.Context, requestID string, query PexecStatusGetParams, opts ...option.RequestOption) (res *PexecStatusGetResponse, err error) {
opts = append(r.Options[:], opts...)
if requestID == "" {
err = errors.New("missing required requestId parameter")
return
}
path := fmt.Sprintf("v2/nvcf/pexec/status/%s", requestID)
err = requestconfig.ExecuteNewRequest(ctx, http.MethodGet, path, nil, &res, opts...)
return
}
type PexecStatusGetResponse struct {
Char string `json:"char"`
Direct bool `json:"direct"`
Double float64 `json:"double"`
Float float64 `json:"float"`
Int int64 `json:"int"`
Long int64 `json:"long"`
ReadOnly bool `json:"readOnly"`
Short int64 `json:"short"`
JSON pexecStatusGetResponseJSON `json:"-"`
}
// pexecStatusGetResponseJSON contains the JSON metadata for the struct
// [PexecStatusGetResponse]
type pexecStatusGetResponseJSON struct {
Char apijson.Field
Direct apijson.Field
Double apijson.Field
Float apijson.Field
Int apijson.Field
Long apijson.Field
ReadOnly apijson.Field
Short apijson.Field
raw string
ExtraFields map[string]apijson.Field
}
func (r *PexecStatusGetResponse) UnmarshalJSON(data []byte) (err error) {
return apijson.UnmarshalRoot(data, r)
}
func (r pexecStatusGetResponseJSON) RawJSON() string {
return r.raw
}
type PexecStatusGetParams struct {
NvcfPollSeconds param.Field[int64] `header:"NVCF-POLL-SECONDS"`
}