@novastera-oss/nitro-metamask 0.5.6 → 0.6.3
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 +4 -1
- package/android/cargo-ecies.gradle +77 -8
- package/android/src/main/jniLibs/arm64-v8a/libecies.so +0 -0
- package/android/src/main/jniLibs/armeabi-v7a/libecies.so +0 -0
- package/android/src/main/jniLibs/x86/libecies.so +0 -0
- package/android/src/main/jniLibs/x86_64/libecies.so +0 -0
- package/lib/typescript/src/specs/nitro-metamask.nitro.d.ts +5 -5
- package/lib/typescript/src/specs/nitro-metamask.nitro.d.ts.map +1 -1
- package/nitro.json +8 -2
- package/nitrogen/generated/android/NitroMetamask+autolinking.cmake +1 -1
- package/nitrogen/generated/android/NitroMetamask+autolinking.gradle +1 -1
- package/nitrogen/generated/android/NitroMetamaskOnLoad.cpp +27 -17
- package/nitrogen/generated/android/NitroMetamaskOnLoad.hpp +14 -5
- package/nitrogen/generated/android/c++/JConnectResult.hpp +2 -2
- package/nitrogen/generated/android/c++/JConnectSignResult.hpp +2 -2
- package/nitrogen/generated/android/c++/JHybridNitroMetamaskSpec.cpp +26 -25
- package/nitrogen/generated/android/c++/JHybridNitroMetamaskSpec.hpp +20 -22
- package/nitrogen/generated/android/c++/JVariant_NullType_Long.cpp +1 -1
- package/nitrogen/generated/android/c++/JVariant_NullType_Long.hpp +4 -4
- package/nitrogen/generated/android/c++/JVariant_NullType_String.cpp +1 -1
- package/nitrogen/generated/android/c++/JVariant_NullType_String.hpp +4 -4
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrometamask/ConnectResult.kt +16 -1
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrometamask/ConnectSignResult.kt +18 -1
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrometamask/HybridNitroMetamaskSpec.kt +16 -19
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrometamask/NitroMetamaskOnLoad.kt +1 -1
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrometamask/Variant_NullType_Long.kt +15 -12
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrometamask/Variant_NullType_String.kt +15 -12
- package/nitrogen/generated/ios/NitroMetamask+autolinking.rb +3 -1
- package/nitrogen/generated/ios/NitroMetamask-Swift-Cxx-Bridge.cpp +1 -1
- package/nitrogen/generated/ios/NitroMetamask-Swift-Cxx-Bridge.hpp +2 -2
- package/nitrogen/generated/ios/NitroMetamask-Swift-Cxx-Umbrella.hpp +1 -1
- package/nitrogen/generated/ios/NitroMetamaskAutolinking.mm +1 -1
- package/nitrogen/generated/ios/NitroMetamaskAutolinking.swift +9 -8
- package/nitrogen/generated/ios/c++/HybridNitroMetamaskSpecSwift.cpp +1 -1
- package/nitrogen/generated/ios/c++/HybridNitroMetamaskSpecSwift.hpp +7 -1
- package/nitrogen/generated/ios/swift/ConnectResult.swift +1 -2
- package/nitrogen/generated/ios/swift/ConnectSignResult.swift +1 -2
- package/nitrogen/generated/ios/swift/Func_void_ConnectResult.swift +1 -2
- package/nitrogen/generated/ios/swift/Func_void_ConnectSignResult.swift +1 -2
- package/nitrogen/generated/ios/swift/Func_void_std__exception_ptr.swift +1 -2
- package/nitrogen/generated/ios/swift/Func_void_std__string.swift +1 -2
- package/nitrogen/generated/ios/swift/Func_void_std__variant_nitro__NullType__int64_t_.swift +1 -2
- package/nitrogen/generated/ios/swift/Func_void_std__variant_nitro__NullType__std__string_.swift +1 -2
- package/nitrogen/generated/ios/swift/HybridNitroMetamaskSpec.swift +3 -4
- package/nitrogen/generated/ios/swift/HybridNitroMetamaskSpec_cxx.swift +9 -2
- package/nitrogen/generated/ios/swift/Variant_NullType_Int64.swift +14 -2
- package/nitrogen/generated/ios/swift/Variant_NullType_String.swift +13 -1
- package/nitrogen/generated/shared/c++/ConnectResult.hpp +1 -1
- package/nitrogen/generated/shared/c++/ConnectSignResult.hpp +1 -1
- package/nitrogen/generated/shared/c++/HybridNitroMetamaskSpec.cpp +1 -1
- package/nitrogen/generated/shared/c++/HybridNitroMetamaskSpec.hpp +1 -1
- package/package.json +6 -8
- package/src/specs/nitro-metamask.nitro.ts +5 -5
package/README.md
CHANGED
|
@@ -54,7 +54,10 @@ Add this inside your `MainActivity` `<activity>` tag:
|
|
|
54
54
|
No extra Android configuration is required for consumers of this package.
|
|
55
55
|
|
|
56
56
|
- `@novastera-oss/nitro-metamask` excludes the legacy `io.metamask.ecies:ecies` native library from transitive dependencies.
|
|
57
|
-
- The package
|
|
57
|
+
- The package ships prebuilt `libecies.so` binaries per ABI under `android/src/main/jniLibs`.
|
|
58
|
+
- Included ABIs: `arm64-v8a`, `armeabi-v7a`, `x86_64`, `x86`.
|
|
59
|
+
- Consumers do **not** need Rust or Cargo installed.
|
|
60
|
+
- Maintainers can rebuild ECIES from source with `-PNitroMetamask_buildEciesFromSource=true`.
|
|
58
61
|
- CI verifies 16 KB ELF LOAD alignment for release native libraries before publish.
|
|
59
62
|
|
|
60
63
|
For app developers, the expected upgrade path is:
|
|
@@ -1,17 +1,72 @@
|
|
|
1
1
|
def eciesRustDir = file("${projectDir}/../rust/ecies-jni")
|
|
2
2
|
def eciesCargoToml = file("${projectDir}/../rust/ecies-jni/Cargo.toml")
|
|
3
3
|
def eciesJniOut = file("${buildDir}/intermediates/rust-ecies-jni")
|
|
4
|
+
def eciesPrebuiltDir = file("${projectDir}/src/main/jniLibs")
|
|
5
|
+
def buildEciesFromSource = (project.findProperty("NitroMetamask_buildEciesFromSource") ?: "false").toString().toBoolean()
|
|
4
6
|
|
|
5
|
-
def reactNativeArchitectures()
|
|
6
|
-
|
|
7
|
-
|
|
7
|
+
def configuredAbis = ((rootProject.getProperties().get("reactNativeArchitectures"))?.split(",")
|
|
8
|
+
?: ["armeabi-v7a", "x86", "x86_64", "arm64-v8a"]) as List<String>
|
|
9
|
+
|
|
10
|
+
def hasCargoExecutable = { ->
|
|
11
|
+
def path = System.getenv("PATH") ?: ""
|
|
12
|
+
if (path.isEmpty()) {
|
|
13
|
+
return false
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
def names = ["cargo"]
|
|
17
|
+
def isWindows = (System.getProperty("os.name") ?: "").toLowerCase().contains("win")
|
|
18
|
+
if (isWindows) {
|
|
19
|
+
names = ["cargo.exe", "cargo.bat", "cargo.cmd"]
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
for (dirPath in path.split(java.io.File.pathSeparator)) {
|
|
23
|
+
for (name in names) {
|
|
24
|
+
def candidate = new File(dirPath, name)
|
|
25
|
+
if (candidate.isFile() && candidate.canExecute()) {
|
|
26
|
+
return true
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
return false
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
def hasPrebuiltEciesForConfiguredAbis = { ->
|
|
35
|
+
def missing = []
|
|
36
|
+
configuredAbis.each { abi ->
|
|
37
|
+
def soFile = new File(eciesPrebuiltDir, "${abi}/libecies.so")
|
|
38
|
+
if (!soFile.isFile()) {
|
|
39
|
+
missing.add("${abi}/libecies.so")
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
return [available: missing.isEmpty(), missing: missing]
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
tasks.register("verifyPrebuiltEciesLibs") {
|
|
46
|
+
group = "verification"
|
|
47
|
+
description = "Verify prebuilt libecies.so exists for all configured ABIs"
|
|
48
|
+
|
|
49
|
+
doLast {
|
|
50
|
+
def result = hasPrebuiltEciesForConfiguredAbis()
|
|
51
|
+
def missing = result.missing
|
|
52
|
+
|
|
53
|
+
if (!missing.isEmpty()) {
|
|
54
|
+
throw new GradleException(
|
|
55
|
+
"Missing prebuilt ECIES native libraries under android/src/main/jniLibs: ${missing.join(', ')}. " +
|
|
56
|
+
"If this is a source checkout, install Rust + cargo-ndk and build with " +
|
|
57
|
+
"-PNitroMetamask_buildEciesFromSource=true."
|
|
58
|
+
)
|
|
59
|
+
}
|
|
60
|
+
}
|
|
8
61
|
}
|
|
9
62
|
|
|
10
63
|
tasks.register("cargoNdkBuildEcies", Exec) {
|
|
11
64
|
group = "build"
|
|
12
|
-
description = "Build libecies.so via Rust (
|
|
65
|
+
description = "Build libecies.so via Rust (maintainer-only)"
|
|
13
66
|
onlyIf {
|
|
14
|
-
|
|
67
|
+
def prebuiltStatus = hasPrebuiltEciesForConfiguredAbis()
|
|
68
|
+
(buildEciesFromSource || !prebuiltStatus.available) &&
|
|
69
|
+
eciesRustDir.isDirectory() && eciesCargoToml.isFile()
|
|
15
70
|
}
|
|
16
71
|
workingDir eciesRustDir
|
|
17
72
|
standardOutput System.out
|
|
@@ -26,11 +81,17 @@ afterEvaluate {
|
|
|
26
81
|
def ndkDir = (ndkProp instanceof File) ? ndkProp : ndkProp.get().asFile
|
|
27
82
|
def ndkPath = ndkDir.absolutePath
|
|
28
83
|
def ndkVer = project.android.ndkVersion
|
|
29
|
-
def abis =
|
|
84
|
+
def abis = configuredAbis
|
|
30
85
|
def outPath = eciesJniOut.absolutePath
|
|
31
|
-
|
|
32
86
|
tasks.named("cargoNdkBuildEcies", Exec).configure {
|
|
33
87
|
doFirst {
|
|
88
|
+
if (!hasCargoExecutable()) {
|
|
89
|
+
throw new GradleException(
|
|
90
|
+
"Cargo is not available. This build mode is maintainer-only. " +
|
|
91
|
+
"Run without -PNitroMetamask_buildEciesFromSource to use bundled prebuilt libraries."
|
|
92
|
+
)
|
|
93
|
+
}
|
|
94
|
+
|
|
34
95
|
eciesJniOut.mkdirs()
|
|
35
96
|
if (!ndkDir.exists()) {
|
|
36
97
|
throw new GradleException("ANDROID NDK not found; ndkVersion is ${ndkVer}")
|
|
@@ -48,7 +109,15 @@ afterEvaluate {
|
|
|
48
109
|
}
|
|
49
110
|
}
|
|
50
111
|
|
|
112
|
+
def prebuiltStatus = hasPrebuiltEciesForConfiguredAbis()
|
|
113
|
+
def canBuildFromSource = hasCargoExecutable() && eciesRustDir.isDirectory() && eciesCargoToml.isFile()
|
|
114
|
+
def shouldBuildFromSource = buildEciesFromSource || (!prebuiltStatus.available && canBuildFromSource)
|
|
115
|
+
|
|
51
116
|
tasks.matching { it.name.startsWith("preBuild") }.configureEach {
|
|
52
|
-
|
|
117
|
+
if (shouldBuildFromSource) {
|
|
118
|
+
dependsOn("cargoNdkBuildEcies")
|
|
119
|
+
} else {
|
|
120
|
+
dependsOn("verifyPrebuiltEciesLibs")
|
|
121
|
+
}
|
|
53
122
|
}
|
|
54
123
|
}
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { type HybridObject } from 'react-native-nitro-modules';
|
|
1
|
+
import { type HybridObject, type Int64 } from 'react-native-nitro-modules';
|
|
2
2
|
export interface ConnectResult {
|
|
3
3
|
address: string;
|
|
4
|
-
chainId:
|
|
4
|
+
chainId: Int64;
|
|
5
5
|
}
|
|
6
6
|
export interface ConnectSignResult {
|
|
7
7
|
signature: string;
|
|
8
8
|
address: string;
|
|
9
|
-
chainId:
|
|
9
|
+
chainId: Int64;
|
|
10
10
|
}
|
|
11
11
|
export interface NitroMetamask extends HybridObject<{
|
|
12
12
|
ios: 'swift';
|
|
@@ -33,7 +33,7 @@ export interface NitroMetamask extends HybridObject<{
|
|
|
33
33
|
* @param exp - Expiration timestamp (as bigint)
|
|
34
34
|
* @returns Promise resolving to ConnectSignResult containing signature, address, and chainId
|
|
35
35
|
*/
|
|
36
|
-
connectSign(nonce: string, exp:
|
|
36
|
+
connectSign(nonce: string, exp: Int64): Promise<ConnectSignResult>;
|
|
37
37
|
/**
|
|
38
38
|
* Get the currently connected wallet address.
|
|
39
39
|
* Returns null if not connected.
|
|
@@ -43,6 +43,6 @@ export interface NitroMetamask extends HybridObject<{
|
|
|
43
43
|
* Get the current chain ID.
|
|
44
44
|
* Returns null if not connected.
|
|
45
45
|
*/
|
|
46
|
-
getChainId(): Promise<
|
|
46
|
+
getChainId(): Promise<Int64 | null>;
|
|
47
47
|
}
|
|
48
48
|
//# sourceMappingURL=nitro-metamask.nitro.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"nitro-metamask.nitro.d.ts","sourceRoot":"","sources":["../../../../src/specs/nitro-metamask.nitro.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,4BAA4B,CAAA;
|
|
1
|
+
{"version":3,"file":"nitro-metamask.nitro.d.ts","sourceRoot":"","sources":["../../../../src/specs/nitro-metamask.nitro.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,YAAY,EAAE,KAAK,KAAK,EAAE,MAAM,4BAA4B,CAAA;AAE1E,MAAM,WAAW,aAAa;IAC5B,OAAO,EAAE,MAAM,CAAA;IACf,OAAO,EAAE,KAAK,CAAA;CACf;AAED,MAAM,WAAW,iBAAiB;IAChC,SAAS,EAAE,MAAM,CAAA;IACjB,OAAO,EAAE,MAAM,CAAA;IACf,OAAO,EAAE,KAAK,CAAA;CACf;AAED,MAAM,WAAW,aAAc,SAAQ,YAAY,CAAC;IAAE,GAAG,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,QAAQ,CAAA;CAAE,CAAC;IACtF;;;;;;;;;OASG;IACH,SAAS,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC1D,OAAO,IAAI,OAAO,CAAC,aAAa,CAAC,CAAA;IACjC,WAAW,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;IAC7C;;;;;;;OAOG;IACH,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAA;IAClE;;;OAGG;IACH,UAAU,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAA;IACpC;;;OAGG;IACH,UAAU,IAAI,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,CAAA;CACpC"}
|
package/nitro.json
CHANGED
|
@@ -14,8 +14,14 @@
|
|
|
14
14
|
},
|
|
15
15
|
"autolinking": {
|
|
16
16
|
"NitroMetamask": {
|
|
17
|
-
"
|
|
18
|
-
|
|
17
|
+
"ios": {
|
|
18
|
+
"language": "swift",
|
|
19
|
+
"implementationClassName": "HybridNitroMetamask"
|
|
20
|
+
},
|
|
21
|
+
"android": {
|
|
22
|
+
"language": "kotlin",
|
|
23
|
+
"implementationClassName": "HybridNitroMetamask"
|
|
24
|
+
}
|
|
19
25
|
}
|
|
20
26
|
},
|
|
21
27
|
"ignorePaths": [
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
# NitroMetamask+autolinking.cmake
|
|
3
3
|
# This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
4
|
# https://github.com/mrousavy/nitro
|
|
5
|
-
# Copyright ©
|
|
5
|
+
# Copyright © Marc Rousavy @ Margelo
|
|
6
6
|
#
|
|
7
7
|
|
|
8
8
|
# This is a CMake file that adds all files generated by Nitrogen
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
/// NitroMetamask+autolinking.gradle
|
|
3
3
|
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
4
|
/// https://github.com/mrousavy/nitro
|
|
5
|
-
/// Copyright ©
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
6
|
///
|
|
7
7
|
|
|
8
8
|
/// This is a Gradle file that adds all files generated by Nitrogen
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
/// NitroMetamaskOnLoad.cpp
|
|
3
3
|
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
4
|
/// https://github.com/mrousavy/nitro
|
|
5
|
-
/// Copyright ©
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
6
|
///
|
|
7
7
|
|
|
8
8
|
#ifndef BUILDING_NITROMETAMASK_WITH_GENERATED_CMAKE_PROJECT
|
|
@@ -21,24 +21,34 @@
|
|
|
21
21
|
namespace margelo::nitro::nitrometamask {
|
|
22
22
|
|
|
23
23
|
int initialize(JavaVM* vm) {
|
|
24
|
+
return facebook::jni::initialize(vm, []() {
|
|
25
|
+
::margelo::nitro::nitrometamask::registerAllNatives();
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
struct JHybridNitroMetamaskSpecImpl: public jni::JavaClass<JHybridNitroMetamaskSpecImpl, JHybridNitroMetamaskSpec::JavaPart> {
|
|
30
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/nitrometamask/HybridNitroMetamask;";
|
|
31
|
+
static std::shared_ptr<JHybridNitroMetamaskSpec> create() {
|
|
32
|
+
static const auto constructorFn = javaClassStatic()->getConstructor<JHybridNitroMetamaskSpecImpl::javaobject()>();
|
|
33
|
+
jni::local_ref<JHybridNitroMetamaskSpec::JavaPart> javaPart = javaClassStatic()->newObject(constructorFn);
|
|
34
|
+
return javaPart->getJHybridNitroMetamaskSpec();
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
void registerAllNatives() {
|
|
24
39
|
using namespace margelo::nitro;
|
|
25
40
|
using namespace margelo::nitro::nitrometamask;
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
auto instance = object.create();
|
|
38
|
-
return instance->cthis()->shared();
|
|
39
|
-
}
|
|
40
|
-
);
|
|
41
|
-
});
|
|
41
|
+
|
|
42
|
+
// Register native JNI methods
|
|
43
|
+
margelo::nitro::nitrometamask::JHybridNitroMetamaskSpec::CxxPart::registerNatives();
|
|
44
|
+
|
|
45
|
+
// Register Nitro Hybrid Objects
|
|
46
|
+
HybridObjectRegistry::registerHybridObjectConstructor(
|
|
47
|
+
"NitroMetamask",
|
|
48
|
+
[]() -> std::shared_ptr<HybridObject> {
|
|
49
|
+
return JHybridNitroMetamaskSpecImpl::create();
|
|
50
|
+
}
|
|
51
|
+
);
|
|
42
52
|
}
|
|
43
53
|
|
|
44
54
|
} // namespace margelo::nitro::nitrometamask
|
|
@@ -2,24 +2,33 @@
|
|
|
2
2
|
/// NitroMetamaskOnLoad.hpp
|
|
3
3
|
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
4
|
/// https://github.com/mrousavy/nitro
|
|
5
|
-
/// Copyright ©
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
6
|
///
|
|
7
7
|
|
|
8
8
|
#include <jni.h>
|
|
9
|
+
#include <functional>
|
|
9
10
|
#include <NitroModules/NitroDefines.hpp>
|
|
10
11
|
|
|
11
12
|
namespace margelo::nitro::nitrometamask {
|
|
12
13
|
|
|
14
|
+
[[deprecated("Use registerNatives() instead.")]]
|
|
15
|
+
int initialize(JavaVM* vm);
|
|
16
|
+
|
|
13
17
|
/**
|
|
14
|
-
*
|
|
15
|
-
* Call this in your `JNI_OnLoad` function (probably inside `cpp-adapter.cpp`)
|
|
18
|
+
* Register the native (C++) part of NitroMetamask, and autolinks all Hybrid Objects.
|
|
19
|
+
* Call this in your `JNI_OnLoad` function (probably inside `cpp-adapter.cpp`),
|
|
20
|
+
* inside a `facebook::jni::initialize(vm, ...)` call.
|
|
16
21
|
* Example:
|
|
17
22
|
* ```cpp (cpp-adapter.cpp)
|
|
18
23
|
* JNIEXPORT jint JNICALL JNI_OnLoad(JavaVM* vm, void*) {
|
|
19
|
-
* return
|
|
24
|
+
* return facebook::jni::initialize(vm, []() {
|
|
25
|
+
* // register all NitroMetamask HybridObjects
|
|
26
|
+
* margelo::nitro::nitrometamask::registerNatives();
|
|
27
|
+
* // any other custom registrations go here.
|
|
28
|
+
* });
|
|
20
29
|
* }
|
|
21
30
|
* ```
|
|
22
31
|
*/
|
|
23
|
-
|
|
32
|
+
void registerAllNatives();
|
|
24
33
|
|
|
25
34
|
} // namespace margelo::nitro::nitrometamask
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
/// JConnectResult.hpp
|
|
3
3
|
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
4
|
/// https://github.com/mrousavy/nitro
|
|
5
|
-
/// Copyright ©
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
6
|
///
|
|
7
7
|
|
|
8
8
|
#pragma once
|
|
@@ -21,7 +21,7 @@ namespace margelo::nitro::nitrometamask {
|
|
|
21
21
|
*/
|
|
22
22
|
struct JConnectResult final: public jni::JavaClass<JConnectResult> {
|
|
23
23
|
public:
|
|
24
|
-
static auto
|
|
24
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/nitrometamask/ConnectResult;";
|
|
25
25
|
|
|
26
26
|
public:
|
|
27
27
|
/**
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
/// JConnectSignResult.hpp
|
|
3
3
|
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
4
|
/// https://github.com/mrousavy/nitro
|
|
5
|
-
/// Copyright ©
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
6
|
///
|
|
7
7
|
|
|
8
8
|
#pragma once
|
|
@@ -21,7 +21,7 @@ namespace margelo::nitro::nitrometamask {
|
|
|
21
21
|
*/
|
|
22
22
|
struct JConnectSignResult final: public jni::JavaClass<JConnectSignResult> {
|
|
23
23
|
public:
|
|
24
|
-
static auto
|
|
24
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/nitrometamask/ConnectSignResult;";
|
|
25
25
|
|
|
26
26
|
public:
|
|
27
27
|
/**
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
/// JHybridNitroMetamaskSpec.cpp
|
|
3
3
|
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
4
|
/// https://github.com/mrousavy/nitro
|
|
5
|
-
/// Copyright ©
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
6
|
///
|
|
7
7
|
|
|
8
8
|
#include "JHybridNitroMetamaskSpec.hpp"
|
|
@@ -28,30 +28,31 @@ namespace margelo::nitro::nitrometamask { struct ConnectSignResult; }
|
|
|
28
28
|
|
|
29
29
|
namespace margelo::nitro::nitrometamask {
|
|
30
30
|
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
});
|
|
31
|
+
std::shared_ptr<JHybridNitroMetamaskSpec> JHybridNitroMetamaskSpec::JavaPart::getJHybridNitroMetamaskSpec() {
|
|
32
|
+
auto hybridObject = JHybridObject::JavaPart::getJHybridObject();
|
|
33
|
+
auto castHybridObject = std::dynamic_pointer_cast<JHybridNitroMetamaskSpec>(hybridObject);
|
|
34
|
+
if (castHybridObject == nullptr) [[unlikely]] {
|
|
35
|
+
throw std::runtime_error("Failed to downcast JHybridObject to JHybridNitroMetamaskSpec!");
|
|
36
|
+
}
|
|
37
|
+
return castHybridObject;
|
|
39
38
|
}
|
|
40
39
|
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
return method(_javaPart);
|
|
40
|
+
jni::local_ref<JHybridNitroMetamaskSpec::CxxPart::jhybriddata> JHybridNitroMetamaskSpec::CxxPart::initHybrid(jni::alias_ref<jhybridobject> jThis) {
|
|
41
|
+
return makeCxxInstance(jThis);
|
|
44
42
|
}
|
|
45
43
|
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
44
|
+
std::shared_ptr<JHybridObject> JHybridNitroMetamaskSpec::CxxPart::createHybridObject(const jni::local_ref<JHybridObject::JavaPart>& javaPart) {
|
|
45
|
+
auto castJavaPart = jni::dynamic_ref_cast<JHybridNitroMetamaskSpec::JavaPart>(javaPart);
|
|
46
|
+
if (castJavaPart == nullptr) [[unlikely]] {
|
|
47
|
+
throw std::runtime_error("Failed to cast JHybridObject::JavaPart to JHybridNitroMetamaskSpec::JavaPart!");
|
|
48
|
+
}
|
|
49
|
+
return std::make_shared<JHybridNitroMetamaskSpec>(castJavaPart);
|
|
49
50
|
}
|
|
50
51
|
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
52
|
+
void JHybridNitroMetamaskSpec::CxxPart::registerNatives() {
|
|
53
|
+
registerHybrid({
|
|
54
|
+
makeNativeMethod("initHybrid", JHybridNitroMetamaskSpec::CxxPart::initHybrid),
|
|
55
|
+
});
|
|
55
56
|
}
|
|
56
57
|
|
|
57
58
|
// Properties
|
|
@@ -59,11 +60,11 @@ namespace margelo::nitro::nitrometamask {
|
|
|
59
60
|
|
|
60
61
|
// Methods
|
|
61
62
|
void JHybridNitroMetamaskSpec::configure(const std::optional<std::string>& dappUrl, const std::optional<std::string>& deepLinkScheme) {
|
|
62
|
-
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<jni::JString> /* dappUrl */, jni::alias_ref<jni::JString> /* deepLinkScheme */)>("configure");
|
|
63
|
+
static const auto method = _javaPart->javaClassStatic()->getMethod<void(jni::alias_ref<jni::JString> /* dappUrl */, jni::alias_ref<jni::JString> /* deepLinkScheme */)>("configure");
|
|
63
64
|
method(_javaPart, dappUrl.has_value() ? jni::make_jstring(dappUrl.value()) : nullptr, deepLinkScheme.has_value() ? jni::make_jstring(deepLinkScheme.value()) : nullptr);
|
|
64
65
|
}
|
|
65
66
|
std::shared_ptr<Promise<ConnectResult>> JHybridNitroMetamaskSpec::connect() {
|
|
66
|
-
static const auto method = javaClassStatic()->getMethod<jni::local_ref<JPromise::javaobject>()>("connect");
|
|
67
|
+
static const auto method = _javaPart->javaClassStatic()->getMethod<jni::local_ref<JPromise::javaobject>()>("connect");
|
|
67
68
|
auto __result = method(_javaPart);
|
|
68
69
|
return [&]() {
|
|
69
70
|
auto __promise = Promise<ConnectResult>::create();
|
|
@@ -79,7 +80,7 @@ namespace margelo::nitro::nitrometamask {
|
|
|
79
80
|
}();
|
|
80
81
|
}
|
|
81
82
|
std::shared_ptr<Promise<std::string>> JHybridNitroMetamaskSpec::signMessage(const std::string& message) {
|
|
82
|
-
static const auto method = javaClassStatic()->getMethod<jni::local_ref<JPromise::javaobject>(jni::alias_ref<jni::JString> /* message */)>("signMessage");
|
|
83
|
+
static const auto method = _javaPart->javaClassStatic()->getMethod<jni::local_ref<JPromise::javaobject>(jni::alias_ref<jni::JString> /* message */)>("signMessage");
|
|
83
84
|
auto __result = method(_javaPart, jni::make_jstring(message));
|
|
84
85
|
return [&]() {
|
|
85
86
|
auto __promise = Promise<std::string>::create();
|
|
@@ -95,7 +96,7 @@ namespace margelo::nitro::nitrometamask {
|
|
|
95
96
|
}();
|
|
96
97
|
}
|
|
97
98
|
std::shared_ptr<Promise<ConnectSignResult>> JHybridNitroMetamaskSpec::connectSign(const std::string& nonce, int64_t exp) {
|
|
98
|
-
static const auto method = javaClassStatic()->getMethod<jni::local_ref<JPromise::javaobject>(jni::alias_ref<jni::JString> /* nonce */, int64_t /* exp */)>("connectSign");
|
|
99
|
+
static const auto method = _javaPart->javaClassStatic()->getMethod<jni::local_ref<JPromise::javaobject>(jni::alias_ref<jni::JString> /* nonce */, int64_t /* exp */)>("connectSign");
|
|
99
100
|
auto __result = method(_javaPart, jni::make_jstring(nonce), exp);
|
|
100
101
|
return [&]() {
|
|
101
102
|
auto __promise = Promise<ConnectSignResult>::create();
|
|
@@ -111,7 +112,7 @@ namespace margelo::nitro::nitrometamask {
|
|
|
111
112
|
}();
|
|
112
113
|
}
|
|
113
114
|
std::shared_ptr<Promise<std::variant<nitro::NullType, std::string>>> JHybridNitroMetamaskSpec::getAddress() {
|
|
114
|
-
static const auto method = javaClassStatic()->getMethod<jni::local_ref<JPromise::javaobject>()>("getAddress");
|
|
115
|
+
static const auto method = _javaPart->javaClassStatic()->getMethod<jni::local_ref<JPromise::javaobject>()>("getAddress");
|
|
115
116
|
auto __result = method(_javaPart);
|
|
116
117
|
return [&]() {
|
|
117
118
|
auto __promise = Promise<std::variant<nitro::NullType, std::string>>::create();
|
|
@@ -127,7 +128,7 @@ namespace margelo::nitro::nitrometamask {
|
|
|
127
128
|
}();
|
|
128
129
|
}
|
|
129
130
|
std::shared_ptr<Promise<std::variant<nitro::NullType, int64_t>>> JHybridNitroMetamaskSpec::getChainId() {
|
|
130
|
-
static const auto method = javaClassStatic()->getMethod<jni::local_ref<JPromise::javaobject>()>("getChainId");
|
|
131
|
+
static const auto method = _javaPart->javaClassStatic()->getMethod<jni::local_ref<JPromise::javaobject>()>("getChainId");
|
|
131
132
|
auto __result = method(_javaPart);
|
|
132
133
|
return [&]() {
|
|
133
134
|
auto __promise = Promise<std::variant<nitro::NullType, int64_t>>::create();
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
/// HybridNitroMetamaskSpec.hpp
|
|
3
3
|
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
4
|
/// https://github.com/mrousavy/nitro
|
|
5
|
-
/// Copyright ©
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
6
|
///
|
|
7
7
|
|
|
8
8
|
#pragma once
|
|
@@ -18,33 +18,33 @@ namespace margelo::nitro::nitrometamask {
|
|
|
18
18
|
|
|
19
19
|
using namespace facebook;
|
|
20
20
|
|
|
21
|
-
class JHybridNitroMetamaskSpec: public
|
|
22
|
-
public virtual HybridNitroMetamaskSpec {
|
|
21
|
+
class JHybridNitroMetamaskSpec: public virtual HybridNitroMetamaskSpec, public virtual JHybridObject {
|
|
23
22
|
public:
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
HybridBase
|
|
33
|
-
|
|
23
|
+
struct JavaPart: public jni::JavaClass<JavaPart, JHybridObject::JavaPart> {
|
|
24
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/nitrometamask/HybridNitroMetamaskSpec;";
|
|
25
|
+
std::shared_ptr<JHybridNitroMetamaskSpec> getJHybridNitroMetamaskSpec();
|
|
26
|
+
};
|
|
27
|
+
struct CxxPart: public jni::HybridClass<CxxPart, JHybridObject::CxxPart> {
|
|
28
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/nitrometamask/HybridNitroMetamaskSpec$CxxPart;";
|
|
29
|
+
static jni::local_ref<jhybriddata> initHybrid(jni::alias_ref<jhybridobject> jThis);
|
|
30
|
+
static void registerNatives();
|
|
31
|
+
using HybridBase::HybridBase;
|
|
32
|
+
protected:
|
|
33
|
+
std::shared_ptr<JHybridObject> createHybridObject(const jni::local_ref<JHybridObject::JavaPart>& javaPart) override;
|
|
34
|
+
};
|
|
34
35
|
|
|
35
36
|
public:
|
|
37
|
+
explicit JHybridNitroMetamaskSpec(const jni::local_ref<JHybridNitroMetamaskSpec::JavaPart>& javaPart):
|
|
38
|
+
HybridObject(HybridNitroMetamaskSpec::TAG),
|
|
39
|
+
JHybridObject(javaPart),
|
|
40
|
+
_javaPart(jni::make_global(javaPart)) {}
|
|
36
41
|
~JHybridNitroMetamaskSpec() override {
|
|
37
42
|
// Hermes GC can destroy JS objects on a non-JNI Thread.
|
|
38
43
|
jni::ThreadScope::WithClassLoader([&] { _javaPart.reset(); });
|
|
39
44
|
}
|
|
40
45
|
|
|
41
46
|
public:
|
|
42
|
-
|
|
43
|
-
void dispose() noexcept override;
|
|
44
|
-
std::string toString() override;
|
|
45
|
-
|
|
46
|
-
public:
|
|
47
|
-
inline const jni::global_ref<JHybridNitroMetamaskSpec::javaobject>& getJavaPart() const noexcept {
|
|
47
|
+
inline const jni::global_ref<JHybridNitroMetamaskSpec::JavaPart>& getJavaPart() const noexcept {
|
|
48
48
|
return _javaPart;
|
|
49
49
|
}
|
|
50
50
|
|
|
@@ -62,9 +62,7 @@ namespace margelo::nitro::nitrometamask {
|
|
|
62
62
|
std::shared_ptr<Promise<std::variant<nitro::NullType, int64_t>>> getChainId() override;
|
|
63
63
|
|
|
64
64
|
private:
|
|
65
|
-
|
|
66
|
-
using HybridBase::HybridBase;
|
|
67
|
-
jni::global_ref<JHybridNitroMetamaskSpec::javaobject> _javaPart;
|
|
65
|
+
jni::global_ref<JHybridNitroMetamaskSpec::JavaPart> _javaPart;
|
|
68
66
|
};
|
|
69
67
|
|
|
70
68
|
} // namespace margelo::nitro::nitrometamask
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
/// JVariant_NullType_Long.cpp
|
|
3
3
|
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
4
|
/// https://github.com/mrousavy/nitro
|
|
5
|
-
/// Copyright ©
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
6
|
///
|
|
7
7
|
|
|
8
8
|
#include "JVariant_NullType_Long.hpp"
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
/// JVariant_NullType_Long.hpp
|
|
3
3
|
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
4
|
/// https://github.com/mrousavy/nitro
|
|
5
|
-
/// Copyright ©
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
6
|
///
|
|
7
7
|
|
|
8
8
|
#pragma once
|
|
@@ -23,7 +23,7 @@ namespace margelo::nitro::nitrometamask {
|
|
|
23
23
|
*/
|
|
24
24
|
class JVariant_NullType_Long: public jni::JavaClass<JVariant_NullType_Long> {
|
|
25
25
|
public:
|
|
26
|
-
static auto
|
|
26
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/nitrometamask/Variant_NullType_Long;";
|
|
27
27
|
|
|
28
28
|
static jni::local_ref<JVariant_NullType_Long> create_0(jni::alias_ref<JNull> value) {
|
|
29
29
|
static const auto method = javaClassStatic()->getStaticMethod<JVariant_NullType_Long(jni::alias_ref<JNull>)>("create");
|
|
@@ -48,7 +48,7 @@ namespace margelo::nitro::nitrometamask {
|
|
|
48
48
|
namespace JVariant_NullType_Long_impl {
|
|
49
49
|
class First final: public jni::JavaClass<First, JVariant_NullType_Long> {
|
|
50
50
|
public:
|
|
51
|
-
static auto
|
|
51
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/nitrometamask/Variant_NullType_Long$First;";
|
|
52
52
|
|
|
53
53
|
[[nodiscard]] jni::local_ref<JNull> getValue() const {
|
|
54
54
|
static const auto field = javaClassStatic()->getField<JNull>("value");
|
|
@@ -58,7 +58,7 @@ namespace margelo::nitro::nitrometamask {
|
|
|
58
58
|
|
|
59
59
|
class Second final: public jni::JavaClass<Second, JVariant_NullType_Long> {
|
|
60
60
|
public:
|
|
61
|
-
static auto
|
|
61
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/nitrometamask/Variant_NullType_Long$Second;";
|
|
62
62
|
|
|
63
63
|
[[nodiscard]] int64_t getValue() const {
|
|
64
64
|
static const auto field = javaClassStatic()->getField<int64_t>("value");
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
/// JVariant_NullType_String.cpp
|
|
3
3
|
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
4
|
/// https://github.com/mrousavy/nitro
|
|
5
|
-
/// Copyright ©
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
6
|
///
|
|
7
7
|
|
|
8
8
|
#include "JVariant_NullType_String.hpp"
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
/// JVariant_NullType_String.hpp
|
|
3
3
|
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
4
|
/// https://github.com/mrousavy/nitro
|
|
5
|
-
/// Copyright ©
|
|
5
|
+
/// Copyright © Marc Rousavy @ Margelo
|
|
6
6
|
///
|
|
7
7
|
|
|
8
8
|
#pragma once
|
|
@@ -24,7 +24,7 @@ namespace margelo::nitro::nitrometamask {
|
|
|
24
24
|
*/
|
|
25
25
|
class JVariant_NullType_String: public jni::JavaClass<JVariant_NullType_String> {
|
|
26
26
|
public:
|
|
27
|
-
static auto
|
|
27
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/nitrometamask/Variant_NullType_String;";
|
|
28
28
|
|
|
29
29
|
static jni::local_ref<JVariant_NullType_String> create_0(jni::alias_ref<JNull> value) {
|
|
30
30
|
static const auto method = javaClassStatic()->getStaticMethod<JVariant_NullType_String(jni::alias_ref<JNull>)>("create");
|
|
@@ -49,7 +49,7 @@ namespace margelo::nitro::nitrometamask {
|
|
|
49
49
|
namespace JVariant_NullType_String_impl {
|
|
50
50
|
class First final: public jni::JavaClass<First, JVariant_NullType_String> {
|
|
51
51
|
public:
|
|
52
|
-
static auto
|
|
52
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/nitrometamask/Variant_NullType_String$First;";
|
|
53
53
|
|
|
54
54
|
[[nodiscard]] jni::local_ref<JNull> getValue() const {
|
|
55
55
|
static const auto field = javaClassStatic()->getField<JNull>("value");
|
|
@@ -59,7 +59,7 @@ namespace margelo::nitro::nitrometamask {
|
|
|
59
59
|
|
|
60
60
|
class Second final: public jni::JavaClass<Second, JVariant_NullType_String> {
|
|
61
61
|
public:
|
|
62
|
-
static auto
|
|
62
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/nitrometamask/Variant_NullType_String$Second;";
|
|
63
63
|
|
|
64
64
|
[[nodiscard]] jni::local_ref<jni::JString> getValue() const {
|
|
65
65
|
static const auto field = javaClassStatic()->getField<jni::JString>("value");
|