react-native-nitro-net 0.1.5 → 0.3.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.
- package/README.md +122 -12
- package/android/libs/arm64-v8a/librust_c_net.so +0 -0
- package/android/libs/armeabi-v7a/librust_c_net.so +0 -0
- package/android/libs/x86/librust_c_net.so +0 -0
- package/android/libs/x86_64/librust_c_net.so +0 -0
- package/cpp/HybridHttpParser.hpp +67 -0
- package/cpp/HybridNetDriver.hpp +74 -0
- package/cpp/HybridNetServerDriver.hpp +16 -0
- package/cpp/HybridNetSocketDriver.hpp +176 -0
- package/cpp/NetBindings.hpp +67 -1
- package/ios/Frameworks/RustCNet.xcframework/ios-arm64/RustCNet.framework/RustCNet +0 -0
- package/ios/Frameworks/RustCNet.xcframework/ios-arm64_x86_64-simulator/RustCNet.framework/RustCNet +0 -0
- package/lib/Net.nitro.d.ts +46 -1
- package/lib/Net.nitro.js +3 -1
- package/lib/http.d.ts +203 -0
- package/lib/http.js +1138 -0
- package/lib/https.d.ts +24 -0
- package/lib/https.js +144 -0
- package/lib/index.d.ts +50 -11
- package/lib/index.js +179 -31
- package/lib/tls.d.ts +145 -0
- package/lib/tls.js +521 -0
- package/nitrogen/generated/android/RustCNet+autolinking.cmake +2 -0
- package/nitrogen/generated/android/RustCNetOnLoad.cpp +2 -0
- package/nitrogen/generated/android/c++/JHybridHttpParserSpec.cpp +54 -0
- package/nitrogen/generated/android/c++/JHybridHttpParserSpec.hpp +65 -0
- package/nitrogen/generated/android/c++/JHybridNetDriverSpec.cpp +47 -1
- package/nitrogen/generated/android/c++/JHybridNetDriverSpec.hpp +9 -0
- package/nitrogen/generated/android/c++/JHybridNetServerDriverSpec.cpp +8 -0
- package/nitrogen/generated/android/c++/JHybridNetServerDriverSpec.hpp +2 -0
- package/nitrogen/generated/android/c++/JHybridNetSocketDriverSpec.cpp +79 -0
- package/nitrogen/generated/android/c++/JHybridNetSocketDriverSpec.hpp +17 -0
- package/nitrogen/generated/android/c++/JNetConfig.hpp +7 -3
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/net/HybridHttpParserSpec.kt +58 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/net/HybridNetDriverSpec.kt +37 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/net/HybridNetServerDriverSpec.kt +8 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/net/HybridNetSocketDriverSpec.kt +68 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/net/NetConfig.kt +6 -3
- package/nitrogen/generated/ios/RustCNet-Swift-Cxx-Bridge.cpp +17 -0
- package/nitrogen/generated/ios/RustCNet-Swift-Cxx-Bridge.hpp +118 -41
- package/nitrogen/generated/ios/RustCNet-Swift-Cxx-Umbrella.hpp +5 -0
- package/nitrogen/generated/ios/c++/HybridHttpParserSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridHttpParserSpecSwift.hpp +79 -0
- package/nitrogen/generated/ios/c++/HybridNetDriverSpecSwift.hpp +69 -0
- package/nitrogen/generated/ios/c++/HybridNetServerDriverSpecSwift.hpp +12 -0
- package/nitrogen/generated/ios/c++/HybridNetSocketDriverSpecSwift.hpp +123 -0
- package/nitrogen/generated/ios/swift/HybridHttpParserSpec.swift +56 -0
- package/nitrogen/generated/ios/swift/HybridHttpParserSpec_cxx.swift +131 -0
- package/nitrogen/generated/ios/swift/HybridNetDriverSpec.swift +9 -0
- package/nitrogen/generated/ios/swift/HybridNetDriverSpec_cxx.swift +133 -0
- package/nitrogen/generated/ios/swift/HybridNetServerDriverSpec.swift +2 -0
- package/nitrogen/generated/ios/swift/HybridNetServerDriverSpec_cxx.swift +36 -0
- package/nitrogen/generated/ios/swift/HybridNetSocketDriverSpec.swift +17 -0
- package/nitrogen/generated/ios/swift/HybridNetSocketDriverSpec_cxx.swift +314 -0
- package/nitrogen/generated/ios/swift/NetConfig.swift +19 -1
- package/nitrogen/generated/shared/c++/HybridHttpParserSpec.cpp +21 -0
- package/nitrogen/generated/shared/c++/HybridHttpParserSpec.hpp +63 -0
- package/nitrogen/generated/shared/c++/HybridNetDriverSpec.cpp +9 -0
- package/nitrogen/generated/shared/c++/HybridNetDriverSpec.hpp +13 -0
- package/nitrogen/generated/shared/c++/HybridNetServerDriverSpec.cpp +2 -0
- package/nitrogen/generated/shared/c++/HybridNetServerDriverSpec.hpp +2 -0
- package/nitrogen/generated/shared/c++/HybridNetSocketDriverSpec.cpp +17 -0
- package/nitrogen/generated/shared/c++/HybridNetSocketDriverSpec.hpp +18 -0
- package/nitrogen/generated/shared/c++/NetConfig.hpp +6 -2
- package/package.json +7 -5
- package/react-native-nitro-net.podspec +1 -3
- package/src/Net.nitro.ts +44 -1
- package/src/http.ts +1304 -0
- package/src/https.ts +127 -0
- package/src/index.ts +167 -27
- package/src/tls.ts +608 -0
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// JHybridHttpParserSpec.cpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2025 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#include "JHybridHttpParserSpec.hpp"
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
#include <string>
|
|
13
|
+
#include <NitroModules/ArrayBuffer.hpp>
|
|
14
|
+
#include <NitroModules/JArrayBuffer.hpp>
|
|
15
|
+
|
|
16
|
+
namespace margelo::nitro::net {
|
|
17
|
+
|
|
18
|
+
jni::local_ref<JHybridHttpParserSpec::jhybriddata> JHybridHttpParserSpec::initHybrid(jni::alias_ref<jhybridobject> jThis) {
|
|
19
|
+
return makeCxxInstance(jThis);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
void JHybridHttpParserSpec::registerNatives() {
|
|
23
|
+
registerHybrid({
|
|
24
|
+
makeNativeMethod("initHybrid", JHybridHttpParserSpec::initHybrid),
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
size_t JHybridHttpParserSpec::getExternalMemorySize() noexcept {
|
|
29
|
+
static const auto method = javaClassStatic()->getMethod<jlong()>("getMemorySize");
|
|
30
|
+
return method(_javaPart);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
void JHybridHttpParserSpec::dispose() noexcept {
|
|
34
|
+
static const auto method = javaClassStatic()->getMethod<void()>("dispose");
|
|
35
|
+
method(_javaPart);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
std::string JHybridHttpParserSpec::toString() {
|
|
39
|
+
static const auto method = javaClassStatic()->getMethod<jni::JString()>("toString");
|
|
40
|
+
auto javaString = method(_javaPart);
|
|
41
|
+
return javaString->toStdString();
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
// Properties
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
// Methods
|
|
48
|
+
std::string JHybridHttpParserSpec::feed(const std::shared_ptr<ArrayBuffer>& data) {
|
|
49
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<jni::JString>(jni::alias_ref<JArrayBuffer::javaobject> /* data */)>("feed");
|
|
50
|
+
auto __result = method(_javaPart, JArrayBuffer::wrap(data));
|
|
51
|
+
return __result->toStdString();
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
} // namespace margelo::nitro::net
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridHttpParserSpec.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2025 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#include <NitroModules/JHybridObject.hpp>
|
|
11
|
+
#include <fbjni/fbjni.h>
|
|
12
|
+
#include "HybridHttpParserSpec.hpp"
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
namespace margelo::nitro::net {
|
|
18
|
+
|
|
19
|
+
using namespace facebook;
|
|
20
|
+
|
|
21
|
+
class JHybridHttpParserSpec: public jni::HybridClass<JHybridHttpParserSpec, JHybridObject>,
|
|
22
|
+
public virtual HybridHttpParserSpec {
|
|
23
|
+
public:
|
|
24
|
+
static auto constexpr kJavaDescriptor = "Lcom/margelo/nitro/net/HybridHttpParserSpec;";
|
|
25
|
+
static jni::local_ref<jhybriddata> initHybrid(jni::alias_ref<jhybridobject> jThis);
|
|
26
|
+
static void registerNatives();
|
|
27
|
+
|
|
28
|
+
protected:
|
|
29
|
+
// C++ constructor (called from Java via `initHybrid()`)
|
|
30
|
+
explicit JHybridHttpParserSpec(jni::alias_ref<jhybridobject> jThis) :
|
|
31
|
+
HybridObject(HybridHttpParserSpec::TAG),
|
|
32
|
+
HybridBase(jThis),
|
|
33
|
+
_javaPart(jni::make_global(jThis)) {}
|
|
34
|
+
|
|
35
|
+
public:
|
|
36
|
+
~JHybridHttpParserSpec() override {
|
|
37
|
+
// Hermes GC can destroy JS objects on a non-JNI Thread.
|
|
38
|
+
jni::ThreadScope::WithClassLoader([&] { _javaPart.reset(); });
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
public:
|
|
42
|
+
size_t getExternalMemorySize() noexcept override;
|
|
43
|
+
void dispose() noexcept override;
|
|
44
|
+
std::string toString() override;
|
|
45
|
+
|
|
46
|
+
public:
|
|
47
|
+
inline const jni::global_ref<JHybridHttpParserSpec::javaobject>& getJavaPart() const noexcept {
|
|
48
|
+
return _javaPart;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
public:
|
|
52
|
+
// Properties
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
public:
|
|
56
|
+
// Methods
|
|
57
|
+
std::string feed(const std::shared_ptr<ArrayBuffer>& data) override;
|
|
58
|
+
|
|
59
|
+
private:
|
|
60
|
+
friend HybridBase;
|
|
61
|
+
using HybridBase::HybridBase;
|
|
62
|
+
jni::global_ref<JHybridHttpParserSpec::javaobject> _javaPart;
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
} // namespace margelo::nitro::net
|
|
@@ -11,6 +11,8 @@
|
|
|
11
11
|
namespace margelo::nitro::net { class HybridNetSocketDriverSpec; }
|
|
12
12
|
// Forward declaration of `HybridNetServerDriverSpec` to properly resolve imports.
|
|
13
13
|
namespace margelo::nitro::net { class HybridNetServerDriverSpec; }
|
|
14
|
+
// Forward declaration of `HybridHttpParserSpec` to properly resolve imports.
|
|
15
|
+
namespace margelo::nitro::net { class HybridHttpParserSpec; }
|
|
14
16
|
// Forward declaration of `NetConfig` to properly resolve imports.
|
|
15
17
|
namespace margelo::nitro::net { struct NetConfig; }
|
|
16
18
|
|
|
@@ -19,8 +21,12 @@ namespace margelo::nitro::net { struct NetConfig; }
|
|
|
19
21
|
#include "JHybridNetSocketDriverSpec.hpp"
|
|
20
22
|
#include "HybridNetServerDriverSpec.hpp"
|
|
21
23
|
#include "JHybridNetServerDriverSpec.hpp"
|
|
22
|
-
#include
|
|
24
|
+
#include "HybridHttpParserSpec.hpp"
|
|
25
|
+
#include "JHybridHttpParserSpec.hpp"
|
|
26
|
+
#include <NitroModules/ArrayBuffer.hpp>
|
|
23
27
|
#include <optional>
|
|
28
|
+
#include <NitroModules/JArrayBuffer.hpp>
|
|
29
|
+
#include <string>
|
|
24
30
|
#include "NetConfig.hpp"
|
|
25
31
|
#include "JNetConfig.hpp"
|
|
26
32
|
|
|
@@ -66,6 +72,46 @@ namespace margelo::nitro::net {
|
|
|
66
72
|
auto __result = method(_javaPart);
|
|
67
73
|
return __result->cthis()->shared_cast<JHybridNetServerDriverSpec>();
|
|
68
74
|
}
|
|
75
|
+
std::shared_ptr<HybridHttpParserSpec> JHybridNetDriverSpec::createHttpParser(double mode) {
|
|
76
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<JHybridHttpParserSpec::javaobject>(double /* mode */)>("createHttpParser");
|
|
77
|
+
auto __result = method(_javaPart, mode);
|
|
78
|
+
return __result->cthis()->shared_cast<JHybridHttpParserSpec>();
|
|
79
|
+
}
|
|
80
|
+
double JHybridNetDriverSpec::createSecureContext(const std::string& cert, const std::string& key, const std::optional<std::string>& passphrase) {
|
|
81
|
+
static const auto method = javaClassStatic()->getMethod<double(jni::alias_ref<jni::JString> /* cert */, jni::alias_ref<jni::JString> /* key */, jni::alias_ref<jni::JString> /* passphrase */)>("createSecureContext");
|
|
82
|
+
auto __result = method(_javaPart, jni::make_jstring(cert), jni::make_jstring(key), passphrase.has_value() ? jni::make_jstring(passphrase.value()) : nullptr);
|
|
83
|
+
return __result;
|
|
84
|
+
}
|
|
85
|
+
double JHybridNetDriverSpec::createEmptySecureContext() {
|
|
86
|
+
static const auto method = javaClassStatic()->getMethod<double()>("createEmptySecureContext");
|
|
87
|
+
auto __result = method(_javaPart);
|
|
88
|
+
return __result;
|
|
89
|
+
}
|
|
90
|
+
void JHybridNetDriverSpec::addCACertToSecureContext(double scId, const std::string& ca) {
|
|
91
|
+
static const auto method = javaClassStatic()->getMethod<void(double /* scId */, jni::alias_ref<jni::JString> /* ca */)>("addCACertToSecureContext");
|
|
92
|
+
method(_javaPart, scId, jni::make_jstring(ca));
|
|
93
|
+
}
|
|
94
|
+
void JHybridNetDriverSpec::addContextToSecureContext(double scId, const std::string& hostname, const std::string& cert, const std::string& key, const std::optional<std::string>& passphrase) {
|
|
95
|
+
static const auto method = javaClassStatic()->getMethod<void(double /* scId */, jni::alias_ref<jni::JString> /* hostname */, jni::alias_ref<jni::JString> /* cert */, jni::alias_ref<jni::JString> /* key */, jni::alias_ref<jni::JString> /* passphrase */)>("addContextToSecureContext");
|
|
96
|
+
method(_javaPart, scId, jni::make_jstring(hostname), jni::make_jstring(cert), jni::make_jstring(key), passphrase.has_value() ? jni::make_jstring(passphrase.value()) : nullptr);
|
|
97
|
+
}
|
|
98
|
+
void JHybridNetDriverSpec::setPFXToSecureContext(double scId, const std::shared_ptr<ArrayBuffer>& pfx, const std::optional<std::string>& passphrase) {
|
|
99
|
+
static const auto method = javaClassStatic()->getMethod<void(double /* scId */, jni::alias_ref<JArrayBuffer::javaobject> /* pfx */, jni::alias_ref<jni::JString> /* passphrase */)>("setPFXToSecureContext");
|
|
100
|
+
method(_javaPart, scId, JArrayBuffer::wrap(pfx), passphrase.has_value() ? jni::make_jstring(passphrase.value()) : nullptr);
|
|
101
|
+
}
|
|
102
|
+
void JHybridNetDriverSpec::setOCSPResponseToSecureContext(double scId, const std::shared_ptr<ArrayBuffer>& ocsp) {
|
|
103
|
+
static const auto method = javaClassStatic()->getMethod<void(double /* scId */, jni::alias_ref<JArrayBuffer::javaobject> /* ocsp */)>("setOCSPResponseToSecureContext");
|
|
104
|
+
method(_javaPart, scId, JArrayBuffer::wrap(ocsp));
|
|
105
|
+
}
|
|
106
|
+
std::optional<std::shared_ptr<ArrayBuffer>> JHybridNetDriverSpec::getTicketKeys(double scId) {
|
|
107
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<JArrayBuffer::javaobject>(double /* scId */)>("getTicketKeys");
|
|
108
|
+
auto __result = method(_javaPart, scId);
|
|
109
|
+
return __result != nullptr ? std::make_optional(__result->cthis()->getArrayBuffer()) : std::nullopt;
|
|
110
|
+
}
|
|
111
|
+
void JHybridNetDriverSpec::setTicketKeys(double scId, const std::shared_ptr<ArrayBuffer>& keys) {
|
|
112
|
+
static const auto method = javaClassStatic()->getMethod<void(double /* scId */, jni::alias_ref<JArrayBuffer::javaobject> /* keys */)>("setTicketKeys");
|
|
113
|
+
method(_javaPart, scId, JArrayBuffer::wrap(keys));
|
|
114
|
+
}
|
|
69
115
|
void JHybridNetDriverSpec::initWithConfig(const NetConfig& config) {
|
|
70
116
|
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<JNetConfig> /* config */)>("initWithConfig");
|
|
71
117
|
method(_javaPart, JNetConfig::fromCpp(config));
|
|
@@ -56,6 +56,15 @@ namespace margelo::nitro::net {
|
|
|
56
56
|
// Methods
|
|
57
57
|
std::shared_ptr<HybridNetSocketDriverSpec> createSocket(const std::optional<std::string>& id) override;
|
|
58
58
|
std::shared_ptr<HybridNetServerDriverSpec> createServer() override;
|
|
59
|
+
std::shared_ptr<HybridHttpParserSpec> createHttpParser(double mode) override;
|
|
60
|
+
double createSecureContext(const std::string& cert, const std::string& key, const std::optional<std::string>& passphrase) override;
|
|
61
|
+
double createEmptySecureContext() override;
|
|
62
|
+
void addCACertToSecureContext(double scId, const std::string& ca) override;
|
|
63
|
+
void addContextToSecureContext(double scId, const std::string& hostname, const std::string& cert, const std::string& key, const std::optional<std::string>& passphrase) override;
|
|
64
|
+
void setPFXToSecureContext(double scId, const std::shared_ptr<ArrayBuffer>& pfx, const std::optional<std::string>& passphrase) override;
|
|
65
|
+
void setOCSPResponseToSecureContext(double scId, const std::shared_ptr<ArrayBuffer>& ocsp) override;
|
|
66
|
+
std::optional<std::shared_ptr<ArrayBuffer>> getTicketKeys(double scId) override;
|
|
67
|
+
void setTicketKeys(double scId, const std::shared_ptr<ArrayBuffer>& keys) override;
|
|
59
68
|
void initWithConfig(const NetConfig& config) override;
|
|
60
69
|
|
|
61
70
|
private:
|
|
@@ -78,10 +78,18 @@ namespace margelo::nitro::net {
|
|
|
78
78
|
static const auto method = javaClassStatic()->getMethod<void(double /* port */, jni::alias_ref<jni::JDouble> /* backlog */, jni::alias_ref<jni::JBoolean> /* ipv6Only */, jni::alias_ref<jni::JBoolean> /* reusePort */)>("listen");
|
|
79
79
|
method(_javaPart, port, backlog.has_value() ? jni::JDouble::valueOf(backlog.value()) : nullptr, ipv6Only.has_value() ? jni::JBoolean::valueOf(ipv6Only.value()) : nullptr, reusePort.has_value() ? jni::JBoolean::valueOf(reusePort.value()) : nullptr);
|
|
80
80
|
}
|
|
81
|
+
void JHybridNetServerDriverSpec::listenTLS(double port, double secureContextId, std::optional<double> backlog, std::optional<bool> ipv6Only, std::optional<bool> reusePort) {
|
|
82
|
+
static const auto method = javaClassStatic()->getMethod<void(double /* port */, double /* secureContextId */, jni::alias_ref<jni::JDouble> /* backlog */, jni::alias_ref<jni::JBoolean> /* ipv6Only */, jni::alias_ref<jni::JBoolean> /* reusePort */)>("listenTLS");
|
|
83
|
+
method(_javaPart, port, secureContextId, backlog.has_value() ? jni::JDouble::valueOf(backlog.value()) : nullptr, ipv6Only.has_value() ? jni::JBoolean::valueOf(ipv6Only.value()) : nullptr, reusePort.has_value() ? jni::JBoolean::valueOf(reusePort.value()) : nullptr);
|
|
84
|
+
}
|
|
81
85
|
void JHybridNetServerDriverSpec::listenUnix(const std::string& path, std::optional<double> backlog) {
|
|
82
86
|
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<jni::JString> /* path */, jni::alias_ref<jni::JDouble> /* backlog */)>("listenUnix");
|
|
83
87
|
method(_javaPart, jni::make_jstring(path), backlog.has_value() ? jni::JDouble::valueOf(backlog.value()) : nullptr);
|
|
84
88
|
}
|
|
89
|
+
void JHybridNetServerDriverSpec::listenTLSUnix(const std::string& path, double secureContextId, std::optional<double> backlog) {
|
|
90
|
+
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<jni::JString> /* path */, double /* secureContextId */, jni::alias_ref<jni::JDouble> /* backlog */)>("listenTLSUnix");
|
|
91
|
+
method(_javaPart, jni::make_jstring(path), secureContextId, backlog.has_value() ? jni::JDouble::valueOf(backlog.value()) : nullptr);
|
|
92
|
+
}
|
|
85
93
|
void JHybridNetServerDriverSpec::listenHandle(double fd, std::optional<double> backlog) {
|
|
86
94
|
static const auto method = javaClassStatic()->getMethod<void(double /* fd */, jni::alias_ref<jni::JDouble> /* backlog */)>("listenHandle");
|
|
87
95
|
method(_javaPart, fd, backlog.has_value() ? jni::JDouble::valueOf(backlog.value()) : nullptr);
|
|
@@ -58,7 +58,9 @@ namespace margelo::nitro::net {
|
|
|
58
58
|
public:
|
|
59
59
|
// Methods
|
|
60
60
|
void listen(double port, std::optional<double> backlog, std::optional<bool> ipv6Only, std::optional<bool> reusePort) override;
|
|
61
|
+
void listenTLS(double port, double secureContextId, std::optional<double> backlog, std::optional<bool> ipv6Only, std::optional<bool> reusePort) override;
|
|
61
62
|
void listenUnix(const std::string& path, std::optional<double> backlog) override;
|
|
63
|
+
void listenTLSUnix(const std::string& path, double secureContextId, std::optional<double> backlog) override;
|
|
62
64
|
void listenHandle(double fd, std::optional<double> backlog) override;
|
|
63
65
|
std::string getLocalAddress() override;
|
|
64
66
|
void close() override;
|
|
@@ -15,6 +15,7 @@
|
|
|
15
15
|
#include <NitroModules/JNICallable.hpp>
|
|
16
16
|
#include <NitroModules/JArrayBuffer.hpp>
|
|
17
17
|
#include <string>
|
|
18
|
+
#include <optional>
|
|
18
19
|
|
|
19
20
|
namespace margelo::nitro::net {
|
|
20
21
|
|
|
@@ -73,10 +74,75 @@ namespace margelo::nitro::net {
|
|
|
73
74
|
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<jni::JString> /* host */, double /* port */)>("connect");
|
|
74
75
|
method(_javaPart, jni::make_jstring(host), port);
|
|
75
76
|
}
|
|
77
|
+
void JHybridNetSocketDriverSpec::connectTLS(const std::string& host, double port, const std::optional<std::string>& serverName, std::optional<bool> rejectUnauthorized) {
|
|
78
|
+
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<jni::JString> /* host */, double /* port */, jni::alias_ref<jni::JString> /* serverName */, jni::alias_ref<jni::JBoolean> /* rejectUnauthorized */)>("connectTLS");
|
|
79
|
+
method(_javaPart, jni::make_jstring(host), port, serverName.has_value() ? jni::make_jstring(serverName.value()) : nullptr, rejectUnauthorized.has_value() ? jni::JBoolean::valueOf(rejectUnauthorized.value()) : nullptr);
|
|
80
|
+
}
|
|
81
|
+
void JHybridNetSocketDriverSpec::connectTLSWithContext(const std::string& host, double port, const std::optional<std::string>& serverName, std::optional<bool> rejectUnauthorized, std::optional<double> secureContextId) {
|
|
82
|
+
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<jni::JString> /* host */, double /* port */, jni::alias_ref<jni::JString> /* serverName */, jni::alias_ref<jni::JBoolean> /* rejectUnauthorized */, jni::alias_ref<jni::JDouble> /* secureContextId */)>("connectTLSWithContext");
|
|
83
|
+
method(_javaPart, jni::make_jstring(host), port, serverName.has_value() ? jni::make_jstring(serverName.value()) : nullptr, rejectUnauthorized.has_value() ? jni::JBoolean::valueOf(rejectUnauthorized.value()) : nullptr, secureContextId.has_value() ? jni::JDouble::valueOf(secureContextId.value()) : nullptr);
|
|
84
|
+
}
|
|
85
|
+
std::optional<std::string> JHybridNetSocketDriverSpec::getAuthorizationError() {
|
|
86
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<jni::JString>()>("getAuthorizationError");
|
|
87
|
+
auto __result = method(_javaPart);
|
|
88
|
+
return __result != nullptr ? std::make_optional(__result->toStdString()) : std::nullopt;
|
|
89
|
+
}
|
|
90
|
+
std::optional<std::string> JHybridNetSocketDriverSpec::getProtocol() {
|
|
91
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<jni::JString>()>("getProtocol");
|
|
92
|
+
auto __result = method(_javaPart);
|
|
93
|
+
return __result != nullptr ? std::make_optional(__result->toStdString()) : std::nullopt;
|
|
94
|
+
}
|
|
95
|
+
std::optional<std::string> JHybridNetSocketDriverSpec::getCipher() {
|
|
96
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<jni::JString>()>("getCipher");
|
|
97
|
+
auto __result = method(_javaPart);
|
|
98
|
+
return __result != nullptr ? std::make_optional(__result->toStdString()) : std::nullopt;
|
|
99
|
+
}
|
|
100
|
+
std::optional<std::string> JHybridNetSocketDriverSpec::getALPN() {
|
|
101
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<jni::JString>()>("getALPN");
|
|
102
|
+
auto __result = method(_javaPart);
|
|
103
|
+
return __result != nullptr ? std::make_optional(__result->toStdString()) : std::nullopt;
|
|
104
|
+
}
|
|
105
|
+
std::optional<std::string> JHybridNetSocketDriverSpec::getPeerCertificateJSON() {
|
|
106
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<jni::JString>()>("getPeerCertificateJSON");
|
|
107
|
+
auto __result = method(_javaPart);
|
|
108
|
+
return __result != nullptr ? std::make_optional(__result->toStdString()) : std::nullopt;
|
|
109
|
+
}
|
|
110
|
+
std::optional<std::string> JHybridNetSocketDriverSpec::getEphemeralKeyInfo() {
|
|
111
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<jni::JString>()>("getEphemeralKeyInfo");
|
|
112
|
+
auto __result = method(_javaPart);
|
|
113
|
+
return __result != nullptr ? std::make_optional(__result->toStdString()) : std::nullopt;
|
|
114
|
+
}
|
|
115
|
+
std::optional<std::string> JHybridNetSocketDriverSpec::getSharedSigalgs() {
|
|
116
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<jni::JString>()>("getSharedSigalgs");
|
|
117
|
+
auto __result = method(_javaPart);
|
|
118
|
+
return __result != nullptr ? std::make_optional(__result->toStdString()) : std::nullopt;
|
|
119
|
+
}
|
|
120
|
+
bool JHybridNetSocketDriverSpec::isSessionReused() {
|
|
121
|
+
static const auto method = javaClassStatic()->getMethod<jboolean()>("isSessionReused");
|
|
122
|
+
auto __result = method(_javaPart);
|
|
123
|
+
return static_cast<bool>(__result);
|
|
124
|
+
}
|
|
125
|
+
std::optional<std::shared_ptr<ArrayBuffer>> JHybridNetSocketDriverSpec::getSession() {
|
|
126
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<JArrayBuffer::javaobject>()>("getSession");
|
|
127
|
+
auto __result = method(_javaPart);
|
|
128
|
+
return __result != nullptr ? std::make_optional(__result->cthis()->getArrayBuffer()) : std::nullopt;
|
|
129
|
+
}
|
|
130
|
+
void JHybridNetSocketDriverSpec::setSession(const std::shared_ptr<ArrayBuffer>& session) {
|
|
131
|
+
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<JArrayBuffer::javaobject> /* session */)>("setSession");
|
|
132
|
+
method(_javaPart, JArrayBuffer::wrap(session));
|
|
133
|
+
}
|
|
76
134
|
void JHybridNetSocketDriverSpec::connectUnix(const std::string& path) {
|
|
77
135
|
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<jni::JString> /* path */)>("connectUnix");
|
|
78
136
|
method(_javaPart, jni::make_jstring(path));
|
|
79
137
|
}
|
|
138
|
+
void JHybridNetSocketDriverSpec::connectUnixTLS(const std::string& path, const std::optional<std::string>& serverName, std::optional<bool> rejectUnauthorized) {
|
|
139
|
+
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<jni::JString> /* path */, jni::alias_ref<jni::JString> /* serverName */, jni::alias_ref<jni::JBoolean> /* rejectUnauthorized */)>("connectUnixTLS");
|
|
140
|
+
method(_javaPart, jni::make_jstring(path), serverName.has_value() ? jni::make_jstring(serverName.value()) : nullptr, rejectUnauthorized.has_value() ? jni::JBoolean::valueOf(rejectUnauthorized.value()) : nullptr);
|
|
141
|
+
}
|
|
142
|
+
void JHybridNetSocketDriverSpec::connectUnixTLSWithContext(const std::string& path, const std::optional<std::string>& serverName, std::optional<bool> rejectUnauthorized, std::optional<double> secureContextId) {
|
|
143
|
+
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<jni::JString> /* path */, jni::alias_ref<jni::JString> /* serverName */, jni::alias_ref<jni::JBoolean> /* rejectUnauthorized */, jni::alias_ref<jni::JDouble> /* secureContextId */)>("connectUnixTLSWithContext");
|
|
144
|
+
method(_javaPart, jni::make_jstring(path), serverName.has_value() ? jni::make_jstring(serverName.value()) : nullptr, rejectUnauthorized.has_value() ? jni::JBoolean::valueOf(rejectUnauthorized.value()) : nullptr, secureContextId.has_value() ? jni::JDouble::valueOf(secureContextId.value()) : nullptr);
|
|
145
|
+
}
|
|
80
146
|
void JHybridNetSocketDriverSpec::write(const std::shared_ptr<ArrayBuffer>& data) {
|
|
81
147
|
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<JArrayBuffer::javaobject> /* data */)>("write");
|
|
82
148
|
method(_javaPart, JArrayBuffer::wrap(data));
|
|
@@ -105,6 +171,19 @@ namespace margelo::nitro::net {
|
|
|
105
171
|
static const auto method = javaClassStatic()->getMethod<void()>("resetAndDestroy");
|
|
106
172
|
method(_javaPart);
|
|
107
173
|
}
|
|
174
|
+
void JHybridNetSocketDriverSpec::enableKeylog() {
|
|
175
|
+
static const auto method = javaClassStatic()->getMethod<void()>("enableKeylog");
|
|
176
|
+
method(_javaPart);
|
|
177
|
+
}
|
|
178
|
+
void JHybridNetSocketDriverSpec::enableTrace() {
|
|
179
|
+
static const auto method = javaClassStatic()->getMethod<void()>("enableTrace");
|
|
180
|
+
method(_javaPart);
|
|
181
|
+
}
|
|
182
|
+
std::optional<std::shared_ptr<ArrayBuffer>> JHybridNetSocketDriverSpec::exportKeyingMaterial(double length, const std::string& label, const std::optional<std::shared_ptr<ArrayBuffer>>& context) {
|
|
183
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<JArrayBuffer::javaobject>(double /* length */, jni::alias_ref<jni::JString> /* label */, jni::alias_ref<JArrayBuffer::javaobject> /* context */)>("exportKeyingMaterial");
|
|
184
|
+
auto __result = method(_javaPart, length, jni::make_jstring(label), context.has_value() ? JArrayBuffer::wrap(context.value()) : nullptr);
|
|
185
|
+
return __result != nullptr ? std::make_optional(__result->cthis()->getArrayBuffer()) : std::nullopt;
|
|
186
|
+
}
|
|
108
187
|
void JHybridNetSocketDriverSpec::setNoDelay(bool enable) {
|
|
109
188
|
static const auto method = javaClassStatic()->getMethod<void(jboolean /* enable */)>("setNoDelay");
|
|
110
189
|
method(_javaPart, enable);
|
|
@@ -57,7 +57,21 @@ namespace margelo::nitro::net {
|
|
|
57
57
|
public:
|
|
58
58
|
// Methods
|
|
59
59
|
void connect(const std::string& host, double port) override;
|
|
60
|
+
void connectTLS(const std::string& host, double port, const std::optional<std::string>& serverName, std::optional<bool> rejectUnauthorized) override;
|
|
61
|
+
void connectTLSWithContext(const std::string& host, double port, const std::optional<std::string>& serverName, std::optional<bool> rejectUnauthorized, std::optional<double> secureContextId) override;
|
|
62
|
+
std::optional<std::string> getAuthorizationError() override;
|
|
63
|
+
std::optional<std::string> getProtocol() override;
|
|
64
|
+
std::optional<std::string> getCipher() override;
|
|
65
|
+
std::optional<std::string> getALPN() override;
|
|
66
|
+
std::optional<std::string> getPeerCertificateJSON() override;
|
|
67
|
+
std::optional<std::string> getEphemeralKeyInfo() override;
|
|
68
|
+
std::optional<std::string> getSharedSigalgs() override;
|
|
69
|
+
bool isSessionReused() override;
|
|
70
|
+
std::optional<std::shared_ptr<ArrayBuffer>> getSession() override;
|
|
71
|
+
void setSession(const std::shared_ptr<ArrayBuffer>& session) override;
|
|
60
72
|
void connectUnix(const std::string& path) override;
|
|
73
|
+
void connectUnixTLS(const std::string& path, const std::optional<std::string>& serverName, std::optional<bool> rejectUnauthorized) override;
|
|
74
|
+
void connectUnixTLSWithContext(const std::string& path, const std::optional<std::string>& serverName, std::optional<bool> rejectUnauthorized, std::optional<double> secureContextId) override;
|
|
61
75
|
void write(const std::shared_ptr<ArrayBuffer>& data) override;
|
|
62
76
|
void pause() override;
|
|
63
77
|
void resume() override;
|
|
@@ -65,6 +79,9 @@ namespace margelo::nitro::net {
|
|
|
65
79
|
void setTimeout(double timeout) override;
|
|
66
80
|
void destroy() override;
|
|
67
81
|
void resetAndDestroy() override;
|
|
82
|
+
void enableKeylog() override;
|
|
83
|
+
void enableTrace() override;
|
|
84
|
+
std::optional<std::shared_ptr<ArrayBuffer>> exportKeyingMaterial(double length, const std::string& label, const std::optional<std::shared_ptr<ArrayBuffer>>& context) override;
|
|
68
85
|
void setNoDelay(bool enable) override;
|
|
69
86
|
void setKeepAlive(bool enable, double delay) override;
|
|
70
87
|
std::string getLocalAddress() override;
|
|
@@ -33,8 +33,11 @@ namespace margelo::nitro::net {
|
|
|
33
33
|
static const auto clazz = javaClassStatic();
|
|
34
34
|
static const auto fieldWorkerThreads = clazz->getField<jni::JDouble>("workerThreads");
|
|
35
35
|
jni::local_ref<jni::JDouble> workerThreads = this->getFieldValue(fieldWorkerThreads);
|
|
36
|
+
static const auto fieldDebug = clazz->getField<jni::JBoolean>("debug");
|
|
37
|
+
jni::local_ref<jni::JBoolean> debug = this->getFieldValue(fieldDebug);
|
|
36
38
|
return NetConfig(
|
|
37
|
-
workerThreads != nullptr ? std::make_optional(workerThreads->value()) : std::nullopt
|
|
39
|
+
workerThreads != nullptr ? std::make_optional(workerThreads->value()) : std::nullopt,
|
|
40
|
+
debug != nullptr ? std::make_optional(static_cast<bool>(debug->value())) : std::nullopt
|
|
38
41
|
);
|
|
39
42
|
}
|
|
40
43
|
|
|
@@ -44,12 +47,13 @@ namespace margelo::nitro::net {
|
|
|
44
47
|
*/
|
|
45
48
|
[[maybe_unused]]
|
|
46
49
|
static jni::local_ref<JNetConfig::javaobject> fromCpp(const NetConfig& value) {
|
|
47
|
-
using JSignature = JNetConfig(jni::alias_ref<jni::JDouble>);
|
|
50
|
+
using JSignature = JNetConfig(jni::alias_ref<jni::JDouble>, jni::alias_ref<jni::JBoolean>);
|
|
48
51
|
static const auto clazz = javaClassStatic();
|
|
49
52
|
static const auto create = clazz->getStaticMethod<JSignature>("fromCpp");
|
|
50
53
|
return create(
|
|
51
54
|
clazz,
|
|
52
|
-
value.workerThreads.has_value() ? jni::JDouble::valueOf(value.workerThreads.value()) : nullptr
|
|
55
|
+
value.workerThreads.has_value() ? jni::JDouble::valueOf(value.workerThreads.value()) : nullptr,
|
|
56
|
+
value.debug.has_value() ? jni::JBoolean::valueOf(value.debug.value()) : nullptr
|
|
53
57
|
);
|
|
54
58
|
}
|
|
55
59
|
};
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridHttpParserSpec.kt
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2025 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
package com.margelo.nitro.net
|
|
9
|
+
|
|
10
|
+
import androidx.annotation.Keep
|
|
11
|
+
import com.facebook.jni.HybridData
|
|
12
|
+
import com.facebook.proguard.annotations.DoNotStrip
|
|
13
|
+
import com.margelo.nitro.core.ArrayBuffer
|
|
14
|
+
import com.margelo.nitro.core.HybridObject
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* A Kotlin class representing the HttpParser HybridObject.
|
|
18
|
+
* Implement this abstract class to create Kotlin-based instances of HttpParser.
|
|
19
|
+
*/
|
|
20
|
+
@DoNotStrip
|
|
21
|
+
@Keep
|
|
22
|
+
@Suppress(
|
|
23
|
+
"KotlinJniMissingFunction", "unused",
|
|
24
|
+
"RedundantSuppression", "RedundantUnitReturnType", "SimpleRedundantLet",
|
|
25
|
+
"LocalVariableName", "PropertyName", "PrivatePropertyName", "FunctionName"
|
|
26
|
+
)
|
|
27
|
+
abstract class HybridHttpParserSpec: HybridObject() {
|
|
28
|
+
@DoNotStrip
|
|
29
|
+
private var mHybridData: HybridData = initHybrid()
|
|
30
|
+
|
|
31
|
+
init {
|
|
32
|
+
super.updateNative(mHybridData)
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
override fun updateNative(hybridData: HybridData) {
|
|
36
|
+
mHybridData = hybridData
|
|
37
|
+
super.updateNative(hybridData)
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
// Default implementation of `HybridObject.toString()`
|
|
41
|
+
override fun toString(): String {
|
|
42
|
+
return "[HybridObject HttpParser]"
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
// Properties
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
// Methods
|
|
49
|
+
@DoNotStrip
|
|
50
|
+
@Keep
|
|
51
|
+
abstract fun feed(data: ArrayBuffer): String
|
|
52
|
+
|
|
53
|
+
private external fun initHybrid(): HybridData
|
|
54
|
+
|
|
55
|
+
companion object {
|
|
56
|
+
protected const val TAG = "HybridHttpParserSpec"
|
|
57
|
+
}
|
|
58
|
+
}
|
|
@@ -10,6 +10,7 @@ package com.margelo.nitro.net
|
|
|
10
10
|
import androidx.annotation.Keep
|
|
11
11
|
import com.facebook.jni.HybridData
|
|
12
12
|
import com.facebook.proguard.annotations.DoNotStrip
|
|
13
|
+
import com.margelo.nitro.core.ArrayBuffer
|
|
13
14
|
import com.margelo.nitro.core.HybridObject
|
|
14
15
|
|
|
15
16
|
/**
|
|
@@ -53,6 +54,42 @@ abstract class HybridNetDriverSpec: HybridObject() {
|
|
|
53
54
|
@Keep
|
|
54
55
|
abstract fun createServer(): HybridNetServerDriverSpec
|
|
55
56
|
|
|
57
|
+
@DoNotStrip
|
|
58
|
+
@Keep
|
|
59
|
+
abstract fun createHttpParser(mode: Double): HybridHttpParserSpec
|
|
60
|
+
|
|
61
|
+
@DoNotStrip
|
|
62
|
+
@Keep
|
|
63
|
+
abstract fun createSecureContext(cert: String, key: String, passphrase: String?): Double
|
|
64
|
+
|
|
65
|
+
@DoNotStrip
|
|
66
|
+
@Keep
|
|
67
|
+
abstract fun createEmptySecureContext(): Double
|
|
68
|
+
|
|
69
|
+
@DoNotStrip
|
|
70
|
+
@Keep
|
|
71
|
+
abstract fun addCACertToSecureContext(scId: Double, ca: String): Unit
|
|
72
|
+
|
|
73
|
+
@DoNotStrip
|
|
74
|
+
@Keep
|
|
75
|
+
abstract fun addContextToSecureContext(scId: Double, hostname: String, cert: String, key: String, passphrase: String?): Unit
|
|
76
|
+
|
|
77
|
+
@DoNotStrip
|
|
78
|
+
@Keep
|
|
79
|
+
abstract fun setPFXToSecureContext(scId: Double, pfx: ArrayBuffer, passphrase: String?): Unit
|
|
80
|
+
|
|
81
|
+
@DoNotStrip
|
|
82
|
+
@Keep
|
|
83
|
+
abstract fun setOCSPResponseToSecureContext(scId: Double, ocsp: ArrayBuffer): Unit
|
|
84
|
+
|
|
85
|
+
@DoNotStrip
|
|
86
|
+
@Keep
|
|
87
|
+
abstract fun getTicketKeys(scId: Double): ArrayBuffer?
|
|
88
|
+
|
|
89
|
+
@DoNotStrip
|
|
90
|
+
@Keep
|
|
91
|
+
abstract fun setTicketKeys(scId: Double, keys: ArrayBuffer): Unit
|
|
92
|
+
|
|
56
93
|
@DoNotStrip
|
|
57
94
|
@Keep
|
|
58
95
|
abstract fun initWithConfig(config: NetConfig): Unit
|
package/nitrogen/generated/android/kotlin/com/margelo/nitro/net/HybridNetServerDriverSpec.kt
CHANGED
|
@@ -68,10 +68,18 @@ abstract class HybridNetServerDriverSpec: HybridObject() {
|
|
|
68
68
|
@Keep
|
|
69
69
|
abstract fun listen(port: Double, backlog: Double?, ipv6Only: Boolean?, reusePort: Boolean?): Unit
|
|
70
70
|
|
|
71
|
+
@DoNotStrip
|
|
72
|
+
@Keep
|
|
73
|
+
abstract fun listenTLS(port: Double, secureContextId: Double, backlog: Double?, ipv6Only: Boolean?, reusePort: Boolean?): Unit
|
|
74
|
+
|
|
71
75
|
@DoNotStrip
|
|
72
76
|
@Keep
|
|
73
77
|
abstract fun listenUnix(path: String, backlog: Double?): Unit
|
|
74
78
|
|
|
79
|
+
@DoNotStrip
|
|
80
|
+
@Keep
|
|
81
|
+
abstract fun listenTLSUnix(path: String, secureContextId: Double, backlog: Double?): Unit
|
|
82
|
+
|
|
75
83
|
@DoNotStrip
|
|
76
84
|
@Keep
|
|
77
85
|
abstract fun listenHandle(fd: Double, backlog: Double?): Unit
|
package/nitrogen/generated/android/kotlin/com/margelo/nitro/net/HybridNetSocketDriverSpec.kt
CHANGED
|
@@ -66,10 +66,66 @@ abstract class HybridNetSocketDriverSpec: HybridObject() {
|
|
|
66
66
|
@Keep
|
|
67
67
|
abstract fun connect(host: String, port: Double): Unit
|
|
68
68
|
|
|
69
|
+
@DoNotStrip
|
|
70
|
+
@Keep
|
|
71
|
+
abstract fun connectTLS(host: String, port: Double, serverName: String?, rejectUnauthorized: Boolean?): Unit
|
|
72
|
+
|
|
73
|
+
@DoNotStrip
|
|
74
|
+
@Keep
|
|
75
|
+
abstract fun connectTLSWithContext(host: String, port: Double, serverName: String?, rejectUnauthorized: Boolean?, secureContextId: Double?): Unit
|
|
76
|
+
|
|
77
|
+
@DoNotStrip
|
|
78
|
+
@Keep
|
|
79
|
+
abstract fun getAuthorizationError(): String?
|
|
80
|
+
|
|
81
|
+
@DoNotStrip
|
|
82
|
+
@Keep
|
|
83
|
+
abstract fun getProtocol(): String?
|
|
84
|
+
|
|
85
|
+
@DoNotStrip
|
|
86
|
+
@Keep
|
|
87
|
+
abstract fun getCipher(): String?
|
|
88
|
+
|
|
89
|
+
@DoNotStrip
|
|
90
|
+
@Keep
|
|
91
|
+
abstract fun getALPN(): String?
|
|
92
|
+
|
|
93
|
+
@DoNotStrip
|
|
94
|
+
@Keep
|
|
95
|
+
abstract fun getPeerCertificateJSON(): String?
|
|
96
|
+
|
|
97
|
+
@DoNotStrip
|
|
98
|
+
@Keep
|
|
99
|
+
abstract fun getEphemeralKeyInfo(): String?
|
|
100
|
+
|
|
101
|
+
@DoNotStrip
|
|
102
|
+
@Keep
|
|
103
|
+
abstract fun getSharedSigalgs(): String?
|
|
104
|
+
|
|
105
|
+
@DoNotStrip
|
|
106
|
+
@Keep
|
|
107
|
+
abstract fun isSessionReused(): Boolean
|
|
108
|
+
|
|
109
|
+
@DoNotStrip
|
|
110
|
+
@Keep
|
|
111
|
+
abstract fun getSession(): ArrayBuffer?
|
|
112
|
+
|
|
113
|
+
@DoNotStrip
|
|
114
|
+
@Keep
|
|
115
|
+
abstract fun setSession(session: ArrayBuffer): Unit
|
|
116
|
+
|
|
69
117
|
@DoNotStrip
|
|
70
118
|
@Keep
|
|
71
119
|
abstract fun connectUnix(path: String): Unit
|
|
72
120
|
|
|
121
|
+
@DoNotStrip
|
|
122
|
+
@Keep
|
|
123
|
+
abstract fun connectUnixTLS(path: String, serverName: String?, rejectUnauthorized: Boolean?): Unit
|
|
124
|
+
|
|
125
|
+
@DoNotStrip
|
|
126
|
+
@Keep
|
|
127
|
+
abstract fun connectUnixTLSWithContext(path: String, serverName: String?, rejectUnauthorized: Boolean?, secureContextId: Double?): Unit
|
|
128
|
+
|
|
73
129
|
@DoNotStrip
|
|
74
130
|
@Keep
|
|
75
131
|
abstract fun write(data: ArrayBuffer): Unit
|
|
@@ -98,6 +154,18 @@ abstract class HybridNetSocketDriverSpec: HybridObject() {
|
|
|
98
154
|
@Keep
|
|
99
155
|
abstract fun resetAndDestroy(): Unit
|
|
100
156
|
|
|
157
|
+
@DoNotStrip
|
|
158
|
+
@Keep
|
|
159
|
+
abstract fun enableKeylog(): Unit
|
|
160
|
+
|
|
161
|
+
@DoNotStrip
|
|
162
|
+
@Keep
|
|
163
|
+
abstract fun enableTrace(): Unit
|
|
164
|
+
|
|
165
|
+
@DoNotStrip
|
|
166
|
+
@Keep
|
|
167
|
+
abstract fun exportKeyingMaterial(length: Double, label: String, context: ArrayBuffer?): ArrayBuffer?
|
|
168
|
+
|
|
101
169
|
@DoNotStrip
|
|
102
170
|
@Keep
|
|
103
171
|
abstract fun setNoDelay(enable: Boolean): Unit
|
|
@@ -19,7 +19,10 @@ import com.facebook.proguard.annotations.DoNotStrip
|
|
|
19
19
|
data class NetConfig(
|
|
20
20
|
@DoNotStrip
|
|
21
21
|
@Keep
|
|
22
|
-
val workerThreads: Double
|
|
22
|
+
val workerThreads: Double?,
|
|
23
|
+
@DoNotStrip
|
|
24
|
+
@Keep
|
|
25
|
+
val debug: Boolean?
|
|
23
26
|
) {
|
|
24
27
|
/* primary constructor */
|
|
25
28
|
|
|
@@ -31,8 +34,8 @@ data class NetConfig(
|
|
|
31
34
|
@Keep
|
|
32
35
|
@Suppress("unused")
|
|
33
36
|
@JvmStatic
|
|
34
|
-
private fun fromCpp(workerThreads: Double?): NetConfig {
|
|
35
|
-
return NetConfig(workerThreads)
|
|
37
|
+
private fun fromCpp(workerThreads: Double?, debug: Boolean?): NetConfig {
|
|
38
|
+
return NetConfig(workerThreads, debug)
|
|
36
39
|
}
|
|
37
40
|
}
|
|
38
41
|
}
|