vern-sdk 0.0.1.pre.alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.ignore +2 -0
- data/CHANGELOG.md +10 -0
- data/README.md +205 -0
- data/SECURITY.md +23 -0
- data/lib/vern_sdk/client.rb +72 -0
- data/lib/vern_sdk/errors.rb +192 -0
- data/lib/vern_sdk/file_part.rb +55 -0
- data/lib/vern_sdk/internal/transport/base_client.rb +555 -0
- data/lib/vern_sdk/internal/transport/pooled_net_requester.rb +209 -0
- data/lib/vern_sdk/internal/type/array_of.rb +162 -0
- data/lib/vern_sdk/internal/type/base_model.rb +484 -0
- data/lib/vern_sdk/internal/type/base_page.rb +55 -0
- data/lib/vern_sdk/internal/type/boolean.rb +71 -0
- data/lib/vern_sdk/internal/type/converter.rb +292 -0
- data/lib/vern_sdk/internal/type/enum.rb +120 -0
- data/lib/vern_sdk/internal/type/file_input.rb +103 -0
- data/lib/vern_sdk/internal/type/hash_of.rb +182 -0
- data/lib/vern_sdk/internal/type/request_parameters.rb +42 -0
- data/lib/vern_sdk/internal/type/union.rb +227 -0
- data/lib/vern_sdk/internal/type/unknown.rb +75 -0
- data/lib/vern_sdk/internal/util.rb +915 -0
- data/lib/vern_sdk/internal.rb +20 -0
- data/lib/vern_sdk/models/run_create_params.rb +46 -0
- data/lib/vern_sdk/models/run_create_response.rb +33 -0
- data/lib/vern_sdk/models/run_retrieve_params.rb +14 -0
- data/lib/vern_sdk/models/run_retrieve_response.rb +88 -0
- data/lib/vern_sdk/models.rb +45 -0
- data/lib/vern_sdk/request_options.rb +77 -0
- data/lib/vern_sdk/resources/runs.rb +62 -0
- data/lib/vern_sdk/version.rb +5 -0
- data/lib/vern_sdk.rb +58 -0
- data/manifest.yaml +15 -0
- data/rbi/vern_sdk/client.rbi +49 -0
- data/rbi/vern_sdk/errors.rbi +162 -0
- data/rbi/vern_sdk/file_part.rbi +37 -0
- data/rbi/vern_sdk/internal/transport/base_client.rbi +293 -0
- data/rbi/vern_sdk/internal/transport/pooled_net_requester.rbi +79 -0
- data/rbi/vern_sdk/internal/type/array_of.rbi +104 -0
- data/rbi/vern_sdk/internal/type/base_model.rbi +302 -0
- data/rbi/vern_sdk/internal/type/base_page.rbi +42 -0
- data/rbi/vern_sdk/internal/type/boolean.rbi +56 -0
- data/rbi/vern_sdk/internal/type/converter.rbi +162 -0
- data/rbi/vern_sdk/internal/type/enum.rbi +82 -0
- data/rbi/vern_sdk/internal/type/file_input.rbi +59 -0
- data/rbi/vern_sdk/internal/type/hash_of.rbi +104 -0
- data/rbi/vern_sdk/internal/type/request_parameters.rbi +29 -0
- data/rbi/vern_sdk/internal/type/union.rbi +116 -0
- data/rbi/vern_sdk/internal/type/unknown.rbi +56 -0
- data/rbi/vern_sdk/internal/util.rbi +482 -0
- data/rbi/vern_sdk/internal.rbi +16 -0
- data/rbi/vern_sdk/models/run_create_params.rbi +76 -0
- data/rbi/vern_sdk/models/run_create_response.rbi +58 -0
- data/rbi/vern_sdk/models/run_retrieve_params.rbi +27 -0
- data/rbi/vern_sdk/models/run_retrieve_response.rbi +168 -0
- data/rbi/vern_sdk/models.rbi +7 -0
- data/rbi/vern_sdk/request_options.rbi +57 -0
- data/rbi/vern_sdk/resources/runs.rbi +49 -0
- data/rbi/vern_sdk/version.rbi +5 -0
- data/sig/vern_sdk/client.rbs +26 -0
- data/sig/vern_sdk/errors.rbs +101 -0
- data/sig/vern_sdk/file_part.rbs +21 -0
- data/sig/vern_sdk/internal/transport/base_client.rbs +131 -0
- data/sig/vern_sdk/internal/transport/pooled_net_requester.rbs +45 -0
- data/sig/vern_sdk/internal/type/array_of.rbs +48 -0
- data/sig/vern_sdk/internal/type/base_model.rbs +102 -0
- data/sig/vern_sdk/internal/type/base_page.rbs +24 -0
- data/sig/vern_sdk/internal/type/boolean.rbs +26 -0
- data/sig/vern_sdk/internal/type/converter.rbs +56 -0
- data/sig/vern_sdk/internal/type/enum.rbs +32 -0
- data/sig/vern_sdk/internal/type/file_input.rbs +25 -0
- data/sig/vern_sdk/internal/type/hash_of.rbs +48 -0
- data/sig/vern_sdk/internal/type/request_parameters.rbs +17 -0
- data/sig/vern_sdk/internal/type/union.rbs +52 -0
- data/sig/vern_sdk/internal/type/unknown.rbs +26 -0
- data/sig/vern_sdk/internal/util.rbs +185 -0
- data/sig/vern_sdk/internal.rbs +9 -0
- data/sig/vern_sdk/models/run_create_params.rbs +47 -0
- data/sig/vern_sdk/models/run_create_response.rbs +32 -0
- data/sig/vern_sdk/models/run_retrieve_params.rbs +15 -0
- data/sig/vern_sdk/models/run_retrieve_response.rbs +86 -0
- data/sig/vern_sdk/models.rbs +5 -0
- data/sig/vern_sdk/request_options.rbs +34 -0
- data/sig/vern_sdk/resources/runs.rbs +20 -0
- data/sig/vern_sdk/version.rbs +3 -0
- metadata +143 -0
@@ -0,0 +1,168 @@
|
|
1
|
+
# typed: strong
|
2
|
+
|
3
|
+
module VernSDK
|
4
|
+
module Models
|
5
|
+
class RunRetrieveResponse < VernSDK::Internal::Type::BaseModel
|
6
|
+
OrHash =
|
7
|
+
T.type_alias do
|
8
|
+
T.any(
|
9
|
+
VernSDK::Models::RunRetrieveResponse,
|
10
|
+
VernSDK::Internal::AnyHash
|
11
|
+
)
|
12
|
+
end
|
13
|
+
|
14
|
+
# Unique identifier for the run
|
15
|
+
sig { returns(T.nilable(String)) }
|
16
|
+
attr_reader :id
|
17
|
+
|
18
|
+
sig { params(id: String).void }
|
19
|
+
attr_writer :id
|
20
|
+
|
21
|
+
# Timestamp when the run completed
|
22
|
+
sig { returns(T.nilable(Time)) }
|
23
|
+
attr_reader :completed_at
|
24
|
+
|
25
|
+
sig { params(completed_at: Time).void }
|
26
|
+
attr_writer :completed_at
|
27
|
+
|
28
|
+
# Timestamp when the run was created
|
29
|
+
sig { returns(T.nilable(Time)) }
|
30
|
+
attr_reader :created_at
|
31
|
+
|
32
|
+
sig { params(created_at: Time).void }
|
33
|
+
attr_writer :created_at
|
34
|
+
|
35
|
+
# The inputs provided for the task
|
36
|
+
sig { returns(T.nilable(T::Hash[Symbol, T.anything])) }
|
37
|
+
attr_reader :inputs
|
38
|
+
|
39
|
+
sig { params(inputs: T::Hash[Symbol, T.anything]).void }
|
40
|
+
attr_writer :inputs
|
41
|
+
|
42
|
+
# The response data from the task execution
|
43
|
+
sig { returns(T.nilable(T::Hash[Symbol, T.anything])) }
|
44
|
+
attr_reader :response
|
45
|
+
|
46
|
+
sig { params(response: T::Hash[Symbol, T.anything]).void }
|
47
|
+
attr_writer :response
|
48
|
+
|
49
|
+
# Timestamp when the run started executing
|
50
|
+
sig { returns(T.nilable(Time)) }
|
51
|
+
attr_reader :started_at
|
52
|
+
|
53
|
+
sig { params(started_at: Time).void }
|
54
|
+
attr_writer :started_at
|
55
|
+
|
56
|
+
# The current status of the run
|
57
|
+
sig do
|
58
|
+
returns(
|
59
|
+
T.nilable(VernSDK::Models::RunRetrieveResponse::Status::TaggedSymbol)
|
60
|
+
)
|
61
|
+
end
|
62
|
+
attr_reader :status
|
63
|
+
|
64
|
+
sig do
|
65
|
+
params(
|
66
|
+
status: VernSDK::Models::RunRetrieveResponse::Status::OrSymbol
|
67
|
+
).void
|
68
|
+
end
|
69
|
+
attr_writer :status
|
70
|
+
|
71
|
+
# The name of the task that was executed
|
72
|
+
sig { returns(T.nilable(String)) }
|
73
|
+
attr_reader :task
|
74
|
+
|
75
|
+
sig { params(task: String).void }
|
76
|
+
attr_writer :task
|
77
|
+
|
78
|
+
sig do
|
79
|
+
params(
|
80
|
+
id: String,
|
81
|
+
completed_at: Time,
|
82
|
+
created_at: Time,
|
83
|
+
inputs: T::Hash[Symbol, T.anything],
|
84
|
+
response: T::Hash[Symbol, T.anything],
|
85
|
+
started_at: Time,
|
86
|
+
status: VernSDK::Models::RunRetrieveResponse::Status::OrSymbol,
|
87
|
+
task: String
|
88
|
+
).returns(T.attached_class)
|
89
|
+
end
|
90
|
+
def self.new(
|
91
|
+
# Unique identifier for the run
|
92
|
+
id: nil,
|
93
|
+
# Timestamp when the run completed
|
94
|
+
completed_at: nil,
|
95
|
+
# Timestamp when the run was created
|
96
|
+
created_at: nil,
|
97
|
+
# The inputs provided for the task
|
98
|
+
inputs: nil,
|
99
|
+
# The response data from the task execution
|
100
|
+
response: nil,
|
101
|
+
# Timestamp when the run started executing
|
102
|
+
started_at: nil,
|
103
|
+
# The current status of the run
|
104
|
+
status: nil,
|
105
|
+
# The name of the task that was executed
|
106
|
+
task: nil
|
107
|
+
)
|
108
|
+
end
|
109
|
+
|
110
|
+
sig do
|
111
|
+
override.returns(
|
112
|
+
{
|
113
|
+
id: String,
|
114
|
+
completed_at: Time,
|
115
|
+
created_at: Time,
|
116
|
+
inputs: T::Hash[Symbol, T.anything],
|
117
|
+
response: T::Hash[Symbol, T.anything],
|
118
|
+
started_at: Time,
|
119
|
+
status: VernSDK::Models::RunRetrieveResponse::Status::TaggedSymbol,
|
120
|
+
task: String
|
121
|
+
}
|
122
|
+
)
|
123
|
+
end
|
124
|
+
def to_hash
|
125
|
+
end
|
126
|
+
|
127
|
+
# The current status of the run
|
128
|
+
module Status
|
129
|
+
extend VernSDK::Internal::Type::Enum
|
130
|
+
|
131
|
+
TaggedSymbol =
|
132
|
+
T.type_alias do
|
133
|
+
T.all(Symbol, VernSDK::Models::RunRetrieveResponse::Status)
|
134
|
+
end
|
135
|
+
OrSymbol = T.type_alias { T.any(Symbol, String) }
|
136
|
+
|
137
|
+
QUEUED =
|
138
|
+
T.let(
|
139
|
+
:queued,
|
140
|
+
VernSDK::Models::RunRetrieveResponse::Status::TaggedSymbol
|
141
|
+
)
|
142
|
+
RUNNING =
|
143
|
+
T.let(
|
144
|
+
:running,
|
145
|
+
VernSDK::Models::RunRetrieveResponse::Status::TaggedSymbol
|
146
|
+
)
|
147
|
+
COMPLETE =
|
148
|
+
T.let(
|
149
|
+
:complete,
|
150
|
+
VernSDK::Models::RunRetrieveResponse::Status::TaggedSymbol
|
151
|
+
)
|
152
|
+
FAILED =
|
153
|
+
T.let(
|
154
|
+
:failed,
|
155
|
+
VernSDK::Models::RunRetrieveResponse::Status::TaggedSymbol
|
156
|
+
)
|
157
|
+
|
158
|
+
sig do
|
159
|
+
override.returns(
|
160
|
+
T::Array[VernSDK::Models::RunRetrieveResponse::Status::TaggedSymbol]
|
161
|
+
)
|
162
|
+
end
|
163
|
+
def self.values
|
164
|
+
end
|
165
|
+
end
|
166
|
+
end
|
167
|
+
end
|
168
|
+
end
|
@@ -0,0 +1,57 @@
|
|
1
|
+
# typed: strong
|
2
|
+
|
3
|
+
module VernSDK
|
4
|
+
# Specify HTTP behaviour to use for a specific request. These options supplement
|
5
|
+
# or override those provided at the client level.
|
6
|
+
#
|
7
|
+
# When making a request, you can pass an actual {RequestOptions} instance, or
|
8
|
+
# simply pass a Hash with symbol keys matching the attributes on this class.
|
9
|
+
class RequestOptions < VernSDK::Internal::Type::BaseModel
|
10
|
+
OrHash =
|
11
|
+
T.type_alias do
|
12
|
+
T.any(VernSDK::RequestOptions, VernSDK::Internal::AnyHash)
|
13
|
+
end
|
14
|
+
|
15
|
+
# @api private
|
16
|
+
sig { params(opts: VernSDK::RequestOptions::OrHash).void }
|
17
|
+
def self.validate!(opts)
|
18
|
+
end
|
19
|
+
|
20
|
+
# Idempotency key to send with request and all associated retries. Will only be
|
21
|
+
# sent for write requests.
|
22
|
+
sig { returns(T.nilable(String)) }
|
23
|
+
attr_accessor :idempotency_key
|
24
|
+
|
25
|
+
# Extra query params to send with the request. These are `.merge`’d into any
|
26
|
+
# `query` given at the client level.
|
27
|
+
sig do
|
28
|
+
returns(
|
29
|
+
T.nilable(T::Hash[String, T.nilable(T.any(T::Array[String], String))])
|
30
|
+
)
|
31
|
+
end
|
32
|
+
attr_accessor :extra_query
|
33
|
+
|
34
|
+
# Extra headers to send with the request. These are `.merged`’d into any
|
35
|
+
# `extra_headers` given at the client level.
|
36
|
+
sig { returns(T.nilable(T::Hash[String, T.nilable(String)])) }
|
37
|
+
attr_accessor :extra_headers
|
38
|
+
|
39
|
+
# Extra data to send with the request. These are deep merged into any data
|
40
|
+
# generated as part of the normal request.
|
41
|
+
sig { returns(T.nilable(T.anything)) }
|
42
|
+
attr_accessor :extra_body
|
43
|
+
|
44
|
+
# Maximum number of retries to attempt after a failed initial request.
|
45
|
+
sig { returns(T.nilable(Integer)) }
|
46
|
+
attr_accessor :max_retries
|
47
|
+
|
48
|
+
# Request timeout in seconds.
|
49
|
+
sig { returns(T.nilable(Float)) }
|
50
|
+
attr_accessor :timeout
|
51
|
+
|
52
|
+
# Returns a new instance of RequestOptions.
|
53
|
+
sig { params(values: VernSDK::Internal::AnyHash).returns(T.attached_class) }
|
54
|
+
def self.new(values = {})
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
@@ -0,0 +1,49 @@
|
|
1
|
+
# typed: strong
|
2
|
+
|
3
|
+
module VernSDK
|
4
|
+
module Resources
|
5
|
+
class Runs
|
6
|
+
# Executes a task with the provided inputs
|
7
|
+
sig do
|
8
|
+
params(
|
9
|
+
task_id: String,
|
10
|
+
inputs: T::Hash[Symbol, T.anything],
|
11
|
+
profile_id: String,
|
12
|
+
url: String,
|
13
|
+
request_options: VernSDK::RequestOptions::OrHash
|
14
|
+
).returns(VernSDK::Models::RunCreateResponse)
|
15
|
+
end
|
16
|
+
def create(
|
17
|
+
# The ID of the task to execute
|
18
|
+
task_id:,
|
19
|
+
# The inputs required for the task
|
20
|
+
inputs: nil,
|
21
|
+
# Optional user-specified UID for a profile linked via magic link
|
22
|
+
profile_id: nil,
|
23
|
+
# An optional URL to be processed by the task
|
24
|
+
url: nil,
|
25
|
+
request_options: {}
|
26
|
+
)
|
27
|
+
end
|
28
|
+
|
29
|
+
# Retrieves the details of a specific task run
|
30
|
+
sig do
|
31
|
+
params(
|
32
|
+
id: String,
|
33
|
+
request_options: VernSDK::RequestOptions::OrHash
|
34
|
+
).returns(VernSDK::Models::RunRetrieveResponse)
|
35
|
+
end
|
36
|
+
def retrieve(
|
37
|
+
# The ID of the run to retrieve
|
38
|
+
id,
|
39
|
+
request_options: {}
|
40
|
+
)
|
41
|
+
end
|
42
|
+
|
43
|
+
# @api private
|
44
|
+
sig { params(client: VernSDK::Client).returns(T.attached_class) }
|
45
|
+
def self.new(client:)
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
@@ -0,0 +1,26 @@
|
|
1
|
+
module VernSDK
|
2
|
+
class Client < VernSDK::Internal::Transport::BaseClient
|
3
|
+
DEFAULT_MAX_RETRIES: 2
|
4
|
+
|
5
|
+
DEFAULT_TIMEOUT_IN_SECONDS: Float
|
6
|
+
|
7
|
+
DEFAULT_INITIAL_RETRY_DELAY: Float
|
8
|
+
|
9
|
+
DEFAULT_MAX_RETRY_DELAY: Float
|
10
|
+
|
11
|
+
attr_reader api_key: String
|
12
|
+
|
13
|
+
attr_reader runs: VernSDK::Resources::Runs
|
14
|
+
|
15
|
+
private def auth_headers: -> ::Hash[String, String]
|
16
|
+
|
17
|
+
def initialize: (
|
18
|
+
?api_key: String?,
|
19
|
+
?base_url: String?,
|
20
|
+
?max_retries: Integer,
|
21
|
+
?timeout: Float,
|
22
|
+
?initial_retry_delay: Float,
|
23
|
+
?max_retry_delay: Float
|
24
|
+
) -> void
|
25
|
+
end
|
26
|
+
end
|
@@ -0,0 +1,101 @@
|
|
1
|
+
module VernSDK
|
2
|
+
module Errors
|
3
|
+
class Error < StandardError
|
4
|
+
attr_accessor cause: StandardError?
|
5
|
+
end
|
6
|
+
|
7
|
+
class ConversionError < VernSDK::Errors::Error
|
8
|
+
end
|
9
|
+
|
10
|
+
class APIError < VernSDK::Errors::Error
|
11
|
+
attr_accessor url: URI::Generic
|
12
|
+
|
13
|
+
attr_accessor status: Integer?
|
14
|
+
|
15
|
+
attr_accessor body: top?
|
16
|
+
|
17
|
+
def initialize: (
|
18
|
+
url: URI::Generic,
|
19
|
+
?status: Integer?,
|
20
|
+
?body: Object?,
|
21
|
+
?request: nil,
|
22
|
+
?response: nil,
|
23
|
+
?message: String?
|
24
|
+
) -> void
|
25
|
+
end
|
26
|
+
|
27
|
+
class APIConnectionError < VernSDK::Errors::APIError
|
28
|
+
def initialize: (
|
29
|
+
url: URI::Generic,
|
30
|
+
?status: nil,
|
31
|
+
?body: nil,
|
32
|
+
?request: nil,
|
33
|
+
?response: nil,
|
34
|
+
?message: String?
|
35
|
+
) -> void
|
36
|
+
end
|
37
|
+
|
38
|
+
class APITimeoutError < VernSDK::Errors::APIConnectionError
|
39
|
+
def initialize: (
|
40
|
+
url: URI::Generic,
|
41
|
+
?status: nil,
|
42
|
+
?body: nil,
|
43
|
+
?request: nil,
|
44
|
+
?response: nil,
|
45
|
+
?message: String?
|
46
|
+
) -> void
|
47
|
+
end
|
48
|
+
|
49
|
+
class APIStatusError < VernSDK::Errors::APIError
|
50
|
+
def self.for: (
|
51
|
+
url: URI::Generic,
|
52
|
+
status: Integer,
|
53
|
+
body: Object?,
|
54
|
+
request: nil,
|
55
|
+
response: nil,
|
56
|
+
?message: String?
|
57
|
+
) -> instance
|
58
|
+
|
59
|
+
def initialize: (
|
60
|
+
url: URI::Generic,
|
61
|
+
status: Integer,
|
62
|
+
body: Object?,
|
63
|
+
request: nil,
|
64
|
+
response: nil,
|
65
|
+
?message: String?
|
66
|
+
) -> void
|
67
|
+
end
|
68
|
+
|
69
|
+
class BadRequestError < VernSDK::Errors::APIStatusError
|
70
|
+
HTTP_STATUS: 400
|
71
|
+
end
|
72
|
+
|
73
|
+
class AuthenticationError < VernSDK::Errors::APIStatusError
|
74
|
+
HTTP_STATUS: 401
|
75
|
+
end
|
76
|
+
|
77
|
+
class PermissionDeniedError < VernSDK::Errors::APIStatusError
|
78
|
+
HTTP_STATUS: 403
|
79
|
+
end
|
80
|
+
|
81
|
+
class NotFoundError < VernSDK::Errors::APIStatusError
|
82
|
+
HTTP_STATUS: 404
|
83
|
+
end
|
84
|
+
|
85
|
+
class ConflictError < VernSDK::Errors::APIStatusError
|
86
|
+
HTTP_STATUS: 409
|
87
|
+
end
|
88
|
+
|
89
|
+
class UnprocessableEntityError < VernSDK::Errors::APIStatusError
|
90
|
+
HTTP_STATUS: 422
|
91
|
+
end
|
92
|
+
|
93
|
+
class RateLimitError < VernSDK::Errors::APIStatusError
|
94
|
+
HTTP_STATUS: 429
|
95
|
+
end
|
96
|
+
|
97
|
+
class InternalServerError < VernSDK::Errors::APIStatusError
|
98
|
+
HTTP_STATUS: Range[Integer]
|
99
|
+
end
|
100
|
+
end
|
101
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
module VernSDK
|
2
|
+
class FilePart
|
3
|
+
attr_reader content: Pathname | StringIO | IO | String
|
4
|
+
|
5
|
+
attr_reader content_type: String?
|
6
|
+
|
7
|
+
attr_reader filename: String?
|
8
|
+
|
9
|
+
private def read: -> String
|
10
|
+
|
11
|
+
def to_json: (*top a) -> String
|
12
|
+
|
13
|
+
def to_yaml: (*top a) -> String
|
14
|
+
|
15
|
+
def initialize: (
|
16
|
+
Pathname | StringIO | IO | String content,
|
17
|
+
?filename: String?,
|
18
|
+
?content_type: String?
|
19
|
+
) -> void
|
20
|
+
end
|
21
|
+
end
|
@@ -0,0 +1,131 @@
|
|
1
|
+
module VernSDK
|
2
|
+
module Internal
|
3
|
+
module Transport
|
4
|
+
class BaseClient
|
5
|
+
extend VernSDK::Internal::Util::SorbetRuntimeSupport
|
6
|
+
|
7
|
+
type request_components =
|
8
|
+
{
|
9
|
+
method: Symbol,
|
10
|
+
path: String | ::Array[String],
|
11
|
+
query: ::Hash[String, (::Array[String] | String)?]?,
|
12
|
+
headers: ::Hash[String, (String
|
13
|
+
| Integer
|
14
|
+
| ::Array[(String | Integer)?])?]?,
|
15
|
+
body: top?,
|
16
|
+
unwrap: (Symbol
|
17
|
+
| Integer
|
18
|
+
| ::Array[(Symbol | Integer)]
|
19
|
+
| (^(top arg0) -> top))?,
|
20
|
+
page: Class?,
|
21
|
+
stream: Class?,
|
22
|
+
model: VernSDK::Internal::Type::Converter::input?,
|
23
|
+
options: VernSDK::request_opts?
|
24
|
+
}
|
25
|
+
type request_input =
|
26
|
+
{
|
27
|
+
method: Symbol,
|
28
|
+
url: URI::Generic,
|
29
|
+
headers: ::Hash[String, String],
|
30
|
+
body: top,
|
31
|
+
max_retries: Integer,
|
32
|
+
timeout: Float
|
33
|
+
}
|
34
|
+
|
35
|
+
MAX_REDIRECTS: 20
|
36
|
+
|
37
|
+
PLATFORM_HEADERS: ::Hash[String, String]
|
38
|
+
|
39
|
+
def self.validate!: (
|
40
|
+
VernSDK::Internal::Transport::BaseClient::request_components req
|
41
|
+
) -> void
|
42
|
+
|
43
|
+
def self.should_retry?: (
|
44
|
+
Integer status,
|
45
|
+
headers: ::Hash[String, String]
|
46
|
+
) -> bool
|
47
|
+
|
48
|
+
def self.follow_redirect: (
|
49
|
+
VernSDK::Internal::Transport::BaseClient::request_input request,
|
50
|
+
status: Integer,
|
51
|
+
response_headers: ::Hash[String, String]
|
52
|
+
) -> VernSDK::Internal::Transport::BaseClient::request_input
|
53
|
+
|
54
|
+
def self.reap_connection!: (
|
55
|
+
Integer | VernSDK::Errors::APIConnectionError status,
|
56
|
+
stream: Enumerable[String]?
|
57
|
+
) -> void
|
58
|
+
|
59
|
+
attr_reader base_url: URI::Generic
|
60
|
+
|
61
|
+
attr_reader timeout: Float
|
62
|
+
|
63
|
+
attr_reader max_retries: Integer
|
64
|
+
|
65
|
+
attr_reader initial_retry_delay: Float
|
66
|
+
|
67
|
+
attr_reader max_retry_delay: Float
|
68
|
+
|
69
|
+
attr_reader headers: ::Hash[String, String]
|
70
|
+
|
71
|
+
attr_reader idempotency_header: String?
|
72
|
+
|
73
|
+
# @api private
|
74
|
+
attr_reader requester: VernSDK::Internal::Transport::PooledNetRequester
|
75
|
+
|
76
|
+
def initialize: (
|
77
|
+
base_url: String,
|
78
|
+
?timeout: Float,
|
79
|
+
?max_retries: Integer,
|
80
|
+
?initial_retry_delay: Float,
|
81
|
+
?max_retry_delay: Float,
|
82
|
+
?headers: ::Hash[String, (String
|
83
|
+
| Integer
|
84
|
+
| ::Array[(String | Integer)?])?],
|
85
|
+
?idempotency_header: String?
|
86
|
+
) -> void
|
87
|
+
|
88
|
+
private def auth_headers: -> ::Hash[String, String]
|
89
|
+
|
90
|
+
private def generate_idempotency_key: -> String
|
91
|
+
|
92
|
+
private def build_request: (
|
93
|
+
VernSDK::Internal::Transport::BaseClient::request_components req,
|
94
|
+
VernSDK::request_options opts
|
95
|
+
) -> VernSDK::Internal::Transport::BaseClient::request_input
|
96
|
+
|
97
|
+
private def retry_delay: (
|
98
|
+
::Hash[String, String] headers,
|
99
|
+
retry_count: Integer
|
100
|
+
) -> Float
|
101
|
+
|
102
|
+
private def send_request: (
|
103
|
+
VernSDK::Internal::Transport::BaseClient::request_input request,
|
104
|
+
redirect_count: Integer,
|
105
|
+
retry_count: Integer,
|
106
|
+
send_retry_header: bool
|
107
|
+
) -> [Integer, top, Enumerable[String]]
|
108
|
+
|
109
|
+
def request: (
|
110
|
+
Symbol method,
|
111
|
+
String | ::Array[String] path,
|
112
|
+
?query: ::Hash[String, (::Array[String] | String)?]?,
|
113
|
+
?headers: ::Hash[String, (String
|
114
|
+
| Integer
|
115
|
+
| ::Array[(String | Integer)?])?]?,
|
116
|
+
?body: top?,
|
117
|
+
?unwrap: (Symbol
|
118
|
+
| Integer
|
119
|
+
| ::Array[(Symbol | Integer)]
|
120
|
+
| (^(top arg0) -> top))?,
|
121
|
+
?page: Class?,
|
122
|
+
?stream: Class?,
|
123
|
+
?model: VernSDK::Internal::Type::Converter::input?,
|
124
|
+
?options: VernSDK::request_opts?
|
125
|
+
) -> top
|
126
|
+
|
127
|
+
def inspect: -> String
|
128
|
+
end
|
129
|
+
end
|
130
|
+
end
|
131
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
module VernSDK
|
2
|
+
module Internal
|
3
|
+
module Transport
|
4
|
+
class PooledNetRequester
|
5
|
+
extend VernSDK::Internal::Util::SorbetRuntimeSupport
|
6
|
+
|
7
|
+
type request =
|
8
|
+
{
|
9
|
+
method: Symbol,
|
10
|
+
url: URI::Generic,
|
11
|
+
headers: ::Hash[String, String],
|
12
|
+
body: top,
|
13
|
+
deadline: Float
|
14
|
+
}
|
15
|
+
|
16
|
+
KEEP_ALIVE_TIMEOUT: 30
|
17
|
+
|
18
|
+
DEFAULT_MAX_CONNECTIONS: Integer
|
19
|
+
|
20
|
+
def self.connect: (URI::Generic url) -> top
|
21
|
+
|
22
|
+
def self.calibrate_socket_timeout: (top conn, Float deadline) -> void
|
23
|
+
|
24
|
+
def self.build_request: (
|
25
|
+
VernSDK::Internal::Transport::PooledNetRequester::request request
|
26
|
+
) {
|
27
|
+
(String arg0) -> void
|
28
|
+
} -> [top, (^-> void)]
|
29
|
+
|
30
|
+
private def with_pool: (
|
31
|
+
URI::Generic url,
|
32
|
+
deadline: Float
|
33
|
+
) {
|
34
|
+
(top arg0) -> void
|
35
|
+
} -> void
|
36
|
+
|
37
|
+
def execute: (
|
38
|
+
VernSDK::Internal::Transport::PooledNetRequester::request request
|
39
|
+
) -> [Integer, top, Enumerable[String]]
|
40
|
+
|
41
|
+
def initialize: (?size: Integer) -> void
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
@@ -0,0 +1,48 @@
|
|
1
|
+
module VernSDK
|
2
|
+
module Internal
|
3
|
+
module Type
|
4
|
+
class ArrayOf[Elem]
|
5
|
+
include VernSDK::Internal::Type::Converter
|
6
|
+
include VernSDK::Internal::Util::SorbetRuntimeSupport
|
7
|
+
|
8
|
+
def self.[]: (
|
9
|
+
::Hash[Symbol, top]
|
10
|
+
| ^-> VernSDK::Internal::Type::Converter::input
|
11
|
+
| VernSDK::Internal::Type::Converter::input type_info,
|
12
|
+
?::Hash[Symbol, top] spec
|
13
|
+
) -> instance
|
14
|
+
|
15
|
+
def ===: (top other) -> bool
|
16
|
+
|
17
|
+
def ==: (top other) -> bool
|
18
|
+
|
19
|
+
def hash: -> Integer
|
20
|
+
|
21
|
+
def coerce: (
|
22
|
+
::Array[top] | top value,
|
23
|
+
state: VernSDK::Internal::Type::Converter::coerce_state
|
24
|
+
) -> (::Array[top] | top)
|
25
|
+
|
26
|
+
def dump: (
|
27
|
+
::Array[top] | top value,
|
28
|
+
state: VernSDK::Internal::Type::Converter::dump_state
|
29
|
+
) -> (::Array[top] | top)
|
30
|
+
|
31
|
+
def to_sorbet_type: -> top
|
32
|
+
|
33
|
+
def item_type: -> Elem
|
34
|
+
|
35
|
+
def nilable?: -> bool
|
36
|
+
|
37
|
+
def initialize: (
|
38
|
+
::Hash[Symbol, top]
|
39
|
+
| ^-> VernSDK::Internal::Type::Converter::input
|
40
|
+
| VernSDK::Internal::Type::Converter::input type_info,
|
41
|
+
?::Hash[Symbol, top] spec
|
42
|
+
) -> void
|
43
|
+
|
44
|
+
def inspect: (?depth: Integer) -> String
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|