seerstack 0.1.0
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 +15 -0
- data/README.md +205 -0
- data/SECURITY.md +23 -0
- data/lib/seerstack/client.rb +79 -0
- data/lib/seerstack/errors.rb +228 -0
- data/lib/seerstack/file_part.rb +58 -0
- data/lib/seerstack/internal/transport/base_client.rb +573 -0
- data/lib/seerstack/internal/transport/pooled_net_requester.rb +210 -0
- data/lib/seerstack/internal/type/array_of.rb +168 -0
- data/lib/seerstack/internal/type/base_model.rb +529 -0
- data/lib/seerstack/internal/type/base_page.rb +55 -0
- data/lib/seerstack/internal/type/boolean.rb +77 -0
- data/lib/seerstack/internal/type/converter.rb +327 -0
- data/lib/seerstack/internal/type/enum.rb +131 -0
- data/lib/seerstack/internal/type/file_input.rb +111 -0
- data/lib/seerstack/internal/type/hash_of.rb +188 -0
- data/lib/seerstack/internal/type/request_parameters.rb +42 -0
- data/lib/seerstack/internal/type/union.rb +237 -0
- data/lib/seerstack/internal/type/unknown.rb +81 -0
- data/lib/seerstack/internal/util.rb +920 -0
- data/lib/seerstack/internal.rb +20 -0
- data/lib/seerstack/models/event_capture_params.rb +38 -0
- data/lib/seerstack/models/event_capture_response.rb +16 -0
- data/lib/seerstack/models/user_identify_params.rb +38 -0
- data/lib/seerstack/models/user_identify_response.rb +16 -0
- data/lib/seerstack/models.rb +45 -0
- data/lib/seerstack/request_options.rb +77 -0
- data/lib/seerstack/resources/events.rb +38 -0
- data/lib/seerstack/resources/users.rb +38 -0
- data/lib/seerstack/version.rb +5 -0
- data/lib/seerstack.rb +61 -0
- data/manifest.yaml +17 -0
- data/rbi/seerstack/client.rbi +53 -0
- data/rbi/seerstack/errors.rbi +205 -0
- data/rbi/seerstack/file_part.rbi +37 -0
- data/rbi/seerstack/internal/transport/base_client.rbi +298 -0
- data/rbi/seerstack/internal/transport/pooled_net_requester.rbi +83 -0
- data/rbi/seerstack/internal/type/array_of.rbi +104 -0
- data/rbi/seerstack/internal/type/base_model.rbi +308 -0
- data/rbi/seerstack/internal/type/base_page.rbi +42 -0
- data/rbi/seerstack/internal/type/boolean.rbi +58 -0
- data/rbi/seerstack/internal/type/converter.rbi +216 -0
- data/rbi/seerstack/internal/type/enum.rbi +82 -0
- data/rbi/seerstack/internal/type/file_input.rbi +59 -0
- data/rbi/seerstack/internal/type/hash_of.rbi +104 -0
- data/rbi/seerstack/internal/type/request_parameters.rbi +29 -0
- data/rbi/seerstack/internal/type/union.rbi +128 -0
- data/rbi/seerstack/internal/type/unknown.rbi +58 -0
- data/rbi/seerstack/internal/util.rbi +487 -0
- data/rbi/seerstack/internal.rbi +18 -0
- data/rbi/seerstack/models/event_capture_params.rbi +68 -0
- data/rbi/seerstack/models/event_capture_response.rbi +26 -0
- data/rbi/seerstack/models/user_identify_params.rbi +68 -0
- data/rbi/seerstack/models/user_identify_response.rbi +26 -0
- data/rbi/seerstack/models.rbi +7 -0
- data/rbi/seerstack/request_options.rbi +59 -0
- data/rbi/seerstack/resources/events.rbi +31 -0
- data/rbi/seerstack/resources/users.rbi +31 -0
- data/rbi/seerstack/version.rbi +5 -0
- data/sig/seerstack/client.rbs +28 -0
- data/sig/seerstack/errors.rbs +117 -0
- data/sig/seerstack/file_part.rbs +21 -0
- data/sig/seerstack/internal/transport/base_client.rbs +133 -0
- data/sig/seerstack/internal/transport/pooled_net_requester.rbs +48 -0
- data/sig/seerstack/internal/type/array_of.rbs +48 -0
- data/sig/seerstack/internal/type/base_model.rbs +102 -0
- data/sig/seerstack/internal/type/base_page.rbs +24 -0
- data/sig/seerstack/internal/type/boolean.rbs +26 -0
- data/sig/seerstack/internal/type/converter.rbs +79 -0
- data/sig/seerstack/internal/type/enum.rbs +32 -0
- data/sig/seerstack/internal/type/file_input.rbs +25 -0
- data/sig/seerstack/internal/type/hash_of.rbs +48 -0
- data/sig/seerstack/internal/type/request_parameters.rbs +19 -0
- data/sig/seerstack/internal/type/union.rbs +52 -0
- data/sig/seerstack/internal/type/unknown.rbs +26 -0
- data/sig/seerstack/internal/util.rbs +185 -0
- data/sig/seerstack/internal.rbs +9 -0
- data/sig/seerstack/models/event_capture_params.rbs +47 -0
- data/sig/seerstack/models/event_capture_response.rbs +13 -0
- data/sig/seerstack/models/user_identify_params.rbs +47 -0
- data/sig/seerstack/models/user_identify_response.rbs +13 -0
- data/sig/seerstack/models.rbs +5 -0
- data/sig/seerstack/request_options.rbs +34 -0
- data/sig/seerstack/resources/events.rbs +15 -0
- data/sig/seerstack/resources/users.rbs +15 -0
- data/sig/seerstack/version.rbs +3 -0
- metadata +146 -0
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
# typed: strong
|
|
2
|
+
|
|
3
|
+
module Seerstack
|
|
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 < Seerstack::Internal::Type::BaseModel
|
|
10
|
+
OrHash =
|
|
11
|
+
T.type_alias do
|
|
12
|
+
T.any(Seerstack::RequestOptions, Seerstack::Internal::AnyHash)
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
# @api private
|
|
16
|
+
sig { params(opts: Seerstack::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 do
|
|
54
|
+
params(values: Seerstack::Internal::AnyHash).returns(T.attached_class)
|
|
55
|
+
end
|
|
56
|
+
def self.new(values = {})
|
|
57
|
+
end
|
|
58
|
+
end
|
|
59
|
+
end
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
# typed: strong
|
|
2
|
+
|
|
3
|
+
module Seerstack
|
|
4
|
+
module Resources
|
|
5
|
+
class Events
|
|
6
|
+
# Capture an event
|
|
7
|
+
sig do
|
|
8
|
+
params(
|
|
9
|
+
name: String,
|
|
10
|
+
data: T::Hash[Symbol, T.nilable(T.anything)],
|
|
11
|
+
timestamp: Time,
|
|
12
|
+
user_id: String,
|
|
13
|
+
request_options: Seerstack::RequestOptions::OrHash
|
|
14
|
+
).returns(Seerstack::Models::EventCaptureResponse)
|
|
15
|
+
end
|
|
16
|
+
def capture(
|
|
17
|
+
name:,
|
|
18
|
+
data: nil,
|
|
19
|
+
timestamp: nil,
|
|
20
|
+
user_id: nil,
|
|
21
|
+
request_options: {}
|
|
22
|
+
)
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
# @api private
|
|
26
|
+
sig { params(client: Seerstack::Client).returns(T.attached_class) }
|
|
27
|
+
def self.new(client:)
|
|
28
|
+
end
|
|
29
|
+
end
|
|
30
|
+
end
|
|
31
|
+
end
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
# typed: strong
|
|
2
|
+
|
|
3
|
+
module Seerstack
|
|
4
|
+
module Resources
|
|
5
|
+
class Users
|
|
6
|
+
# Identify a user
|
|
7
|
+
sig do
|
|
8
|
+
params(
|
|
9
|
+
user_id: String,
|
|
10
|
+
attributes: T::Hash[Symbol, T.nilable(T.anything)],
|
|
11
|
+
email: String,
|
|
12
|
+
name: String,
|
|
13
|
+
request_options: Seerstack::RequestOptions::OrHash
|
|
14
|
+
).returns(Seerstack::Models::UserIdentifyResponse)
|
|
15
|
+
end
|
|
16
|
+
def identify(
|
|
17
|
+
user_id:,
|
|
18
|
+
attributes: nil,
|
|
19
|
+
email: nil,
|
|
20
|
+
name: nil,
|
|
21
|
+
request_options: {}
|
|
22
|
+
)
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
# @api private
|
|
26
|
+
sig { params(client: Seerstack::Client).returns(T.attached_class) }
|
|
27
|
+
def self.new(client:)
|
|
28
|
+
end
|
|
29
|
+
end
|
|
30
|
+
end
|
|
31
|
+
end
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
module Seerstack
|
|
2
|
+
class Client < Seerstack::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 events: Seerstack::Resources::Events
|
|
14
|
+
|
|
15
|
+
attr_reader users: Seerstack::Resources::Users
|
|
16
|
+
|
|
17
|
+
private def auth_headers: -> ::Hash[String, String]
|
|
18
|
+
|
|
19
|
+
def initialize: (
|
|
20
|
+
?api_key: String?,
|
|
21
|
+
?base_url: String?,
|
|
22
|
+
?max_retries: Integer,
|
|
23
|
+
?timeout: Float,
|
|
24
|
+
?initial_retry_delay: Float,
|
|
25
|
+
?max_retry_delay: Float
|
|
26
|
+
) -> void
|
|
27
|
+
end
|
|
28
|
+
end
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
module Seerstack
|
|
2
|
+
module Errors
|
|
3
|
+
class Error < StandardError
|
|
4
|
+
attr_accessor cause: StandardError?
|
|
5
|
+
end
|
|
6
|
+
|
|
7
|
+
class ConversionError < Seerstack::Errors::Error
|
|
8
|
+
def cause: -> StandardError?
|
|
9
|
+
|
|
10
|
+
def initialize: (
|
|
11
|
+
on: Class,
|
|
12
|
+
method: Symbol,
|
|
13
|
+
target: top,
|
|
14
|
+
value: top,
|
|
15
|
+
?cause: StandardError?
|
|
16
|
+
) -> void
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
class APIError < Seerstack::Errors::Error
|
|
20
|
+
attr_accessor url: URI::Generic
|
|
21
|
+
|
|
22
|
+
attr_accessor status: Integer?
|
|
23
|
+
|
|
24
|
+
attr_accessor headers: ::Hash[String, String]?
|
|
25
|
+
|
|
26
|
+
attr_accessor body: top?
|
|
27
|
+
|
|
28
|
+
def initialize: (
|
|
29
|
+
url: URI::Generic,
|
|
30
|
+
?status: Integer?,
|
|
31
|
+
?headers: ::Hash[String, String]?,
|
|
32
|
+
?body: Object?,
|
|
33
|
+
?request: nil,
|
|
34
|
+
?response: nil,
|
|
35
|
+
?message: String?
|
|
36
|
+
) -> void
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
class APIConnectionError < Seerstack::Errors::APIError
|
|
40
|
+
def initialize: (
|
|
41
|
+
url: URI::Generic,
|
|
42
|
+
?status: nil,
|
|
43
|
+
?headers: ::Hash[String, String]?,
|
|
44
|
+
?body: nil,
|
|
45
|
+
?request: nil,
|
|
46
|
+
?response: nil,
|
|
47
|
+
?message: String?
|
|
48
|
+
) -> void
|
|
49
|
+
end
|
|
50
|
+
|
|
51
|
+
class APITimeoutError < Seerstack::Errors::APIConnectionError
|
|
52
|
+
def initialize: (
|
|
53
|
+
url: URI::Generic,
|
|
54
|
+
?status: nil,
|
|
55
|
+
?headers: ::Hash[String, String]?,
|
|
56
|
+
?body: nil,
|
|
57
|
+
?request: nil,
|
|
58
|
+
?response: nil,
|
|
59
|
+
?message: String?
|
|
60
|
+
) -> void
|
|
61
|
+
end
|
|
62
|
+
|
|
63
|
+
class APIStatusError < Seerstack::Errors::APIError
|
|
64
|
+
def self.for: (
|
|
65
|
+
url: URI::Generic,
|
|
66
|
+
status: Integer,
|
|
67
|
+
headers: ::Hash[String, String]?,
|
|
68
|
+
body: Object?,
|
|
69
|
+
request: nil,
|
|
70
|
+
response: nil,
|
|
71
|
+
?message: String?
|
|
72
|
+
) -> instance
|
|
73
|
+
|
|
74
|
+
def initialize: (
|
|
75
|
+
url: URI::Generic,
|
|
76
|
+
status: Integer,
|
|
77
|
+
headers: ::Hash[String, String]?,
|
|
78
|
+
body: Object?,
|
|
79
|
+
request: nil,
|
|
80
|
+
response: nil,
|
|
81
|
+
?message: String?
|
|
82
|
+
) -> void
|
|
83
|
+
end
|
|
84
|
+
|
|
85
|
+
class BadRequestError < Seerstack::Errors::APIStatusError
|
|
86
|
+
HTTP_STATUS: 400
|
|
87
|
+
end
|
|
88
|
+
|
|
89
|
+
class AuthenticationError < Seerstack::Errors::APIStatusError
|
|
90
|
+
HTTP_STATUS: 401
|
|
91
|
+
end
|
|
92
|
+
|
|
93
|
+
class PermissionDeniedError < Seerstack::Errors::APIStatusError
|
|
94
|
+
HTTP_STATUS: 403
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
class NotFoundError < Seerstack::Errors::APIStatusError
|
|
98
|
+
HTTP_STATUS: 404
|
|
99
|
+
end
|
|
100
|
+
|
|
101
|
+
class ConflictError < Seerstack::Errors::APIStatusError
|
|
102
|
+
HTTP_STATUS: 409
|
|
103
|
+
end
|
|
104
|
+
|
|
105
|
+
class UnprocessableEntityError < Seerstack::Errors::APIStatusError
|
|
106
|
+
HTTP_STATUS: 422
|
|
107
|
+
end
|
|
108
|
+
|
|
109
|
+
class RateLimitError < Seerstack::Errors::APIStatusError
|
|
110
|
+
HTTP_STATUS: 429
|
|
111
|
+
end
|
|
112
|
+
|
|
113
|
+
class InternalServerError < Seerstack::Errors::APIStatusError
|
|
114
|
+
HTTP_STATUS: Range[Integer]
|
|
115
|
+
end
|
|
116
|
+
end
|
|
117
|
+
end
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
module Seerstack
|
|
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: (Pathname | String)?,
|
|
18
|
+
?content_type: String?
|
|
19
|
+
) -> void
|
|
20
|
+
end
|
|
21
|
+
end
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
module Seerstack
|
|
2
|
+
module Internal
|
|
3
|
+
module Transport
|
|
4
|
+
class BaseClient
|
|
5
|
+
extend Seerstack::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: Seerstack::Internal::Type::Converter::input?,
|
|
23
|
+
options: Seerstack::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
|
+
Seerstack::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
|
+
Seerstack::Internal::Transport::BaseClient::request_input request,
|
|
50
|
+
status: Integer,
|
|
51
|
+
response_headers: ::Hash[String, String]
|
|
52
|
+
) -> Seerstack::Internal::Transport::BaseClient::request_input
|
|
53
|
+
|
|
54
|
+
def self.reap_connection!: (
|
|
55
|
+
Integer | Seerstack::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: Seerstack::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 user_agent: -> String
|
|
91
|
+
|
|
92
|
+
private def generate_idempotency_key: -> String
|
|
93
|
+
|
|
94
|
+
private def build_request: (
|
|
95
|
+
Seerstack::Internal::Transport::BaseClient::request_components req,
|
|
96
|
+
Seerstack::request_options opts
|
|
97
|
+
) -> Seerstack::Internal::Transport::BaseClient::request_input
|
|
98
|
+
|
|
99
|
+
private def retry_delay: (
|
|
100
|
+
::Hash[String, String] headers,
|
|
101
|
+
retry_count: Integer
|
|
102
|
+
) -> Float
|
|
103
|
+
|
|
104
|
+
def send_request: (
|
|
105
|
+
Seerstack::Internal::Transport::BaseClient::request_input request,
|
|
106
|
+
redirect_count: Integer,
|
|
107
|
+
retry_count: Integer,
|
|
108
|
+
send_retry_header: bool
|
|
109
|
+
) -> [Integer, top, Enumerable[String]]
|
|
110
|
+
|
|
111
|
+
def request: (
|
|
112
|
+
Symbol method,
|
|
113
|
+
String | ::Array[String] path,
|
|
114
|
+
?query: ::Hash[String, (::Array[String] | String)?]?,
|
|
115
|
+
?headers: ::Hash[String, (String
|
|
116
|
+
| Integer
|
|
117
|
+
| ::Array[(String | Integer)?])?]?,
|
|
118
|
+
?body: top?,
|
|
119
|
+
?unwrap: (Symbol
|
|
120
|
+
| Integer
|
|
121
|
+
| ::Array[(Symbol | Integer)]
|
|
122
|
+
| (^(top arg0) -> top))?,
|
|
123
|
+
?page: Class?,
|
|
124
|
+
?stream: Class?,
|
|
125
|
+
?model: Seerstack::Internal::Type::Converter::input?,
|
|
126
|
+
?options: Seerstack::request_opts?
|
|
127
|
+
) -> top
|
|
128
|
+
|
|
129
|
+
def inspect: -> String
|
|
130
|
+
end
|
|
131
|
+
end
|
|
132
|
+
end
|
|
133
|
+
end
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
module Seerstack
|
|
2
|
+
module Internal
|
|
3
|
+
module Transport
|
|
4
|
+
class PooledNetRequester
|
|
5
|
+
extend Seerstack::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: (
|
|
21
|
+
cert_store: OpenSSL::X509::Store,
|
|
22
|
+
url: URI::Generic
|
|
23
|
+
) -> top
|
|
24
|
+
|
|
25
|
+
def self.calibrate_socket_timeout: (top conn, Float deadline) -> void
|
|
26
|
+
|
|
27
|
+
def self.build_request: (
|
|
28
|
+
Seerstack::Internal::Transport::PooledNetRequester::request request
|
|
29
|
+
) {
|
|
30
|
+
(String arg0) -> void
|
|
31
|
+
} -> [top, (^-> void)]
|
|
32
|
+
|
|
33
|
+
private def with_pool: (
|
|
34
|
+
URI::Generic url,
|
|
35
|
+
deadline: Float
|
|
36
|
+
) {
|
|
37
|
+
(top arg0) -> void
|
|
38
|
+
} -> void
|
|
39
|
+
|
|
40
|
+
def execute: (
|
|
41
|
+
Seerstack::Internal::Transport::PooledNetRequester::request request
|
|
42
|
+
) -> [Integer, top, Enumerable[String]]
|
|
43
|
+
|
|
44
|
+
def initialize: (?size: Integer) -> void
|
|
45
|
+
end
|
|
46
|
+
end
|
|
47
|
+
end
|
|
48
|
+
end
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
module Seerstack
|
|
2
|
+
module Internal
|
|
3
|
+
module Type
|
|
4
|
+
class ArrayOf[Elem]
|
|
5
|
+
include Seerstack::Internal::Type::Converter
|
|
6
|
+
include Seerstack::Internal::Util::SorbetRuntimeSupport
|
|
7
|
+
|
|
8
|
+
def self.[]: (
|
|
9
|
+
::Hash[Symbol, top]
|
|
10
|
+
| ^-> Seerstack::Internal::Type::Converter::input
|
|
11
|
+
| Seerstack::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: Seerstack::Internal::Type::Converter::coerce_state
|
|
24
|
+
) -> (::Array[top] | top)
|
|
25
|
+
|
|
26
|
+
def dump: (
|
|
27
|
+
::Array[top] | top value,
|
|
28
|
+
state: Seerstack::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
|
+
| ^-> Seerstack::Internal::Type::Converter::input
|
|
40
|
+
| Seerstack::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
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
module Seerstack
|
|
2
|
+
module Internal
|
|
3
|
+
module Type
|
|
4
|
+
class BaseModel
|
|
5
|
+
extend Seerstack::Internal::Type::Converter
|
|
6
|
+
extend Seerstack::Internal::Util::SorbetRuntimeSupport
|
|
7
|
+
|
|
8
|
+
type known_field =
|
|
9
|
+
{ mode: (:coerce | :dump)?, required: bool, nilable: bool }
|
|
10
|
+
|
|
11
|
+
def self.inherited: (self child) -> void
|
|
12
|
+
|
|
13
|
+
def self.known_fields: -> ::Hash[Symbol, (Seerstack::Internal::Type::BaseModel::known_field
|
|
14
|
+
& { type_fn: (^-> Seerstack::Internal::Type::Converter::input) })]
|
|
15
|
+
|
|
16
|
+
def self.fields: -> ::Hash[Symbol, (Seerstack::Internal::Type::BaseModel::known_field
|
|
17
|
+
& { type: Seerstack::Internal::Type::Converter::input })]
|
|
18
|
+
|
|
19
|
+
private def self.add_field: (
|
|
20
|
+
Symbol name_sym,
|
|
21
|
+
required: bool,
|
|
22
|
+
type_info: {
|
|
23
|
+
const: (nil | bool | Integer | Float | Symbol)?,
|
|
24
|
+
enum: ^-> Seerstack::Internal::Type::Converter::input?,
|
|
25
|
+
union: ^-> Seerstack::Internal::Type::Converter::input?,
|
|
26
|
+
api_name: Symbol
|
|
27
|
+
}
|
|
28
|
+
| ^-> Seerstack::Internal::Type::Converter::input
|
|
29
|
+
| Seerstack::Internal::Type::Converter::input,
|
|
30
|
+
spec: ::Hash[Symbol, top]
|
|
31
|
+
) -> void
|
|
32
|
+
|
|
33
|
+
def self.required: (
|
|
34
|
+
Symbol name_sym,
|
|
35
|
+
::Hash[Symbol, top]
|
|
36
|
+
| ^-> Seerstack::Internal::Type::Converter::input
|
|
37
|
+
| Seerstack::Internal::Type::Converter::input type_info,
|
|
38
|
+
?::Hash[Symbol, top] spec
|
|
39
|
+
) -> void
|
|
40
|
+
|
|
41
|
+
def self.optional: (
|
|
42
|
+
Symbol name_sym,
|
|
43
|
+
::Hash[Symbol, top]
|
|
44
|
+
| ^-> Seerstack::Internal::Type::Converter::input
|
|
45
|
+
| Seerstack::Internal::Type::Converter::input type_info,
|
|
46
|
+
?::Hash[Symbol, top] spec
|
|
47
|
+
) -> void
|
|
48
|
+
|
|
49
|
+
private def self.request_only: { -> void } -> void
|
|
50
|
+
|
|
51
|
+
private def self.response_only: { -> void } -> void
|
|
52
|
+
|
|
53
|
+
def self.==: (top other) -> bool
|
|
54
|
+
|
|
55
|
+
def self.hash: -> Integer
|
|
56
|
+
|
|
57
|
+
def ==: (top other) -> bool
|
|
58
|
+
|
|
59
|
+
def hash: -> Integer
|
|
60
|
+
|
|
61
|
+
def self.coerce: (
|
|
62
|
+
Seerstack::Internal::Type::BaseModel | ::Hash[top, top] | top value,
|
|
63
|
+
state: Seerstack::Internal::Type::Converter::coerce_state
|
|
64
|
+
) -> (instance | top)
|
|
65
|
+
|
|
66
|
+
def self.dump: (
|
|
67
|
+
instance | top value,
|
|
68
|
+
state: Seerstack::Internal::Type::Converter::dump_state
|
|
69
|
+
) -> (::Hash[top, top] | top)
|
|
70
|
+
|
|
71
|
+
def self.to_sorbet_type: -> top
|
|
72
|
+
|
|
73
|
+
def self.recursively_to_h: (
|
|
74
|
+
Seerstack::Internal::Type::BaseModel model,
|
|
75
|
+
convert: bool
|
|
76
|
+
) -> ::Hash[Symbol, top]
|
|
77
|
+
|
|
78
|
+
def []: (Symbol key) -> top?
|
|
79
|
+
|
|
80
|
+
def to_h: -> ::Hash[Symbol, top]
|
|
81
|
+
|
|
82
|
+
alias to_hash to_h
|
|
83
|
+
|
|
84
|
+
def deep_to_h: -> ::Hash[Symbol, top]
|
|
85
|
+
|
|
86
|
+
def deconstruct_keys: (::Array[Symbol]? keys) -> ::Hash[Symbol, top]
|
|
87
|
+
|
|
88
|
+
def to_json: (*top a) -> String
|
|
89
|
+
|
|
90
|
+
def to_yaml: (*top a) -> String
|
|
91
|
+
|
|
92
|
+
def initialize: (?::Hash[Symbol, top] | instance data) -> void
|
|
93
|
+
|
|
94
|
+
def self.inspect: (?depth: Integer) -> String
|
|
95
|
+
|
|
96
|
+
def to_s: -> String
|
|
97
|
+
|
|
98
|
+
def inspect: -> String
|
|
99
|
+
end
|
|
100
|
+
end
|
|
101
|
+
end
|
|
102
|
+
end
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
module Seerstack
|
|
2
|
+
module Internal
|
|
3
|
+
module Type
|
|
4
|
+
module BasePage[Elem]
|
|
5
|
+
def next_page?: -> bool
|
|
6
|
+
|
|
7
|
+
def next_page: -> instance
|
|
8
|
+
|
|
9
|
+
def auto_paging_each: { (Elem arg0) -> void } -> void
|
|
10
|
+
|
|
11
|
+
def to_enum: -> Enumerable[Elem]
|
|
12
|
+
|
|
13
|
+
alias enum_for to_enum
|
|
14
|
+
|
|
15
|
+
def initialize: (
|
|
16
|
+
client: Seerstack::Internal::Transport::BaseClient,
|
|
17
|
+
req: Seerstack::Internal::Transport::BaseClient::request_components,
|
|
18
|
+
headers: ::Hash[String, String],
|
|
19
|
+
page_data: top
|
|
20
|
+
) -> void
|
|
21
|
+
end
|
|
22
|
+
end
|
|
23
|
+
end
|
|
24
|
+
end
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
module Seerstack
|
|
2
|
+
module Internal
|
|
3
|
+
module Type
|
|
4
|
+
class Boolean
|
|
5
|
+
extend Seerstack::Internal::Type::Converter
|
|
6
|
+
extend Seerstack::Internal::Util::SorbetRuntimeSupport
|
|
7
|
+
|
|
8
|
+
def self.===: (top other) -> bool
|
|
9
|
+
|
|
10
|
+
def self.==: (top other) -> bool
|
|
11
|
+
|
|
12
|
+
def self.coerce: (
|
|
13
|
+
bool | top value,
|
|
14
|
+
state: Seerstack::Internal::Type::Converter::coerce_state
|
|
15
|
+
) -> (bool | top)
|
|
16
|
+
|
|
17
|
+
def self.dump: (
|
|
18
|
+
bool | top value,
|
|
19
|
+
state: Seerstack::Internal::Type::Converter::dump_state
|
|
20
|
+
) -> (bool | top)
|
|
21
|
+
|
|
22
|
+
def self.to_sorbet_type: -> top
|
|
23
|
+
end
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
end
|