react-native-nitro-sse 0.1.0-beta.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 (72) hide show
  1. package/LICENSE +21 -0
  2. package/NitroSse.podspec +30 -0
  3. package/README.md +121 -0
  4. package/android/CMakeLists.txt +24 -0
  5. package/android/build.gradle +120 -0
  6. package/android/src/main/AndroidManifest.xml +2 -0
  7. package/android/src/main/cpp/cpp-adapter.cpp +6 -0
  8. package/android/src/main/java/com/margelo/nitro/nitrosse/NitroSse.kt +279 -0
  9. package/android/src/main/java/com/margelo/nitro/nitrosse/NitroSsePackage.kt +22 -0
  10. package/ios/NitroSse.swift +311 -0
  11. package/lib/module/NitroSse.nitro.js +4 -0
  12. package/lib/module/NitroSse.nitro.js.map +1 -0
  13. package/lib/module/SseInterface.js +2 -0
  14. package/lib/module/SseInterface.js.map +1 -0
  15. package/lib/module/index.js +22 -0
  16. package/lib/module/index.js.map +1 -0
  17. package/lib/module/package.json +1 -0
  18. package/lib/typescript/package.json +1 -0
  19. package/lib/typescript/src/NitroSse.nitro.d.ts +34 -0
  20. package/lib/typescript/src/NitroSse.nitro.d.ts.map +1 -0
  21. package/lib/typescript/src/SseInterface.d.ts +25 -0
  22. package/lib/typescript/src/SseInterface.d.ts.map +1 -0
  23. package/lib/typescript/src/index.d.ts +5 -0
  24. package/lib/typescript/src/index.d.ts.map +1 -0
  25. package/nitro.json +17 -0
  26. package/nitrogen/generated/android/c++/JFunc_void_std__vector_SseEvent_.hpp +100 -0
  27. package/nitrogen/generated/android/c++/JHttpMethod.hpp +58 -0
  28. package/nitrogen/generated/android/c++/JHybridNitroSseSpec.cpp +110 -0
  29. package/nitrogen/generated/android/c++/JHybridNitroSseSpec.hpp +71 -0
  30. package/nitrogen/generated/android/c++/JSseConfig.hpp +98 -0
  31. package/nitrogen/generated/android/c++/JSseEvent.hpp +76 -0
  32. package/nitrogen/generated/android/c++/JSseEventType.hpp +67 -0
  33. package/nitrogen/generated/android/c++/JSseStats.hpp +70 -0
  34. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrosse/Func_void_std__vector_SseEvent_.kt +80 -0
  35. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrosse/HttpMethod.kt +23 -0
  36. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrosse/HybridNitroSseSpec.kt +82 -0
  37. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrosse/SseConfig.kt +56 -0
  38. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrosse/SseEvent.kt +50 -0
  39. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrosse/SseEventType.kt +26 -0
  40. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrosse/SseStats.kt +47 -0
  41. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrosse/nitrosseOnLoad.kt +35 -0
  42. package/nitrogen/generated/android/nitrosse+autolinking.cmake +81 -0
  43. package/nitrogen/generated/android/nitrosse+autolinking.gradle +27 -0
  44. package/nitrogen/generated/android/nitrosseOnLoad.cpp +46 -0
  45. package/nitrogen/generated/android/nitrosseOnLoad.hpp +25 -0
  46. package/nitrogen/generated/ios/NitroSse+autolinking.rb +60 -0
  47. package/nitrogen/generated/ios/NitroSse-Swift-Cxx-Bridge.cpp +41 -0
  48. package/nitrogen/generated/ios/NitroSse-Swift-Cxx-Bridge.hpp +210 -0
  49. package/nitrogen/generated/ios/NitroSse-Swift-Cxx-Umbrella.hpp +63 -0
  50. package/nitrogen/generated/ios/NitroSseAutolinking.mm +33 -0
  51. package/nitrogen/generated/ios/NitroSseAutolinking.swift +26 -0
  52. package/nitrogen/generated/ios/c++/HybridNitroSseSpecSwift.cpp +11 -0
  53. package/nitrogen/generated/ios/c++/HybridNitroSseSpecSwift.hpp +130 -0
  54. package/nitrogen/generated/ios/swift/Func_void_std__vector_SseEvent_.swift +46 -0
  55. package/nitrogen/generated/ios/swift/HttpMethod.swift +40 -0
  56. package/nitrogen/generated/ios/swift/HybridNitroSseSpec.swift +60 -0
  57. package/nitrogen/generated/ios/swift/HybridNitroSseSpec_cxx.swift +212 -0
  58. package/nitrogen/generated/ios/swift/SseConfig.swift +130 -0
  59. package/nitrogen/generated/ios/swift/SseEvent.swift +101 -0
  60. package/nitrogen/generated/ios/swift/SseEventType.swift +52 -0
  61. package/nitrogen/generated/ios/swift/SseStats.swift +63 -0
  62. package/nitrogen/generated/shared/c++/HttpMethod.hpp +76 -0
  63. package/nitrogen/generated/shared/c++/HybridNitroSseSpec.cpp +26 -0
  64. package/nitrogen/generated/shared/c++/HybridNitroSseSpec.hpp +78 -0
  65. package/nitrogen/generated/shared/c++/SseConfig.hpp +111 -0
  66. package/nitrogen/generated/shared/c++/SseEvent.hpp +102 -0
  67. package/nitrogen/generated/shared/c++/SseEventType.hpp +88 -0
  68. package/nitrogen/generated/shared/c++/SseStats.hpp +96 -0
  69. package/package.json +179 -0
  70. package/src/NitroSse.nitro.ts +37 -0
  71. package/src/SseInterface.ts +28 -0
  72. package/src/index.tsx +26 -0
@@ -0,0 +1,212 @@
1
+ ///
2
+ /// HybridNitroSseSpec_cxx.swift
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ import NitroModules
9
+
10
+ /**
11
+ * A class implementation that bridges HybridNitroSseSpec over to C++.
12
+ * In C++, we cannot use Swift protocols - so we need to wrap it in a class to make it strongly defined.
13
+ *
14
+ * Also, some Swift types need to be bridged with special handling:
15
+ * - Enums need to be wrapped in Structs, otherwise they cannot be accessed bi-directionally (Swift bug: https://github.com/swiftlang/swift/issues/75330)
16
+ * - Other HybridObjects need to be wrapped/unwrapped from the Swift TCxx wrapper
17
+ * - Throwing methods need to be wrapped with a Result<T, Error> type, as exceptions cannot be propagated to C++
18
+ */
19
+ open class HybridNitroSseSpec_cxx {
20
+ /**
21
+ * The Swift <> C++ bridge's namespace (`margelo::nitro::nitrosse::bridge::swift`)
22
+ * from `NitroSse-Swift-Cxx-Bridge.hpp`.
23
+ * This contains specialized C++ templates, and C++ helper functions that can be accessed from Swift.
24
+ */
25
+ public typealias bridge = margelo.nitro.nitrosse.bridge.swift
26
+
27
+ /**
28
+ * Holds an instance of the `HybridNitroSseSpec` Swift protocol.
29
+ */
30
+ private var __implementation: any HybridNitroSseSpec
31
+
32
+ /**
33
+ * Holds a weak pointer to the C++ class that wraps the Swift class.
34
+ */
35
+ private var __cxxPart: bridge.std__weak_ptr_HybridNitroSseSpec_
36
+
37
+ /**
38
+ * Create a new `HybridNitroSseSpec_cxx` that wraps the given `HybridNitroSseSpec`.
39
+ * All properties and methods bridge to C++ types.
40
+ */
41
+ public init(_ implementation: any HybridNitroSseSpec) {
42
+ self.__implementation = implementation
43
+ self.__cxxPart = .init()
44
+ /* no base class */
45
+ }
46
+
47
+ /**
48
+ * Get the actual `HybridNitroSseSpec` instance this class wraps.
49
+ */
50
+ @inline(__always)
51
+ public func getHybridNitroSseSpec() -> any HybridNitroSseSpec {
52
+ return __implementation
53
+ }
54
+
55
+ /**
56
+ * Casts this instance to a retained unsafe raw pointer.
57
+ * This acquires one additional strong reference on the object!
58
+ */
59
+ public func toUnsafe() -> UnsafeMutableRawPointer {
60
+ return Unmanaged.passRetained(self).toOpaque()
61
+ }
62
+
63
+ /**
64
+ * Casts an unsafe pointer to a `HybridNitroSseSpec_cxx`.
65
+ * The pointer has to be a retained opaque `Unmanaged<HybridNitroSseSpec_cxx>`.
66
+ * This removes one strong reference from the object!
67
+ */
68
+ public class func fromUnsafe(_ pointer: UnsafeMutableRawPointer) -> HybridNitroSseSpec_cxx {
69
+ return Unmanaged<HybridNitroSseSpec_cxx>.fromOpaque(pointer).takeRetainedValue()
70
+ }
71
+
72
+ /**
73
+ * Gets (or creates) the C++ part of this Hybrid Object.
74
+ * The C++ part is a `std::shared_ptr<HybridNitroSseSpec>`.
75
+ */
76
+ public func getCxxPart() -> bridge.std__shared_ptr_HybridNitroSseSpec_ {
77
+ let cachedCxxPart = self.__cxxPart.lock()
78
+ if Bool(fromCxx: cachedCxxPart) {
79
+ return cachedCxxPart
80
+ } else {
81
+ let newCxxPart = bridge.create_std__shared_ptr_HybridNitroSseSpec_(self.toUnsafe())
82
+ __cxxPart = bridge.weakify_std__shared_ptr_HybridNitroSseSpec_(newCxxPart)
83
+ return newCxxPart
84
+ }
85
+ }
86
+
87
+
88
+
89
+ /**
90
+ * Get the memory size of the Swift class (plus size of any other allocations)
91
+ * so the JS VM can properly track it and garbage-collect the JS object if needed.
92
+ */
93
+ @inline(__always)
94
+ public var memorySize: Int {
95
+ return MemoryHelper.getSizeOf(self.__implementation) + self.__implementation.memorySize
96
+ }
97
+
98
+ /**
99
+ * Compares this object with the given [other] object for reference equality.
100
+ */
101
+ @inline(__always)
102
+ public func equals(other: HybridNitroSseSpec_cxx) -> Bool {
103
+ return self.__implementation === other.__implementation
104
+ }
105
+
106
+ /**
107
+ * Call dispose() on the Swift class.
108
+ * This _may_ be called manually from JS.
109
+ */
110
+ @inline(__always)
111
+ public func dispose() {
112
+ self.__implementation.dispose()
113
+ }
114
+
115
+ /**
116
+ * Call toString() on the Swift class.
117
+ */
118
+ @inline(__always)
119
+ public func toString() -> String {
120
+ return self.__implementation.toString()
121
+ }
122
+
123
+ // Properties
124
+
125
+
126
+ // Methods
127
+ @inline(__always)
128
+ public final func setup(config: SseConfig, onEvent: bridge.Func_void_std__vector_SseEvent_) -> bridge.Result_void_ {
129
+ do {
130
+ try self.__implementation.setup(config: config, onEvent: { () -> ([SseEvent]) -> Void in
131
+ let __wrappedFunction = bridge.wrap_Func_void_std__vector_SseEvent_(onEvent)
132
+ return { (__events: [SseEvent]) -> Void in
133
+ __wrappedFunction.call({ () -> bridge.std__vector_SseEvent_ in
134
+ var __vector = bridge.create_std__vector_SseEvent_(__events.count)
135
+ for __item in __events {
136
+ __vector.push_back(__item)
137
+ }
138
+ return __vector
139
+ }())
140
+ }
141
+ }())
142
+ return bridge.create_Result_void_()
143
+ } catch (let __error) {
144
+ let __exceptionPtr = __error.toCpp()
145
+ return bridge.create_Result_void_(__exceptionPtr)
146
+ }
147
+ }
148
+
149
+ @inline(__always)
150
+ public final func start() -> bridge.Result_void_ {
151
+ do {
152
+ try self.__implementation.start()
153
+ return bridge.create_Result_void_()
154
+ } catch (let __error) {
155
+ let __exceptionPtr = __error.toCpp()
156
+ return bridge.create_Result_void_(__exceptionPtr)
157
+ }
158
+ }
159
+
160
+ @inline(__always)
161
+ public final func stop() -> bridge.Result_void_ {
162
+ do {
163
+ try self.__implementation.stop()
164
+ return bridge.create_Result_void_()
165
+ } catch (let __error) {
166
+ let __exceptionPtr = __error.toCpp()
167
+ return bridge.create_Result_void_(__exceptionPtr)
168
+ }
169
+ }
170
+
171
+ @inline(__always)
172
+ public final func setLastProcessedId(id: std.string) -> bridge.Result_void_ {
173
+ do {
174
+ try self.__implementation.setLastProcessedId(id: String(id))
175
+ return bridge.create_Result_void_()
176
+ } catch (let __error) {
177
+ let __exceptionPtr = __error.toCpp()
178
+ return bridge.create_Result_void_(__exceptionPtr)
179
+ }
180
+ }
181
+
182
+ @inline(__always)
183
+ public final func updateHeaders(headers: bridge.std__unordered_map_std__string__std__string_) -> bridge.Result_void_ {
184
+ do {
185
+ try self.__implementation.updateHeaders(headers: { () -> Dictionary<String, String> in
186
+ var __dictionary = Dictionary<String, String>(minimumCapacity: headers.size())
187
+ let __keys = bridge.get_std__unordered_map_std__string__std__string__keys(headers)
188
+ for __key in __keys {
189
+ let __value = bridge.get_std__unordered_map_std__string__std__string__value(headers, __key)
190
+ __dictionary[String(__key)] = String(__value)
191
+ }
192
+ return __dictionary
193
+ }())
194
+ return bridge.create_Result_void_()
195
+ } catch (let __error) {
196
+ let __exceptionPtr = __error.toCpp()
197
+ return bridge.create_Result_void_(__exceptionPtr)
198
+ }
199
+ }
200
+
201
+ @inline(__always)
202
+ public final func getStats() -> bridge.Result_SseStats_ {
203
+ do {
204
+ let __result = try self.__implementation.getStats()
205
+ let __resultCpp = __result
206
+ return bridge.create_Result_SseStats_(__resultCpp)
207
+ } catch (let __error) {
208
+ let __exceptionPtr = __error.toCpp()
209
+ return bridge.create_Result_SseStats_(__exceptionPtr)
210
+ }
211
+ }
212
+ }
@@ -0,0 +1,130 @@
1
+ ///
2
+ /// SseConfig.swift
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ import NitroModules
9
+
10
+ /**
11
+ * Represents an instance of `SseConfig`, backed by a C++ struct.
12
+ */
13
+ public typealias SseConfig = margelo.nitro.nitrosse.SseConfig
14
+
15
+ public extension SseConfig {
16
+ private typealias bridge = margelo.nitro.nitrosse.bridge.swift
17
+
18
+ /**
19
+ * Create a new instance of `SseConfig`.
20
+ */
21
+ init(url: String, method: HttpMethod?, headers: Dictionary<String, String>?, body: String?, backgroundExecution: Bool?, batchingIntervalMs: Double?, maxBufferSize: Double?) {
22
+ self.init(std.string(url), { () -> bridge.std__optional_HttpMethod_ in
23
+ if let __unwrappedValue = method {
24
+ return bridge.create_std__optional_HttpMethod_(__unwrappedValue)
25
+ } else {
26
+ return .init()
27
+ }
28
+ }(), { () -> bridge.std__optional_std__unordered_map_std__string__std__string__ in
29
+ if let __unwrappedValue = headers {
30
+ return bridge.create_std__optional_std__unordered_map_std__string__std__string__({ () -> bridge.std__unordered_map_std__string__std__string_ in
31
+ var __map = bridge.create_std__unordered_map_std__string__std__string_(__unwrappedValue.count)
32
+ for (__k, __v) in __unwrappedValue {
33
+ bridge.emplace_std__unordered_map_std__string__std__string_(&__map, std.string(__k), std.string(__v))
34
+ }
35
+ return __map
36
+ }())
37
+ } else {
38
+ return .init()
39
+ }
40
+ }(), { () -> bridge.std__optional_std__string_ in
41
+ if let __unwrappedValue = body {
42
+ return bridge.create_std__optional_std__string_(std.string(__unwrappedValue))
43
+ } else {
44
+ return .init()
45
+ }
46
+ }(), { () -> bridge.std__optional_bool_ in
47
+ if let __unwrappedValue = backgroundExecution {
48
+ return bridge.create_std__optional_bool_(__unwrappedValue)
49
+ } else {
50
+ return .init()
51
+ }
52
+ }(), { () -> bridge.std__optional_double_ in
53
+ if let __unwrappedValue = batchingIntervalMs {
54
+ return bridge.create_std__optional_double_(__unwrappedValue)
55
+ } else {
56
+ return .init()
57
+ }
58
+ }(), { () -> bridge.std__optional_double_ in
59
+ if let __unwrappedValue = maxBufferSize {
60
+ return bridge.create_std__optional_double_(__unwrappedValue)
61
+ } else {
62
+ return .init()
63
+ }
64
+ }())
65
+ }
66
+
67
+ @inline(__always)
68
+ var url: String {
69
+ return String(self.__url)
70
+ }
71
+
72
+ @inline(__always)
73
+ var method: HttpMethod? {
74
+ return self.__method.value
75
+ }
76
+
77
+ @inline(__always)
78
+ var headers: Dictionary<String, String>? {
79
+ return { () -> Dictionary<String, String>? in
80
+ if bridge.has_value_std__optional_std__unordered_map_std__string__std__string__(self.__headers) {
81
+ let __unwrapped = bridge.get_std__optional_std__unordered_map_std__string__std__string__(self.__headers)
82
+ return { () -> Dictionary<String, String> in
83
+ var __dictionary = Dictionary<String, String>(minimumCapacity: __unwrapped.size())
84
+ let __keys = bridge.get_std__unordered_map_std__string__std__string__keys(__unwrapped)
85
+ for __key in __keys {
86
+ let __value = bridge.get_std__unordered_map_std__string__std__string__value(__unwrapped, __key)
87
+ __dictionary[String(__key)] = String(__value)
88
+ }
89
+ return __dictionary
90
+ }()
91
+ } else {
92
+ return nil
93
+ }
94
+ }()
95
+ }
96
+
97
+ @inline(__always)
98
+ var body: String? {
99
+ return { () -> String? in
100
+ if bridge.has_value_std__optional_std__string_(self.__body) {
101
+ let __unwrapped = bridge.get_std__optional_std__string_(self.__body)
102
+ return String(__unwrapped)
103
+ } else {
104
+ return nil
105
+ }
106
+ }()
107
+ }
108
+
109
+ @inline(__always)
110
+ var backgroundExecution: Bool? {
111
+ return { () -> Bool? in
112
+ if bridge.has_value_std__optional_bool_(self.__backgroundExecution) {
113
+ let __unwrapped = bridge.get_std__optional_bool_(self.__backgroundExecution)
114
+ return __unwrapped
115
+ } else {
116
+ return nil
117
+ }
118
+ }()
119
+ }
120
+
121
+ @inline(__always)
122
+ var batchingIntervalMs: Double? {
123
+ return self.__batchingIntervalMs.value
124
+ }
125
+
126
+ @inline(__always)
127
+ var maxBufferSize: Double? {
128
+ return self.__maxBufferSize.value
129
+ }
130
+ }
@@ -0,0 +1,101 @@
1
+ ///
2
+ /// SseEvent.swift
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ import NitroModules
9
+
10
+ /**
11
+ * Represents an instance of `SseEvent`, backed by a C++ struct.
12
+ */
13
+ public typealias SseEvent = margelo.nitro.nitrosse.SseEvent
14
+
15
+ public extension SseEvent {
16
+ private typealias bridge = margelo.nitro.nitrosse.bridge.swift
17
+
18
+ /**
19
+ * Create a new instance of `SseEvent`.
20
+ */
21
+ init(type: SseEventType, data: String?, id: String?, event: String?, message: String?) {
22
+ self.init(type, { () -> bridge.std__optional_std__string_ in
23
+ if let __unwrappedValue = data {
24
+ return bridge.create_std__optional_std__string_(std.string(__unwrappedValue))
25
+ } else {
26
+ return .init()
27
+ }
28
+ }(), { () -> bridge.std__optional_std__string_ in
29
+ if let __unwrappedValue = id {
30
+ return bridge.create_std__optional_std__string_(std.string(__unwrappedValue))
31
+ } else {
32
+ return .init()
33
+ }
34
+ }(), { () -> bridge.std__optional_std__string_ in
35
+ if let __unwrappedValue = event {
36
+ return bridge.create_std__optional_std__string_(std.string(__unwrappedValue))
37
+ } else {
38
+ return .init()
39
+ }
40
+ }(), { () -> bridge.std__optional_std__string_ in
41
+ if let __unwrappedValue = message {
42
+ return bridge.create_std__optional_std__string_(std.string(__unwrappedValue))
43
+ } else {
44
+ return .init()
45
+ }
46
+ }())
47
+ }
48
+
49
+ @inline(__always)
50
+ var type: SseEventType {
51
+ return self.__type
52
+ }
53
+
54
+ @inline(__always)
55
+ var data: String? {
56
+ return { () -> String? in
57
+ if bridge.has_value_std__optional_std__string_(self.__data) {
58
+ let __unwrapped = bridge.get_std__optional_std__string_(self.__data)
59
+ return String(__unwrapped)
60
+ } else {
61
+ return nil
62
+ }
63
+ }()
64
+ }
65
+
66
+ @inline(__always)
67
+ var id: String? {
68
+ return { () -> String? in
69
+ if bridge.has_value_std__optional_std__string_(self.__id) {
70
+ let __unwrapped = bridge.get_std__optional_std__string_(self.__id)
71
+ return String(__unwrapped)
72
+ } else {
73
+ return nil
74
+ }
75
+ }()
76
+ }
77
+
78
+ @inline(__always)
79
+ var event: String? {
80
+ return { () -> String? in
81
+ if bridge.has_value_std__optional_std__string_(self.__event) {
82
+ let __unwrapped = bridge.get_std__optional_std__string_(self.__event)
83
+ return String(__unwrapped)
84
+ } else {
85
+ return nil
86
+ }
87
+ }()
88
+ }
89
+
90
+ @inline(__always)
91
+ var message: String? {
92
+ return { () -> String? in
93
+ if bridge.has_value_std__optional_std__string_(self.__message) {
94
+ let __unwrapped = bridge.get_std__optional_std__string_(self.__message)
95
+ return String(__unwrapped)
96
+ } else {
97
+ return nil
98
+ }
99
+ }()
100
+ }
101
+ }
@@ -0,0 +1,52 @@
1
+ ///
2
+ /// SseEventType.swift
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ /**
9
+ * Represents the JS union `SseEventType`, backed by a C++ enum.
10
+ */
11
+ public typealias SseEventType = margelo.nitro.nitrosse.SseEventType
12
+
13
+ public extension SseEventType {
14
+ /**
15
+ * Get a SseEventType for the given String value, or
16
+ * return `nil` if the given value was invalid/unknown.
17
+ */
18
+ init?(fromString string: String) {
19
+ switch string {
20
+ case "open":
21
+ self = .open
22
+ case "message":
23
+ self = .message
24
+ case "error":
25
+ self = .error
26
+ case "close":
27
+ self = .close
28
+ case "heartbeat":
29
+ self = .heartbeat
30
+ default:
31
+ return nil
32
+ }
33
+ }
34
+
35
+ /**
36
+ * Get the String value this SseEventType represents.
37
+ */
38
+ var stringValue: String {
39
+ switch self {
40
+ case .open:
41
+ return "open"
42
+ case .message:
43
+ return "message"
44
+ case .error:
45
+ return "error"
46
+ case .close:
47
+ return "close"
48
+ case .heartbeat:
49
+ return "heartbeat"
50
+ }
51
+ }
52
+ }
@@ -0,0 +1,63 @@
1
+ ///
2
+ /// SseStats.swift
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ import NitroModules
9
+
10
+ /**
11
+ * Represents an instance of `SseStats`, backed by a C++ struct.
12
+ */
13
+ public typealias SseStats = margelo.nitro.nitrosse.SseStats
14
+
15
+ public extension SseStats {
16
+ private typealias bridge = margelo.nitro.nitrosse.bridge.swift
17
+
18
+ /**
19
+ * Create a new instance of `SseStats`.
20
+ */
21
+ init(totalBytesReceived: Double, reconnectCount: Double, lastErrorTime: Double?, lastErrorCode: String?) {
22
+ self.init(totalBytesReceived, reconnectCount, { () -> bridge.std__optional_double_ in
23
+ if let __unwrappedValue = lastErrorTime {
24
+ return bridge.create_std__optional_double_(__unwrappedValue)
25
+ } else {
26
+ return .init()
27
+ }
28
+ }(), { () -> bridge.std__optional_std__string_ in
29
+ if let __unwrappedValue = lastErrorCode {
30
+ return bridge.create_std__optional_std__string_(std.string(__unwrappedValue))
31
+ } else {
32
+ return .init()
33
+ }
34
+ }())
35
+ }
36
+
37
+ @inline(__always)
38
+ var totalBytesReceived: Double {
39
+ return self.__totalBytesReceived
40
+ }
41
+
42
+ @inline(__always)
43
+ var reconnectCount: Double {
44
+ return self.__reconnectCount
45
+ }
46
+
47
+ @inline(__always)
48
+ var lastErrorTime: Double? {
49
+ return self.__lastErrorTime.value
50
+ }
51
+
52
+ @inline(__always)
53
+ var lastErrorCode: String? {
54
+ return { () -> String? in
55
+ if bridge.has_value_std__optional_std__string_(self.__lastErrorCode) {
56
+ let __unwrapped = bridge.get_std__optional_std__string_(self.__lastErrorCode)
57
+ return String(__unwrapped)
58
+ } else {
59
+ return nil
60
+ }
61
+ }()
62
+ }
63
+ }
@@ -0,0 +1,76 @@
1
+ ///
2
+ /// HttpMethod.hpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #pragma once
9
+
10
+ #if __has_include(<NitroModules/NitroHash.hpp>)
11
+ #include <NitroModules/NitroHash.hpp>
12
+ #else
13
+ #error NitroModules cannot be found! Are you sure you installed NitroModules properly?
14
+ #endif
15
+ #if __has_include(<NitroModules/JSIConverter.hpp>)
16
+ #include <NitroModules/JSIConverter.hpp>
17
+ #else
18
+ #error NitroModules cannot be found! Are you sure you installed NitroModules properly?
19
+ #endif
20
+ #if __has_include(<NitroModules/NitroDefines.hpp>)
21
+ #include <NitroModules/NitroDefines.hpp>
22
+ #else
23
+ #error NitroModules cannot be found! Are you sure you installed NitroModules properly?
24
+ #endif
25
+
26
+ namespace margelo::nitro::nitrosse {
27
+
28
+ /**
29
+ * An enum which can be represented as a JavaScript union (HttpMethod).
30
+ */
31
+ enum class HttpMethod {
32
+ GET SWIFT_NAME(get) = 0,
33
+ POST SWIFT_NAME(post) = 1,
34
+ } CLOSED_ENUM;
35
+
36
+ } // namespace margelo::nitro::nitrosse
37
+
38
+ namespace margelo::nitro {
39
+
40
+ // C++ HttpMethod <> JS HttpMethod (union)
41
+ template <>
42
+ struct JSIConverter<margelo::nitro::nitrosse::HttpMethod> final {
43
+ static inline margelo::nitro::nitrosse::HttpMethod fromJSI(jsi::Runtime& runtime, const jsi::Value& arg) {
44
+ std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, arg);
45
+ switch (hashString(unionValue.c_str(), unionValue.size())) {
46
+ case hashString("get"): return margelo::nitro::nitrosse::HttpMethod::GET;
47
+ case hashString("post"): return margelo::nitro::nitrosse::HttpMethod::POST;
48
+ default: [[unlikely]]
49
+ throw std::invalid_argument("Cannot convert \"" + unionValue + "\" to enum HttpMethod - invalid value!");
50
+ }
51
+ }
52
+ static inline jsi::Value toJSI(jsi::Runtime& runtime, margelo::nitro::nitrosse::HttpMethod arg) {
53
+ switch (arg) {
54
+ case margelo::nitro::nitrosse::HttpMethod::GET: return JSIConverter<std::string>::toJSI(runtime, "get");
55
+ case margelo::nitro::nitrosse::HttpMethod::POST: return JSIConverter<std::string>::toJSI(runtime, "post");
56
+ default: [[unlikely]]
57
+ throw std::invalid_argument("Cannot convert HttpMethod to JS - invalid value: "
58
+ + std::to_string(static_cast<int>(arg)) + "!");
59
+ }
60
+ }
61
+ static inline bool canConvert(jsi::Runtime& runtime, const jsi::Value& value) {
62
+ if (!value.isString()) {
63
+ return false;
64
+ }
65
+ std::string unionValue = JSIConverter<std::string>::fromJSI(runtime, value);
66
+ switch (hashString(unionValue.c_str(), unionValue.size())) {
67
+ case hashString("get"):
68
+ case hashString("post"):
69
+ return true;
70
+ default:
71
+ return false;
72
+ }
73
+ }
74
+ };
75
+
76
+ } // namespace margelo::nitro
@@ -0,0 +1,26 @@
1
+ ///
2
+ /// HybridNitroSseSpec.cpp
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ #include "HybridNitroSseSpec.hpp"
9
+
10
+ namespace margelo::nitro::nitrosse {
11
+
12
+ void HybridNitroSseSpec::loadHybridMethods() {
13
+ // load base methods/properties
14
+ HybridObject::loadHybridMethods();
15
+ // load custom methods/properties
16
+ registerHybrids(this, [](Prototype& prototype) {
17
+ prototype.registerHybridMethod("setup", &HybridNitroSseSpec::setup);
18
+ prototype.registerHybridMethod("start", &HybridNitroSseSpec::start);
19
+ prototype.registerHybridMethod("stop", &HybridNitroSseSpec::stop);
20
+ prototype.registerHybridMethod("setLastProcessedId", &HybridNitroSseSpec::setLastProcessedId);
21
+ prototype.registerHybridMethod("updateHeaders", &HybridNitroSseSpec::updateHeaders);
22
+ prototype.registerHybridMethod("getStats", &HybridNitroSseSpec::getStats);
23
+ });
24
+ }
25
+
26
+ } // namespace margelo::nitro::nitrosse