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.
Files changed (89) hide show
  1. checksums.yaml +7 -0
  2. data/.ignore +2 -0
  3. data/CHANGELOG.md +15 -0
  4. data/README.md +205 -0
  5. data/SECURITY.md +23 -0
  6. data/lib/seerstack/client.rb +79 -0
  7. data/lib/seerstack/errors.rb +228 -0
  8. data/lib/seerstack/file_part.rb +58 -0
  9. data/lib/seerstack/internal/transport/base_client.rb +573 -0
  10. data/lib/seerstack/internal/transport/pooled_net_requester.rb +210 -0
  11. data/lib/seerstack/internal/type/array_of.rb +168 -0
  12. data/lib/seerstack/internal/type/base_model.rb +529 -0
  13. data/lib/seerstack/internal/type/base_page.rb +55 -0
  14. data/lib/seerstack/internal/type/boolean.rb +77 -0
  15. data/lib/seerstack/internal/type/converter.rb +327 -0
  16. data/lib/seerstack/internal/type/enum.rb +131 -0
  17. data/lib/seerstack/internal/type/file_input.rb +111 -0
  18. data/lib/seerstack/internal/type/hash_of.rb +188 -0
  19. data/lib/seerstack/internal/type/request_parameters.rb +42 -0
  20. data/lib/seerstack/internal/type/union.rb +237 -0
  21. data/lib/seerstack/internal/type/unknown.rb +81 -0
  22. data/lib/seerstack/internal/util.rb +920 -0
  23. data/lib/seerstack/internal.rb +20 -0
  24. data/lib/seerstack/models/event_capture_params.rb +38 -0
  25. data/lib/seerstack/models/event_capture_response.rb +16 -0
  26. data/lib/seerstack/models/user_identify_params.rb +38 -0
  27. data/lib/seerstack/models/user_identify_response.rb +16 -0
  28. data/lib/seerstack/models.rb +45 -0
  29. data/lib/seerstack/request_options.rb +77 -0
  30. data/lib/seerstack/resources/events.rb +38 -0
  31. data/lib/seerstack/resources/users.rb +38 -0
  32. data/lib/seerstack/version.rb +5 -0
  33. data/lib/seerstack.rb +61 -0
  34. data/manifest.yaml +17 -0
  35. data/rbi/seerstack/client.rbi +53 -0
  36. data/rbi/seerstack/errors.rbi +205 -0
  37. data/rbi/seerstack/file_part.rbi +37 -0
  38. data/rbi/seerstack/internal/transport/base_client.rbi +298 -0
  39. data/rbi/seerstack/internal/transport/pooled_net_requester.rbi +83 -0
  40. data/rbi/seerstack/internal/type/array_of.rbi +104 -0
  41. data/rbi/seerstack/internal/type/base_model.rbi +308 -0
  42. data/rbi/seerstack/internal/type/base_page.rbi +42 -0
  43. data/rbi/seerstack/internal/type/boolean.rbi +58 -0
  44. data/rbi/seerstack/internal/type/converter.rbi +216 -0
  45. data/rbi/seerstack/internal/type/enum.rbi +82 -0
  46. data/rbi/seerstack/internal/type/file_input.rbi +59 -0
  47. data/rbi/seerstack/internal/type/hash_of.rbi +104 -0
  48. data/rbi/seerstack/internal/type/request_parameters.rbi +29 -0
  49. data/rbi/seerstack/internal/type/union.rbi +128 -0
  50. data/rbi/seerstack/internal/type/unknown.rbi +58 -0
  51. data/rbi/seerstack/internal/util.rbi +487 -0
  52. data/rbi/seerstack/internal.rbi +18 -0
  53. data/rbi/seerstack/models/event_capture_params.rbi +68 -0
  54. data/rbi/seerstack/models/event_capture_response.rbi +26 -0
  55. data/rbi/seerstack/models/user_identify_params.rbi +68 -0
  56. data/rbi/seerstack/models/user_identify_response.rbi +26 -0
  57. data/rbi/seerstack/models.rbi +7 -0
  58. data/rbi/seerstack/request_options.rbi +59 -0
  59. data/rbi/seerstack/resources/events.rbi +31 -0
  60. data/rbi/seerstack/resources/users.rbi +31 -0
  61. data/rbi/seerstack/version.rbi +5 -0
  62. data/sig/seerstack/client.rbs +28 -0
  63. data/sig/seerstack/errors.rbs +117 -0
  64. data/sig/seerstack/file_part.rbs +21 -0
  65. data/sig/seerstack/internal/transport/base_client.rbs +133 -0
  66. data/sig/seerstack/internal/transport/pooled_net_requester.rbs +48 -0
  67. data/sig/seerstack/internal/type/array_of.rbs +48 -0
  68. data/sig/seerstack/internal/type/base_model.rbs +102 -0
  69. data/sig/seerstack/internal/type/base_page.rbs +24 -0
  70. data/sig/seerstack/internal/type/boolean.rbs +26 -0
  71. data/sig/seerstack/internal/type/converter.rbs +79 -0
  72. data/sig/seerstack/internal/type/enum.rbs +32 -0
  73. data/sig/seerstack/internal/type/file_input.rbs +25 -0
  74. data/sig/seerstack/internal/type/hash_of.rbs +48 -0
  75. data/sig/seerstack/internal/type/request_parameters.rbs +19 -0
  76. data/sig/seerstack/internal/type/union.rbs +52 -0
  77. data/sig/seerstack/internal/type/unknown.rbs +26 -0
  78. data/sig/seerstack/internal/util.rbs +185 -0
  79. data/sig/seerstack/internal.rbs +9 -0
  80. data/sig/seerstack/models/event_capture_params.rbs +47 -0
  81. data/sig/seerstack/models/event_capture_response.rbs +13 -0
  82. data/sig/seerstack/models/user_identify_params.rbs +47 -0
  83. data/sig/seerstack/models/user_identify_response.rbs +13 -0
  84. data/sig/seerstack/models.rbs +5 -0
  85. data/sig/seerstack/request_options.rbs +34 -0
  86. data/sig/seerstack/resources/events.rbs +15 -0
  87. data/sig/seerstack/resources/users.rbs +15 -0
  88. data/sig/seerstack/version.rbs +3 -0
  89. 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,5 @@
1
+ # typed: strong
2
+
3
+ module Seerstack
4
+ VERSION = T.let(T.unsafe(nil), String)
5
+ 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