-
Notifications
You must be signed in to change notification settings - Fork 0
/
envelopefunctioninvocationfunction.go
103 lines (91 loc) · 4.75 KB
/
envelopefunctioninvocationfunction.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
// 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"
"github.com/brevdev/nvcf-go/shared"
)
// EnvelopeFunctionInvocationFunctionService 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 [NewEnvelopeFunctionInvocationFunctionService] method instead.
type EnvelopeFunctionInvocationFunctionService struct {
Options []option.RequestOption
Versions *EnvelopeFunctionInvocationFunctionVersionService
}
// NewEnvelopeFunctionInvocationFunctionService 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 NewEnvelopeFunctionInvocationFunctionService(opts ...option.RequestOption) (r *EnvelopeFunctionInvocationFunctionService) {
r = &EnvelopeFunctionInvocationFunctionService{}
r.Options = opts
r.Versions = NewEnvelopeFunctionInvocationFunctionVersionService(opts...)
return
}
// Invokes the specified function that was successfully deployed. If the version is
// not specified, any active function versions will handle the request. If the
// version is specified in the URI, then the request is exclusively processed by
// the designated version of the function. By default, this endpoint will block for
// 5 seconds. If the request is not fulfilled before the timeout, it's status is
// considered in-progress or pending and the response includes HTTP status code 202
// with an invocation request ID, indicating that the client should commence
// polling for the result using the invocation request ID. Access to this endpoint
// mandates inclusion of either a bearer token or an api-key with 'invoke_function'
// scope in the HTTP Authorization header. Additionally, this endpoint has the
// capability to provide updates on the progress of the request, contingent upon
// the workload's provision of such information. 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 *EnvelopeFunctionInvocationFunctionService) Invoke(ctx context.Context, functionID string, body EnvelopeFunctionInvocationFunctionInvokeParams, opts ...option.RequestOption) (res *shared.InvokeFunctionResponse, err error) {
opts = append(r.Options[:], opts...)
if functionID == "" {
err = errors.New("missing required functionId parameter")
return
}
path := fmt.Sprintf("v2/nvcf/exec/functions/%s", functionID)
err = requestconfig.ExecuteNewRequest(ctx, http.MethodPost, path, body, &res, opts...)
return
}
type EnvelopeFunctionInvocationFunctionInvokeParams struct {
RequestBody param.Field[interface{}] `json:"requestBody,required"`
// Data Transfer Object(DTO) representing header/address for Cloud Functions
// processing.
RequestHeader param.Field[EnvelopeFunctionInvocationFunctionInvokeParamsRequestHeader] `json:"requestHeader"`
}
func (r EnvelopeFunctionInvocationFunctionInvokeParams) MarshalJSON() (data []byte, err error) {
return apijson.MarshalRoot(r)
}
// Data Transfer Object(DTO) representing header/address for Cloud Functions
// processing.
type EnvelopeFunctionInvocationFunctionInvokeParamsRequestHeader struct {
// List of UUIDs corresponding to the uploaded assets to be used as input for
// executing the task.
InputAssetReferences param.Field[[]string] `json:"inputAssetReferences" format:"uuid"`
// Metadata used for billing/metering purposes.
MeteringData param.Field[[]EnvelopeFunctionInvocationFunctionInvokeParamsRequestHeaderMeteringData] `json:"meteringData"`
// Polling timeout duration.
PollDurationSeconds param.Field[int64] `json:"pollDurationSeconds"`
}
func (r EnvelopeFunctionInvocationFunctionInvokeParamsRequestHeader) MarshalJSON() (data []byte, err error) {
return apijson.MarshalRoot(r)
}
// Data Transfer Object(DTO) representing a billing/metering data entry
type EnvelopeFunctionInvocationFunctionInvokeParamsRequestHeaderMeteringData struct {
// Metering/Billing key
Key param.Field[string] `json:"key,required"`
// Metering/Billing value
Value param.Field[string] `json:"value,required"`
}
func (r EnvelopeFunctionInvocationFunctionInvokeParamsRequestHeaderMeteringData) MarshalJSON() (data []byte, err error) {
return apijson.MarshalRoot(r)
}