method-ruby 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 (125) hide show
  1. checksums.yaml +7 -0
  2. data/.ignore +2 -0
  3. data/CHANGELOG.md +11 -0
  4. data/README.md +244 -0
  5. data/SECURITY.md +27 -0
  6. data/lib/method_ruby/client.rb +114 -0
  7. data/lib/method_ruby/errors.rb +228 -0
  8. data/lib/method_ruby/file_part.rb +58 -0
  9. data/lib/method_ruby/internal/transport/base_client.rb +595 -0
  10. data/lib/method_ruby/internal/transport/pooled_net_requester.rb +210 -0
  11. data/lib/method_ruby/internal/type/array_of.rb +168 -0
  12. data/lib/method_ruby/internal/type/base_model.rb +531 -0
  13. data/lib/method_ruby/internal/type/base_page.rb +55 -0
  14. data/lib/method_ruby/internal/type/boolean.rb +77 -0
  15. data/lib/method_ruby/internal/type/converter.rb +327 -0
  16. data/lib/method_ruby/internal/type/enum.rb +131 -0
  17. data/lib/method_ruby/internal/type/file_input.rb +111 -0
  18. data/lib/method_ruby/internal/type/hash_of.rb +188 -0
  19. data/lib/method_ruby/internal/type/request_parameters.rb +42 -0
  20. data/lib/method_ruby/internal/type/union.rb +237 -0
  21. data/lib/method_ruby/internal/type/unknown.rb +81 -0
  22. data/lib/method_ruby/internal/util.rb +951 -0
  23. data/lib/method_ruby/internal.rb +20 -0
  24. data/lib/method_ruby/models/address.rb +45 -0
  25. data/lib/method_ruby/models/entity.rb +102 -0
  26. data/lib/method_ruby/models/entity_corporation.rb +33 -0
  27. data/lib/method_ruby/models/entity_corporation_owner.rb +45 -0
  28. data/lib/method_ruby/models/entity_create_params.rb +188 -0
  29. data/lib/method_ruby/models/entity_create_response.rb +32 -0
  30. data/lib/method_ruby/models/entity_individual.rb +39 -0
  31. data/lib/method_ruby/models/entity_list_params.rb +61 -0
  32. data/lib/method_ruby/models/entity_list_response.rb +32 -0
  33. data/lib/method_ruby/models/entity_retrieve_params.rb +37 -0
  34. data/lib/method_ruby/models/entity_retrieve_response.rb +32 -0
  35. data/lib/method_ruby/models/entity_update_params.rb +75 -0
  36. data/lib/method_ruby/models/entity_update_response.rb +32 -0
  37. data/lib/method_ruby/models/ping_check_params.rb +14 -0
  38. data/lib/method_ruby/models/ping_check_response.rb +49 -0
  39. data/lib/method_ruby/models/resource_error.rb +33 -0
  40. data/lib/method_ruby/models.rb +63 -0
  41. data/lib/method_ruby/request_options.rb +77 -0
  42. data/lib/method_ruby/resources/entities.rb +141 -0
  43. data/lib/method_ruby/resources/ping.rb +34 -0
  44. data/lib/method_ruby/version.rb +5 -0
  45. data/lib/method_ruby.rb +73 -0
  46. data/manifest.yaml +17 -0
  47. data/rbi/method_ruby/client.rbi +85 -0
  48. data/rbi/method_ruby/errors.rbi +205 -0
  49. data/rbi/method_ruby/file_part.rbi +37 -0
  50. data/rbi/method_ruby/internal/transport/base_client.rbi +303 -0
  51. data/rbi/method_ruby/internal/transport/pooled_net_requester.rbi +84 -0
  52. data/rbi/method_ruby/internal/type/array_of.rbi +104 -0
  53. data/rbi/method_ruby/internal/type/base_model.rbi +308 -0
  54. data/rbi/method_ruby/internal/type/base_page.rbi +42 -0
  55. data/rbi/method_ruby/internal/type/boolean.rbi +58 -0
  56. data/rbi/method_ruby/internal/type/converter.rbi +216 -0
  57. data/rbi/method_ruby/internal/type/enum.rbi +82 -0
  58. data/rbi/method_ruby/internal/type/file_input.rbi +59 -0
  59. data/rbi/method_ruby/internal/type/hash_of.rbi +104 -0
  60. data/rbi/method_ruby/internal/type/request_parameters.rbi +29 -0
  61. data/rbi/method_ruby/internal/type/union.rbi +128 -0
  62. data/rbi/method_ruby/internal/type/unknown.rbi +58 -0
  63. data/rbi/method_ruby/internal/util.rbi +507 -0
  64. data/rbi/method_ruby/internal.rbi +18 -0
  65. data/rbi/method_ruby/models/address.rbi +63 -0
  66. data/rbi/method_ruby/models/entity.rbi +151 -0
  67. data/rbi/method_ruby/models/entity_corporation.rbi +61 -0
  68. data/rbi/method_ruby/models/entity_corporation_owner.rbi +86 -0
  69. data/rbi/method_ruby/models/entity_create_params.rbi +408 -0
  70. data/rbi/method_ruby/models/entity_create_response.rbi +84 -0
  71. data/rbi/method_ruby/models/entity_individual.rbi +65 -0
  72. data/rbi/method_ruby/models/entity_list_params.rbi +132 -0
  73. data/rbi/method_ruby/models/entity_list_response.rbi +84 -0
  74. data/rbi/method_ruby/models/entity_retrieve_params.rbi +93 -0
  75. data/rbi/method_ruby/models/entity_retrieve_response.rbi +89 -0
  76. data/rbi/method_ruby/models/entity_update_params.rbi +141 -0
  77. data/rbi/method_ruby/models/entity_update_response.rbi +84 -0
  78. data/rbi/method_ruby/models/ping_check_params.rbi +27 -0
  79. data/rbi/method_ruby/models/ping_check_response.rbi +118 -0
  80. data/rbi/method_ruby/models/resource_error.rbi +55 -0
  81. data/rbi/method_ruby/models.rbi +25 -0
  82. data/rbi/method_ruby/request_options.rbi +59 -0
  83. data/rbi/method_ruby/resources/entities.rbi +119 -0
  84. data/rbi/method_ruby/resources/ping.rbi +22 -0
  85. data/rbi/method_ruby/version.rbi +5 -0
  86. data/sig/method_ruby/client.rbs +39 -0
  87. data/sig/method_ruby/errors.rbs +117 -0
  88. data/sig/method_ruby/file_part.rbs +21 -0
  89. data/sig/method_ruby/internal/transport/base_client.rbs +135 -0
  90. data/sig/method_ruby/internal/transport/pooled_net_requester.rbs +48 -0
  91. data/sig/method_ruby/internal/type/array_of.rbs +48 -0
  92. data/sig/method_ruby/internal/type/base_model.rbs +102 -0
  93. data/sig/method_ruby/internal/type/base_page.rbs +24 -0
  94. data/sig/method_ruby/internal/type/boolean.rbs +26 -0
  95. data/sig/method_ruby/internal/type/converter.rbs +79 -0
  96. data/sig/method_ruby/internal/type/enum.rbs +32 -0
  97. data/sig/method_ruby/internal/type/file_input.rbs +25 -0
  98. data/sig/method_ruby/internal/type/hash_of.rbs +48 -0
  99. data/sig/method_ruby/internal/type/request_parameters.rbs +19 -0
  100. data/sig/method_ruby/internal/type/union.rbs +52 -0
  101. data/sig/method_ruby/internal/type/unknown.rbs +26 -0
  102. data/sig/method_ruby/internal/util.rbs +195 -0
  103. data/sig/method_ruby/internal.rbs +9 -0
  104. data/sig/method_ruby/models/address.rbs +40 -0
  105. data/sig/method_ruby/models/entity.rbs +94 -0
  106. data/sig/method_ruby/models/entity_corporation.rbs +43 -0
  107. data/sig/method_ruby/models/entity_corporation_owner.rbs +57 -0
  108. data/sig/method_ruby/models/entity_create_params.rbs +215 -0
  109. data/sig/method_ruby/models/entity_create_response.rbs +41 -0
  110. data/sig/method_ruby/models/entity_individual.rbs +44 -0
  111. data/sig/method_ruby/models/entity_list_params.rbs +77 -0
  112. data/sig/method_ruby/models/entity_list_response.rbs +41 -0
  113. data/sig/method_ruby/models/entity_retrieve_params.rbs +47 -0
  114. data/sig/method_ruby/models/entity_retrieve_response.rbs +41 -0
  115. data/sig/method_ruby/models/entity_update_params.rbs +84 -0
  116. data/sig/method_ruby/models/entity_update_response.rbs +41 -0
  117. data/sig/method_ruby/models/ping_check_params.rbs +15 -0
  118. data/sig/method_ruby/models/ping_check_response.rbs +59 -0
  119. data/sig/method_ruby/models/resource_error.rbs +38 -0
  120. data/sig/method_ruby/models.rbs +23 -0
  121. data/sig/method_ruby/request_options.rbs +36 -0
  122. data/sig/method_ruby/resources/entities.rbs +41 -0
  123. data/sig/method_ruby/resources/ping.rbs +11 -0
  124. data/sig/method_ruby/version.rbs +3 -0
  125. metadata +196 -0
@@ -0,0 +1,507 @@
1
+ # typed: strong
2
+
3
+ module MethodRuby
4
+ module Internal
5
+ # @api private
6
+ module Util
7
+ extend MethodRuby::Internal::Util::SorbetRuntimeSupport
8
+
9
+ # @api private
10
+ sig { returns(Float) }
11
+ def self.monotonic_secs
12
+ end
13
+
14
+ # @api private
15
+ sig do
16
+ params(ns: T.any(Module, T::Class[T.anything])).returns(
17
+ T::Enumerable[T.any(Module, T::Class[T.anything])]
18
+ )
19
+ end
20
+ def self.walk_namespaces(ns)
21
+ end
22
+
23
+ class << self
24
+ # @api private
25
+ sig { returns(String) }
26
+ def arch
27
+ end
28
+
29
+ # @api private
30
+ sig { returns(String) }
31
+ def os
32
+ end
33
+ end
34
+
35
+ class << self
36
+ # @api private
37
+ sig { params(input: T.anything).returns(T::Boolean) }
38
+ def primitive?(input)
39
+ end
40
+
41
+ # @api private
42
+ sig do
43
+ params(input: T.any(String, T::Boolean)).returns(
44
+ T.any(T::Boolean, T.anything)
45
+ )
46
+ end
47
+ def coerce_boolean(input)
48
+ end
49
+
50
+ # @api private
51
+ sig do
52
+ params(input: T.any(String, T::Boolean)).returns(
53
+ T.nilable(T::Boolean)
54
+ )
55
+ end
56
+ def coerce_boolean!(input)
57
+ end
58
+
59
+ # @api private
60
+ sig do
61
+ params(input: T.any(String, Integer)).returns(
62
+ T.any(Integer, T.anything)
63
+ )
64
+ end
65
+ def coerce_integer(input)
66
+ end
67
+
68
+ # @api private
69
+ sig do
70
+ params(input: T.any(String, Integer, Float)).returns(
71
+ T.any(Float, T.anything)
72
+ )
73
+ end
74
+ def coerce_float(input)
75
+ end
76
+
77
+ # @api private
78
+ sig do
79
+ params(input: T.anything).returns(
80
+ T.any(T::Hash[T.anything, T.anything], T.anything)
81
+ )
82
+ end
83
+ def coerce_hash(input)
84
+ end
85
+
86
+ # @api private
87
+ sig do
88
+ params(input: T.anything).returns(
89
+ T.nilable(T::Hash[T.anything, T.anything])
90
+ )
91
+ end
92
+ def coerce_hash!(input)
93
+ end
94
+ end
95
+
96
+ class << self
97
+ # @api private
98
+ sig do
99
+ params(lhs: T.anything, rhs: T.anything, concat: T::Boolean).returns(
100
+ T.anything
101
+ )
102
+ end
103
+ private def deep_merge_lr(lhs, rhs, concat: false)
104
+ end
105
+
106
+ # @api private
107
+ #
108
+ # Recursively merge one hash with another. If the values at a given key are not
109
+ # both hashes, just take the new value.
110
+ sig do
111
+ params(
112
+ values: T::Array[T.anything],
113
+ sentinel: T.nilable(T.anything),
114
+ concat: T::Boolean
115
+ ).returns(T.anything)
116
+ end
117
+ def deep_merge(
118
+ *values,
119
+ # the value to return if no values are provided.
120
+ sentinel: nil,
121
+ # whether to merge sequences by concatenation.
122
+ concat: false
123
+ )
124
+ end
125
+
126
+ # @api private
127
+ sig do
128
+ params(
129
+ data:
130
+ T.any(
131
+ MethodRuby::Internal::AnyHash,
132
+ T::Array[T.anything],
133
+ T.anything
134
+ ),
135
+ pick:
136
+ T.nilable(
137
+ T.any(
138
+ Symbol,
139
+ Integer,
140
+ T::Array[T.any(Symbol, Integer)],
141
+ T.proc.params(arg0: T.anything).returns(T.anything)
142
+ )
143
+ ),
144
+ blk: T.nilable(T.proc.returns(T.anything))
145
+ ).returns(T.nilable(T.anything))
146
+ end
147
+ def dig(data, pick, &blk)
148
+ end
149
+ end
150
+
151
+ class << self
152
+ # @api private
153
+ sig { params(uri: URI::Generic).returns(String) }
154
+ def uri_origin(uri)
155
+ end
156
+
157
+ # @api private
158
+ sig { params(path: T.any(String, T::Array[String])).returns(String) }
159
+ def interpolate_path(path)
160
+ end
161
+ end
162
+
163
+ class << self
164
+ # @api private
165
+ sig do
166
+ params(query: T.nilable(String)).returns(
167
+ T::Hash[String, T::Array[String]]
168
+ )
169
+ end
170
+ def decode_query(query)
171
+ end
172
+
173
+ # @api private
174
+ sig do
175
+ params(
176
+ query:
177
+ T.nilable(
178
+ T::Hash[String, T.nilable(T.any(T::Array[String], String))]
179
+ )
180
+ ).returns(T.nilable(String))
181
+ end
182
+ def encode_query(query)
183
+ end
184
+ end
185
+
186
+ ParsedUri =
187
+ T.type_alias do
188
+ {
189
+ scheme: T.nilable(String),
190
+ host: T.nilable(String),
191
+ port: T.nilable(Integer),
192
+ path: T.nilable(String),
193
+ query: T::Hash[String, T::Array[String]]
194
+ }
195
+ end
196
+
197
+ class << self
198
+ # @api private
199
+ sig do
200
+ params(url: T.any(URI::Generic, String)).returns(
201
+ MethodRuby::Internal::Util::ParsedUri
202
+ )
203
+ end
204
+ def parse_uri(url)
205
+ end
206
+
207
+ # @api private
208
+ sig do
209
+ params(parsed: MethodRuby::Internal::Util::ParsedUri).returns(
210
+ URI::Generic
211
+ )
212
+ end
213
+ def unparse_uri(parsed)
214
+ end
215
+
216
+ # @api private
217
+ sig do
218
+ params(
219
+ lhs: MethodRuby::Internal::Util::ParsedUri,
220
+ rhs: MethodRuby::Internal::Util::ParsedUri
221
+ ).returns(URI::Generic)
222
+ end
223
+ def join_parsed_uri(lhs, rhs)
224
+ end
225
+ end
226
+
227
+ class << self
228
+ # @api private
229
+ sig do
230
+ params(
231
+ headers:
232
+ T::Hash[
233
+ String,
234
+ T.nilable(
235
+ T.any(
236
+ String,
237
+ Integer,
238
+ T::Array[T.nilable(T.any(String, Integer))]
239
+ )
240
+ )
241
+ ]
242
+ ).returns(T::Hash[String, String])
243
+ end
244
+ def normalized_headers(*headers)
245
+ end
246
+ end
247
+
248
+ # @api private
249
+ #
250
+ # An adapter that satisfies the IO interface required by `::IO.copy_stream`
251
+ class ReadIOAdapter
252
+ # @api private
253
+ sig { returns(T.nilable(T::Boolean)) }
254
+ def close?
255
+ end
256
+
257
+ # @api private
258
+ sig { void }
259
+ def close
260
+ end
261
+
262
+ # @api private
263
+ sig { params(max_len: T.nilable(Integer)).returns(String) }
264
+ private def read_enum(max_len)
265
+ end
266
+
267
+ # @api private
268
+ sig do
269
+ params(
270
+ max_len: T.nilable(Integer),
271
+ out_string: T.nilable(String)
272
+ ).returns(T.nilable(String))
273
+ end
274
+ def read(max_len = nil, out_string = nil)
275
+ end
276
+
277
+ # @api private
278
+ sig do
279
+ params(
280
+ src: T.any(String, Pathname, StringIO, T::Enumerable[String]),
281
+ blk: T.proc.params(arg0: String).void
282
+ ).returns(T.attached_class)
283
+ end
284
+ def self.new(src, &blk)
285
+ end
286
+ end
287
+
288
+ class << self
289
+ sig do
290
+ params(blk: T.proc.params(y: Enumerator::Yielder).void).returns(
291
+ T::Enumerable[String]
292
+ )
293
+ end
294
+ def writable_enum(&blk)
295
+ end
296
+ end
297
+
298
+ JSON_CONTENT =
299
+ T.let(%r{^application/(?:[a-zA-Z0-9.-]+\+)?json(?!l)}, Regexp)
300
+ JSONL_CONTENT =
301
+ T.let(%r{^application/(:?x-(?:n|l)djson)|(:?(?:x-)?jsonl)}, Regexp)
302
+
303
+ class << self
304
+ # @api private
305
+ sig do
306
+ params(query: MethodRuby::Internal::AnyHash).returns(
307
+ MethodRuby::Internal::AnyHash
308
+ )
309
+ end
310
+ def encode_query_params(query)
311
+ end
312
+
313
+ # @api private
314
+ sig do
315
+ params(
316
+ collection: MethodRuby::Internal::AnyHash,
317
+ key: String,
318
+ element: T.anything
319
+ ).void
320
+ end
321
+ private def write_query_param_element!(collection, key, element)
322
+ end
323
+
324
+ # @api private
325
+ sig do
326
+ params(
327
+ y: Enumerator::Yielder,
328
+ val: T.anything,
329
+ closing: T::Array[T.proc.void],
330
+ content_type: T.nilable(String)
331
+ ).void
332
+ end
333
+ private def write_multipart_content(
334
+ y,
335
+ val:,
336
+ closing:,
337
+ content_type: nil
338
+ )
339
+ end
340
+
341
+ # @api private
342
+ sig do
343
+ params(
344
+ y: Enumerator::Yielder,
345
+ boundary: String,
346
+ key: T.any(Symbol, String),
347
+ val: T.anything,
348
+ closing: T::Array[T.proc.void]
349
+ ).void
350
+ end
351
+ private def write_multipart_chunk(y, boundary:, key:, val:, closing:)
352
+ end
353
+
354
+ # @api private
355
+ #
356
+ # https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.1.md#special-considerations-for-multipart-content
357
+ sig do
358
+ params(body: T.anything).returns([String, T::Enumerable[String]])
359
+ end
360
+ private def encode_multipart_streaming(body)
361
+ end
362
+
363
+ # @api private
364
+ sig do
365
+ params(headers: T::Hash[String, String], body: T.anything).returns(
366
+ T.anything
367
+ )
368
+ end
369
+ def encode_content(headers, body)
370
+ end
371
+
372
+ # @api private
373
+ #
374
+ # https://www.iana.org/assignments/character-sets/character-sets.xhtml
375
+ sig { params(content_type: String, text: String).void }
376
+ def force_charset!(content_type, text:)
377
+ end
378
+
379
+ # @api private
380
+ #
381
+ # Assumes each chunk in stream has `Encoding::BINARY`.
382
+ sig do
383
+ params(
384
+ headers: T::Hash[String, String],
385
+ stream: T::Enumerable[String],
386
+ suppress_error: T::Boolean
387
+ ).returns(T.anything)
388
+ end
389
+ def decode_content(headers, stream:, suppress_error: false)
390
+ end
391
+ end
392
+
393
+ class << self
394
+ # @api private
395
+ #
396
+ # https://doc.rust-lang.org/std/iter/trait.FusedIterator.html
397
+ sig do
398
+ params(
399
+ enum: T::Enumerable[T.anything],
400
+ external: T::Boolean,
401
+ close: T.proc.void
402
+ ).returns(T::Enumerable[T.anything])
403
+ end
404
+ def fused_enum(enum, external: false, &close)
405
+ end
406
+
407
+ # @api private
408
+ sig { params(enum: T.nilable(T::Enumerable[T.anything])).void }
409
+ def close_fused!(enum)
410
+ end
411
+
412
+ # @api private
413
+ sig do
414
+ params(
415
+ enum: T.nilable(T::Enumerable[T.anything]),
416
+ blk: T.proc.params(arg0: Enumerator::Yielder).void
417
+ ).returns(T::Enumerable[T.anything])
418
+ end
419
+ def chain_fused(enum, &blk)
420
+ end
421
+ end
422
+
423
+ ServerSentEvent =
424
+ T.type_alias do
425
+ {
426
+ event: T.nilable(String),
427
+ data: T.nilable(String),
428
+ id: T.nilable(String),
429
+ retry: T.nilable(Integer)
430
+ }
431
+ end
432
+
433
+ class << self
434
+ # @api private
435
+ #
436
+ # Assumes Strings have been forced into having `Encoding::BINARY`.
437
+ #
438
+ # This decoder is responsible for reassembling lines split across multiple
439
+ # fragments.
440
+ sig do
441
+ params(enum: T::Enumerable[String]).returns(T::Enumerable[String])
442
+ end
443
+ def decode_lines(enum)
444
+ end
445
+
446
+ # @api private
447
+ #
448
+ # https://html.spec.whatwg.org/multipage/server-sent-events.html#parsing-an-event-stream
449
+ #
450
+ # Assumes that `lines` has been decoded with `#decode_lines`.
451
+ sig do
452
+ params(lines: T::Enumerable[String]).returns(
453
+ T::Enumerable[MethodRuby::Internal::Util::ServerSentEvent]
454
+ )
455
+ end
456
+ def decode_sse(lines)
457
+ end
458
+ end
459
+
460
+ # @api private
461
+ module SorbetRuntimeSupport
462
+ class MissingSorbetRuntimeError < ::RuntimeError
463
+ end
464
+
465
+ # @api private
466
+ sig { returns(T::Hash[Symbol, T.anything]) }
467
+ private def sorbet_runtime_constants
468
+ end
469
+
470
+ # @api private
471
+ sig { params(name: Symbol).void }
472
+ def const_missing(name)
473
+ end
474
+
475
+ # @api private
476
+ sig { params(name: Symbol).returns(T::Boolean) }
477
+ def sorbet_constant_defined?(name)
478
+ end
479
+
480
+ # @api private
481
+ sig { params(name: Symbol, blk: T.proc.returns(T.anything)).void }
482
+ def define_sorbet_constant!(name, &blk)
483
+ end
484
+
485
+ # @api private
486
+ sig { returns(T.anything) }
487
+ def to_sorbet_type
488
+ end
489
+
490
+ class << self
491
+ # @api private
492
+ sig do
493
+ params(
494
+ type:
495
+ T.any(
496
+ MethodRuby::Internal::Util::SorbetRuntimeSupport,
497
+ T.anything
498
+ )
499
+ ).returns(T.anything)
500
+ end
501
+ def to_sorbet_type(type)
502
+ end
503
+ end
504
+ end
505
+ end
506
+ end
507
+ end
@@ -0,0 +1,18 @@
1
+ # typed: strong
2
+
3
+ module MethodRuby
4
+ module Internal
5
+ extend MethodRuby::Internal::Util::SorbetRuntimeSupport
6
+
7
+ # Due to the current WIP status of Shapes support in Sorbet, types referencing
8
+ # this alias might be refined in the future.
9
+ AnyHash = T.type_alias { T::Hash[Symbol, T.anything] }
10
+
11
+ FileInput =
12
+ T.type_alias do
13
+ T.any(Pathname, StringIO, IO, String, MethodRuby::FilePart)
14
+ end
15
+
16
+ OMIT = T.let(Object.new.freeze, T.anything)
17
+ end
18
+ end
@@ -0,0 +1,63 @@
1
+ # typed: strong
2
+
3
+ module MethodRuby
4
+ module Models
5
+ class Address < MethodRuby::Internal::Type::BaseModel
6
+ OrHash =
7
+ T.type_alias do
8
+ T.any(MethodRuby::Address, MethodRuby::Internal::AnyHash)
9
+ end
10
+
11
+ sig { returns(T.nilable(String)) }
12
+ attr_accessor :city
13
+
14
+ # Street address line 1
15
+ sig { returns(T.nilable(String)) }
16
+ attr_accessor :line1
17
+
18
+ # Street address line 2
19
+ sig { returns(T.nilable(String)) }
20
+ attr_accessor :line2
21
+
22
+ sig { returns(T.nilable(String)) }
23
+ attr_accessor :state
24
+
25
+ sig { returns(T.nilable(String)) }
26
+ attr_accessor :zip
27
+
28
+ sig do
29
+ params(
30
+ city: T.nilable(String),
31
+ line1: T.nilable(String),
32
+ line2: T.nilable(String),
33
+ state: T.nilable(String),
34
+ zip: T.nilable(String)
35
+ ).returns(T.attached_class)
36
+ end
37
+ def self.new(
38
+ city: nil,
39
+ # Street address line 1
40
+ line1: nil,
41
+ # Street address line 2
42
+ line2: nil,
43
+ state: nil,
44
+ zip: nil
45
+ )
46
+ end
47
+
48
+ sig do
49
+ override.returns(
50
+ {
51
+ city: T.nilable(String),
52
+ line1: T.nilable(String),
53
+ line2: T.nilable(String),
54
+ state: T.nilable(String),
55
+ zip: T.nilable(String)
56
+ }
57
+ )
58
+ end
59
+ def to_hash
60
+ end
61
+ end
62
+ end
63
+ end