userplex 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 +14 -0
  4. data/README.md +217 -0
  5. data/SECURITY.md +23 -0
  6. data/lib/userplex/client.rb +80 -0
  7. data/lib/userplex/errors.rb +228 -0
  8. data/lib/userplex/file_part.rb +58 -0
  9. data/lib/userplex/internal/transport/base_client.rb +567 -0
  10. data/lib/userplex/internal/transport/pooled_net_requester.rb +198 -0
  11. data/lib/userplex/internal/type/array_of.rb +168 -0
  12. data/lib/userplex/internal/type/base_model.rb +530 -0
  13. data/lib/userplex/internal/type/base_page.rb +55 -0
  14. data/lib/userplex/internal/type/boolean.rb +77 -0
  15. data/lib/userplex/internal/type/converter.rb +327 -0
  16. data/lib/userplex/internal/type/enum.rb +131 -0
  17. data/lib/userplex/internal/type/file_input.rb +111 -0
  18. data/lib/userplex/internal/type/hash_of.rb +188 -0
  19. data/lib/userplex/internal/type/request_parameters.rb +42 -0
  20. data/lib/userplex/internal/type/union.rb +237 -0
  21. data/lib/userplex/internal/type/unknown.rb +81 -0
  22. data/lib/userplex/internal/util.rb +915 -0
  23. data/lib/userplex/internal.rb +20 -0
  24. data/lib/userplex/models/event_track_params.rb +46 -0
  25. data/lib/userplex/models/event_track_response.rb +33 -0
  26. data/lib/userplex/models/user_identify_params.rb +46 -0
  27. data/lib/userplex/models/user_identify_response.rb +25 -0
  28. data/lib/userplex/models.rb +45 -0
  29. data/lib/userplex/request_options.rb +77 -0
  30. data/lib/userplex/resources/events.rb +43 -0
  31. data/lib/userplex/resources/users.rb +43 -0
  32. data/lib/userplex/version.rb +5 -0
  33. data/lib/userplex.rb +59 -0
  34. data/manifest.yaml +15 -0
  35. data/rbi/userplex/client.rbi +54 -0
  36. data/rbi/userplex/errors.rbi +205 -0
  37. data/rbi/userplex/file_part.rbi +37 -0
  38. data/rbi/userplex/internal/transport/base_client.rbi +292 -0
  39. data/rbi/userplex/internal/transport/pooled_net_requester.rbi +79 -0
  40. data/rbi/userplex/internal/type/array_of.rbi +104 -0
  41. data/rbi/userplex/internal/type/base_model.rbi +302 -0
  42. data/rbi/userplex/internal/type/base_page.rbi +42 -0
  43. data/rbi/userplex/internal/type/boolean.rbi +58 -0
  44. data/rbi/userplex/internal/type/converter.rbi +216 -0
  45. data/rbi/userplex/internal/type/enum.rbi +82 -0
  46. data/rbi/userplex/internal/type/file_input.rbi +59 -0
  47. data/rbi/userplex/internal/type/hash_of.rbi +104 -0
  48. data/rbi/userplex/internal/type/request_parameters.rbi +29 -0
  49. data/rbi/userplex/internal/type/union.rbi +128 -0
  50. data/rbi/userplex/internal/type/unknown.rbi +58 -0
  51. data/rbi/userplex/internal/util.rbi +487 -0
  52. data/rbi/userplex/internal.rbi +16 -0
  53. data/rbi/userplex/models/event_track_params.rbi +73 -0
  54. data/rbi/userplex/models/event_track_response.rbi +52 -0
  55. data/rbi/userplex/models/user_identify_params.rbi +70 -0
  56. data/rbi/userplex/models/user_identify_response.rbi +38 -0
  57. data/rbi/userplex/models.rbi +7 -0
  58. data/rbi/userplex/request_options.rbi +59 -0
  59. data/rbi/userplex/resources/events.rbi +36 -0
  60. data/rbi/userplex/resources/users.rbi +36 -0
  61. data/rbi/userplex/version.rbi +5 -0
  62. data/sig/userplex/client.rbs +28 -0
  63. data/sig/userplex/errors.rbs +117 -0
  64. data/sig/userplex/file_part.rbs +21 -0
  65. data/sig/userplex/internal/transport/base_client.rbs +131 -0
  66. data/sig/userplex/internal/transport/pooled_net_requester.rbs +45 -0
  67. data/sig/userplex/internal/type/array_of.rbs +48 -0
  68. data/sig/userplex/internal/type/base_model.rbs +102 -0
  69. data/sig/userplex/internal/type/base_page.rbs +24 -0
  70. data/sig/userplex/internal/type/boolean.rbs +26 -0
  71. data/sig/userplex/internal/type/converter.rbs +79 -0
  72. data/sig/userplex/internal/type/enum.rbs +32 -0
  73. data/sig/userplex/internal/type/file_input.rbs +25 -0
  74. data/sig/userplex/internal/type/hash_of.rbs +48 -0
  75. data/sig/userplex/internal/type/request_parameters.rbs +17 -0
  76. data/sig/userplex/internal/type/union.rbs +52 -0
  77. data/sig/userplex/internal/type/unknown.rbs +26 -0
  78. data/sig/userplex/internal/util.rbs +185 -0
  79. data/sig/userplex/internal.rbs +9 -0
  80. data/sig/userplex/models/event_track_params.rbs +45 -0
  81. data/sig/userplex/models/event_track_response.rbs +22 -0
  82. data/sig/userplex/models/user_identify_params.rbs +43 -0
  83. data/sig/userplex/models/user_identify_response.rbs +15 -0
  84. data/sig/userplex/models.rbs +5 -0
  85. data/sig/userplex/request_options.rbs +34 -0
  86. data/sig/userplex/resources/events.rbs +15 -0
  87. data/sig/userplex/resources/users.rbs +15 -0
  88. data/sig/userplex/version.rbs +3 -0
  89. metadata +146 -0
@@ -0,0 +1,487 @@
1
+ # typed: strong
2
+
3
+ module Userplex
4
+ module Internal
5
+ # @api private
6
+ module Util
7
+ extend Userplex::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
+ Userplex::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
+ Userplex::Internal::Util::ParsedUri
202
+ )
203
+ end
204
+ def parse_uri(url)
205
+ end
206
+
207
+ # @api private
208
+ sig do
209
+ params(parsed: Userplex::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: Userplex::Internal::Util::ParsedUri,
220
+ rhs: Userplex::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/(?:vnd(?:\.[^.]+)*\+)?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(
307
+ y: Enumerator::Yielder,
308
+ val: T.anything,
309
+ closing: T::Array[T.proc.void],
310
+ content_type: T.nilable(String)
311
+ ).void
312
+ end
313
+ private def write_multipart_content(
314
+ y,
315
+ val:,
316
+ closing:,
317
+ content_type: nil
318
+ )
319
+ end
320
+
321
+ # @api private
322
+ sig do
323
+ params(
324
+ y: Enumerator::Yielder,
325
+ boundary: String,
326
+ key: T.any(Symbol, String),
327
+ val: T.anything,
328
+ closing: T::Array[T.proc.void]
329
+ ).void
330
+ end
331
+ private def write_multipart_chunk(y, boundary:, key:, val:, closing:)
332
+ end
333
+
334
+ # @api private
335
+ #
336
+ # https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.1.md#special-considerations-for-multipart-content
337
+ sig do
338
+ params(body: T.anything).returns([String, T::Enumerable[String]])
339
+ end
340
+ private def encode_multipart_streaming(body)
341
+ end
342
+
343
+ # @api private
344
+ sig do
345
+ params(headers: T::Hash[String, String], body: T.anything).returns(
346
+ T.anything
347
+ )
348
+ end
349
+ def encode_content(headers, body)
350
+ end
351
+
352
+ # @api private
353
+ #
354
+ # https://www.iana.org/assignments/character-sets/character-sets.xhtml
355
+ sig { params(content_type: String, text: String).void }
356
+ def force_charset!(content_type, text:)
357
+ end
358
+
359
+ # @api private
360
+ #
361
+ # Assumes each chunk in stream has `Encoding::BINARY`.
362
+ sig do
363
+ params(
364
+ headers: T::Hash[String, String],
365
+ stream: T::Enumerable[String],
366
+ suppress_error: T::Boolean
367
+ ).returns(T.anything)
368
+ end
369
+ def decode_content(headers, stream:, suppress_error: false)
370
+ end
371
+ end
372
+
373
+ class << self
374
+ # @api private
375
+ #
376
+ # https://doc.rust-lang.org/std/iter/trait.FusedIterator.html
377
+ sig do
378
+ params(
379
+ enum: T::Enumerable[T.anything],
380
+ external: T::Boolean,
381
+ close: T.proc.void
382
+ ).returns(T::Enumerable[T.anything])
383
+ end
384
+ def fused_enum(enum, external: false, &close)
385
+ end
386
+
387
+ # @api private
388
+ sig { params(enum: T.nilable(T::Enumerable[T.anything])).void }
389
+ def close_fused!(enum)
390
+ end
391
+
392
+ # @api private
393
+ sig do
394
+ params(
395
+ enum: T.nilable(T::Enumerable[T.anything]),
396
+ blk: T.proc.params(arg0: Enumerator::Yielder).void
397
+ ).returns(T::Enumerable[T.anything])
398
+ end
399
+ def chain_fused(enum, &blk)
400
+ end
401
+ end
402
+
403
+ ServerSentEvent =
404
+ T.type_alias do
405
+ {
406
+ event: T.nilable(String),
407
+ data: T.nilable(String),
408
+ id: T.nilable(String),
409
+ retry: T.nilable(Integer)
410
+ }
411
+ end
412
+
413
+ class << self
414
+ # @api private
415
+ #
416
+ # Assumes Strings have been forced into having `Encoding::BINARY`.
417
+ #
418
+ # This decoder is responsible for reassembling lines split across multiple
419
+ # fragments.
420
+ sig do
421
+ params(enum: T::Enumerable[String]).returns(T::Enumerable[String])
422
+ end
423
+ def decode_lines(enum)
424
+ end
425
+
426
+ # @api private
427
+ #
428
+ # https://html.spec.whatwg.org/multipage/server-sent-events.html#parsing-an-event-stream
429
+ #
430
+ # Assumes that `lines` has been decoded with `#decode_lines`.
431
+ sig do
432
+ params(lines: T::Enumerable[String]).returns(
433
+ T::Enumerable[Userplex::Internal::Util::ServerSentEvent]
434
+ )
435
+ end
436
+ def decode_sse(lines)
437
+ end
438
+ end
439
+
440
+ # @api private
441
+ module SorbetRuntimeSupport
442
+ class MissingSorbetRuntimeError < ::RuntimeError
443
+ end
444
+
445
+ # @api private
446
+ sig { returns(T::Hash[Symbol, T.anything]) }
447
+ private def sorbet_runtime_constants
448
+ end
449
+
450
+ # @api private
451
+ sig { params(name: Symbol).void }
452
+ def const_missing(name)
453
+ end
454
+
455
+ # @api private
456
+ sig { params(name: Symbol).returns(T::Boolean) }
457
+ def sorbet_constant_defined?(name)
458
+ end
459
+
460
+ # @api private
461
+ sig { params(name: Symbol, blk: T.proc.returns(T.anything)).void }
462
+ def define_sorbet_constant!(name, &blk)
463
+ end
464
+
465
+ # @api private
466
+ sig { returns(T.anything) }
467
+ def to_sorbet_type
468
+ end
469
+
470
+ class << self
471
+ # @api private
472
+ sig do
473
+ params(
474
+ type:
475
+ T.any(
476
+ Userplex::Internal::Util::SorbetRuntimeSupport,
477
+ T.anything
478
+ )
479
+ ).returns(T.anything)
480
+ end
481
+ def to_sorbet_type(type)
482
+ end
483
+ end
484
+ end
485
+ end
486
+ end
487
+ end
@@ -0,0 +1,16 @@
1
+ # typed: strong
2
+
3
+ module Userplex
4
+ module Internal
5
+ extend Userplex::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 { T.any(Pathname, StringIO, IO, String, Userplex::FilePart) }
13
+
14
+ OMIT = T.let(Object.new.freeze, T.anything)
15
+ end
16
+ end
@@ -0,0 +1,73 @@
1
+ # typed: strong
2
+
3
+ module Userplex
4
+ module Models
5
+ class EventTrackParams < Userplex::Internal::Type::BaseModel
6
+ extend Userplex::Internal::Type::RequestParameters::Converter
7
+ include Userplex::Internal::Type::RequestParameters
8
+
9
+ OrHash =
10
+ T.type_alias do
11
+ T.any(Userplex::EventTrackParams, Userplex::Internal::AnyHash)
12
+ end
13
+
14
+ # Event name
15
+ sig { returns(String) }
16
+ attr_accessor :event
17
+
18
+ # External user ID
19
+ sig { returns(String) }
20
+ attr_accessor :user_id
21
+
22
+ # Event metadata
23
+ sig { returns(T.nilable(T::Hash[Symbol, T.nilable(T.anything)])) }
24
+ attr_reader :properties
25
+
26
+ sig { params(properties: T::Hash[Symbol, T.nilable(T.anything)]).void }
27
+ attr_writer :properties
28
+
29
+ # Event timestamp (ISO 8601)
30
+ sig { returns(T.nilable(Time)) }
31
+ attr_reader :timestamp
32
+
33
+ sig { params(timestamp: Time).void }
34
+ attr_writer :timestamp
35
+
36
+ sig do
37
+ params(
38
+ event: String,
39
+ user_id: String,
40
+ properties: T::Hash[Symbol, T.nilable(T.anything)],
41
+ timestamp: Time,
42
+ request_options: Userplex::RequestOptions::OrHash
43
+ ).returns(T.attached_class)
44
+ end
45
+ def self.new(
46
+ # Event name
47
+ event:,
48
+ # External user ID
49
+ user_id:,
50
+ # Event metadata
51
+ properties: nil,
52
+ # Event timestamp (ISO 8601)
53
+ timestamp: nil,
54
+ request_options: {}
55
+ )
56
+ end
57
+
58
+ sig do
59
+ override.returns(
60
+ {
61
+ event: String,
62
+ user_id: String,
63
+ properties: T::Hash[Symbol, T.nilable(T.anything)],
64
+ timestamp: Time,
65
+ request_options: Userplex::RequestOptions
66
+ }
67
+ )
68
+ end
69
+ def to_hash
70
+ end
71
+ end
72
+ end
73
+ end
@@ -0,0 +1,52 @@
1
+ # typed: strong
2
+
3
+ module Userplex
4
+ module Models
5
+ class EventTrackResponse < Userplex::Internal::Type::BaseModel
6
+ OrHash =
7
+ T.type_alias do
8
+ T.any(
9
+ Userplex::Models::EventTrackResponse,
10
+ Userplex::Internal::AnyHash
11
+ )
12
+ end
13
+
14
+ # The event ID
15
+ sig { returns(String) }
16
+ attr_accessor :event_id
17
+
18
+ # The event occurrence ID
19
+ sig { returns(String) }
20
+ attr_accessor :occurrence_id
21
+
22
+ # Whether the operation was successful
23
+ sig { returns(T::Boolean) }
24
+ attr_accessor :success
25
+
26
+ sig do
27
+ params(
28
+ event_id: String,
29
+ occurrence_id: String,
30
+ success: T::Boolean
31
+ ).returns(T.attached_class)
32
+ end
33
+ def self.new(
34
+ # The event ID
35
+ event_id:,
36
+ # The event occurrence ID
37
+ occurrence_id:,
38
+ # Whether the operation was successful
39
+ success:
40
+ )
41
+ end
42
+
43
+ sig do
44
+ override.returns(
45
+ { event_id: String, occurrence_id: String, success: T::Boolean }
46
+ )
47
+ end
48
+ def to_hash
49
+ end
50
+ end
51
+ end
52
+ end
@@ -0,0 +1,70 @@
1
+ # typed: strong
2
+
3
+ module Userplex
4
+ module Models
5
+ class UserIdentifyParams < Userplex::Internal::Type::BaseModel
6
+ extend Userplex::Internal::Type::RequestParameters::Converter
7
+ include Userplex::Internal::Type::RequestParameters
8
+
9
+ OrHash =
10
+ T.type_alias do
11
+ T.any(Userplex::UserIdentifyParams, Userplex::Internal::AnyHash)
12
+ end
13
+
14
+ # User email address
15
+ sig { returns(String) }
16
+ attr_accessor :email
17
+
18
+ # User full name
19
+ sig { returns(String) }
20
+ attr_accessor :name
21
+
22
+ # Unique identifier for the user
23
+ sig { returns(String) }
24
+ attr_accessor :user_id
25
+
26
+ # Additional user properties
27
+ sig { returns(T.nilable(T::Hash[Symbol, T.nilable(T.anything)])) }
28
+ attr_reader :properties
29
+
30
+ sig { params(properties: T::Hash[Symbol, T.nilable(T.anything)]).void }
31
+ attr_writer :properties
32
+
33
+ sig do
34
+ params(
35
+ email: String,
36
+ name: String,
37
+ user_id: String,
38
+ properties: T::Hash[Symbol, T.nilable(T.anything)],
39
+ request_options: Userplex::RequestOptions::OrHash
40
+ ).returns(T.attached_class)
41
+ end
42
+ def self.new(
43
+ # User email address
44
+ email:,
45
+ # User full name
46
+ name:,
47
+ # Unique identifier for the user
48
+ user_id:,
49
+ # Additional user properties
50
+ properties: nil,
51
+ request_options: {}
52
+ )
53
+ end
54
+
55
+ sig do
56
+ override.returns(
57
+ {
58
+ email: String,
59
+ name: String,
60
+ user_id: String,
61
+ properties: T::Hash[Symbol, T.nilable(T.anything)],
62
+ request_options: Userplex::RequestOptions
63
+ }
64
+ )
65
+ end
66
+ def to_hash
67
+ end
68
+ end
69
+ end
70
+ end