react-native-security-pack 1.0.1 → 2.0.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 +181 -13
- package/android/CMakeLists.txt +24 -0
- package/android/build.gradle +55 -60
- package/android/fix-prefab.gradle +44 -0
- package/android/gradle.properties +5 -5
- package/android/src/main/cpp/cpp-adapter.cpp +6 -0
- package/android/src/main/java/com/leerman/rnsecuritypack/RNSecurityPackPackage.kt +23 -0
- package/android/src/main/java/com/margelo/nitro/rnsecuritypack/HybridSecurityPack.kt +85 -0
- package/ios/HybridSecurityPack.swift +17 -0
- package/jest/mock.js +7 -0
- package/lib/commonjs/index.js +24 -17
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/specs/SecurityPack.nitro.js +6 -0
- package/lib/commonjs/specs/SecurityPack.nitro.js.map +1 -0
- package/lib/module/index.js +25 -18
- package/lib/module/index.js.map +1 -1
- package/lib/module/specs/SecurityPack.nitro.js +4 -0
- package/lib/module/specs/SecurityPack.nitro.js.map +1 -0
- package/lib/typescript/commonjs/src/index.d.ts +7 -0
- package/lib/typescript/commonjs/src/index.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/specs/SecurityPack.nitro.d.ts +9 -0
- package/lib/typescript/commonjs/src/specs/SecurityPack.nitro.d.ts.map +1 -0
- package/lib/typescript/module/src/index.d.ts +7 -0
- package/lib/typescript/module/src/index.d.ts.map +1 -1
- package/lib/typescript/module/src/specs/SecurityPack.nitro.d.ts +9 -0
- package/lib/typescript/module/src/specs/SecurityPack.nitro.d.ts.map +1 -0
- package/nitro.json +24 -0
- package/nitrogen/generated/.gitattributes +1 -0
- package/nitrogen/generated/android/RNSecurityPack+autolinking.cmake +81 -0
- package/nitrogen/generated/android/RNSecurityPack+autolinking.gradle +27 -0
- package/nitrogen/generated/android/RNSecurityPackOnLoad.cpp +54 -0
- package/nitrogen/generated/android/RNSecurityPackOnLoad.hpp +34 -0
- package/nitrogen/generated/android/c++/JHybridSecurityPackSpec.cpp +92 -0
- package/nitrogen/generated/android/c++/JHybridSecurityPackSpec.hpp +64 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/rnsecuritypack/HybridSecurityPackSpec.kt +59 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/rnsecuritypack/RNSecurityPackOnLoad.kt +35 -0
- package/nitrogen/generated/ios/RNSecurityPack+autolinking.rb +62 -0
- package/nitrogen/generated/ios/RNSecurityPack-Swift-Cxx-Bridge.cpp +57 -0
- package/nitrogen/generated/ios/RNSecurityPack-Swift-Cxx-Bridge.hpp +166 -0
- package/nitrogen/generated/ios/RNSecurityPack-Swift-Cxx-Umbrella.hpp +46 -0
- package/nitrogen/generated/ios/RNSecurityPackAutolinking.mm +33 -0
- package/nitrogen/generated/ios/RNSecurityPackAutolinking.swift +26 -0
- package/nitrogen/generated/ios/c++/HybridSecurityPackSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridSecurityPackSpecSwift.hpp +92 -0
- package/nitrogen/generated/ios/swift/Func_void_bool.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_std__exception_ptr.swift +46 -0
- package/nitrogen/generated/ios/swift/Func_void_std__vector_std__string_.swift +46 -0
- package/nitrogen/generated/ios/swift/HybridSecurityPackSpec.swift +56 -0
- package/nitrogen/generated/ios/swift/HybridSecurityPackSpec_cxx.swift +170 -0
- package/nitrogen/generated/shared/c++/HybridSecurityPackSpec.cpp +22 -0
- package/nitrogen/generated/shared/c++/HybridSecurityPackSpec.hpp +65 -0
- package/package.json +36 -42
- package/react-native-security-pack.podspec +18 -27
- package/react-native.config.js +1 -0
- package/src/index.ts +39 -0
- package/src/specs/SecurityPack.nitro.ts +7 -0
- package/android/src/main/AndroidManifestNew.xml +0 -2
- package/android/src/main/java/com/leerman/rnsecuritypack/SecurityPackModule.kt +0 -85
- package/android/src/main/java/com/leerman/rnsecuritypack/SecurityPackPackage.kt +0 -35
- package/android/src/newarch/SecurityPackSpec.kt +0 -7
- package/android/src/oldarch/SecurityPackSpec.kt +0 -12
- package/ios/SecurityPack.h +0 -12
- package/ios/SecurityPack.mm +0 -25
- package/lib/commonjs/NativeSecurityPack.js +0 -9
- package/lib/commonjs/NativeSecurityPack.js.map +0 -1
- package/lib/module/NativeSecurityPack.js +0 -5
- package/lib/module/NativeSecurityPack.js.map +0 -1
- package/lib/typescript/commonjs/src/NativeSecurityPack.d.ts +0 -8
- package/lib/typescript/commonjs/src/NativeSecurityPack.d.ts.map +0 -1
- package/lib/typescript/module/src/NativeSecurityPack.d.ts +0 -8
- package/lib/typescript/module/src/NativeSecurityPack.d.ts.map +0 -1
- package/src/NativeSecurityPack.ts +0 -9
- package/src/index.tsx +0 -43
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/SecurityPack.nitro.ts"],"mappings":"","ignoreList":[]}
|
package/lib/module/index.js
CHANGED
|
@@ -1,29 +1,36 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
// @ts-expect-error
|
|
10
|
-
const isTurboModuleEnabled = global.__turboModuleProxy != null;
|
|
11
|
-
const SecurityPackModule = isTurboModuleEnabled ? require('./NativeSecurityPack').default : NativeModules.SecurityPack;
|
|
12
|
-
const SecurityPack = SecurityPackModule ? SecurityPackModule : new Proxy({}, {
|
|
13
|
-
get() {
|
|
14
|
-
throw new Error(LINKING_ERROR);
|
|
3
|
+
import { Platform } from 'react-native';
|
|
4
|
+
import { NitroModules } from 'react-native-nitro-modules';
|
|
5
|
+
let securityPack = null;
|
|
6
|
+
function getSecurityPack() {
|
|
7
|
+
if (securityPack == null) {
|
|
8
|
+
securityPack = NitroModules.createHybridObject('SecurityPack');
|
|
15
9
|
}
|
|
16
|
-
|
|
10
|
+
return securityPack;
|
|
11
|
+
}
|
|
17
12
|
async function getSignatures() {
|
|
18
|
-
|
|
13
|
+
const signatures = await getSecurityPack().getSignatures();
|
|
14
|
+
return signatures.map(item => item.toUpperCase());
|
|
19
15
|
}
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Checks whether the app's signing certificate matches any of the given SHA-1
|
|
19
|
+
* fingerprints (hex, case-insensitive).
|
|
20
|
+
*
|
|
21
|
+
* On iOS this always returns `true` because APK signatures are Android-only.
|
|
22
|
+
*/
|
|
20
23
|
export async function containsSignatures(sigs) {
|
|
21
|
-
if (Platform.OS === 'ios')
|
|
24
|
+
if (Platform.OS === 'ios') {
|
|
25
|
+
return true;
|
|
26
|
+
}
|
|
22
27
|
const signatures = await getSignatures();
|
|
23
|
-
const
|
|
24
|
-
return signatures.some(item =>
|
|
28
|
+
const expected = sigs.map(item => item.toUpperCase());
|
|
29
|
+
return signatures.some(item => expected.includes(item));
|
|
25
30
|
}
|
|
31
|
+
|
|
32
|
+
/** Returns `true` when the device appears to be rooted (Android) or jailbroken (iOS). */
|
|
26
33
|
export async function isRooted() {
|
|
27
|
-
return
|
|
34
|
+
return await getSecurityPack().isRooted();
|
|
28
35
|
}
|
|
29
36
|
//# sourceMappingURL=index.js.map
|
package/lib/module/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["Platform","NitroModules","securityPack","getSecurityPack","createHybridObject","getSignatures","signatures","map","item","toUpperCase","containsSignatures","sigs","OS","expected","some","includes","isRooted"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":";;AAAA,SAASA,QAAQ,QAAQ,cAAc;AACvC,SAASC,YAAY,QAAQ,4BAA4B;AAGzD,IAAIC,YAAqC,GAAG,IAAI;AAEhD,SAASC,eAAeA,CAAA,EAAqB;EAC3C,IAAID,YAAY,IAAI,IAAI,EAAE;IACxBA,YAAY,GACVD,YAAY,CAACG,kBAAkB,CAAmB,cAAc,CAAC;EACrE;EACA,OAAOF,YAAY;AACrB;AAEA,eAAeG,aAAaA,CAAA,EAAsB;EAChD,MAAMC,UAAU,GAAG,MAAMH,eAAe,CAAC,CAAC,CAACE,aAAa,CAAC,CAAC;EAC1D,OAAOC,UAAU,CAACC,GAAG,CAAEC,IAAI,IAAKA,IAAI,CAACC,WAAW,CAAC,CAAC,CAAC;AACrD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,eAAeC,kBAAkBA,CAACC,IAAc,EAAoB;EACzE,IAAIX,QAAQ,CAACY,EAAE,KAAK,KAAK,EAAE;IACzB,OAAO,IAAI;EACb;EAEA,MAAMN,UAAU,GAAG,MAAMD,aAAa,CAAC,CAAC;EACxC,MAAMQ,QAAQ,GAAGF,IAAI,CAACJ,GAAG,CAAEC,IAAI,IAAKA,IAAI,CAACC,WAAW,CAAC,CAAC,CAAC;EACvD,OAAOH,UAAU,CAACQ,IAAI,CAAEN,IAAI,IAAKK,QAAQ,CAACE,QAAQ,CAACP,IAAI,CAAC,CAAC;AAC3D;;AAEA;AACA,OAAO,eAAeQ,QAAQA,CAAA,EAAqB;EACjD,OAAO,MAAMb,eAAe,CAAC,CAAC,CAACa,QAAQ,CAAC,CAAC;AAC3C","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/SecurityPack.nitro.ts"],"mappings":"","ignoreList":[]}
|
|
@@ -1,3 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Checks whether the app's signing certificate matches any of the given SHA-1
|
|
3
|
+
* fingerprints (hex, case-insensitive).
|
|
4
|
+
*
|
|
5
|
+
* On iOS this always returns `true` because APK signatures are Android-only.
|
|
6
|
+
*/
|
|
1
7
|
export declare function containsSignatures(sigs: string[]): Promise<boolean>;
|
|
8
|
+
/** Returns `true` when the device appears to be rooted (Android) or jailbroken (iOS). */
|
|
2
9
|
export declare function isRooted(): Promise<boolean>;
|
|
3
10
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/index.
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/index.ts"],"names":[],"mappings":"AAmBA;;;;;GAKG;AACH,wBAAsB,kBAAkB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC,CAQzE;AAED,yFAAyF;AACzF,wBAAsB,QAAQ,IAAI,OAAO,CAAC,OAAO,CAAC,CAEjD"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { HybridObject } from 'react-native-nitro-modules';
|
|
2
|
+
export interface SecurityPack extends HybridObject<{
|
|
3
|
+
ios: 'swift';
|
|
4
|
+
android: 'kotlin';
|
|
5
|
+
}> {
|
|
6
|
+
getSignatures(): Promise<string[]>;
|
|
7
|
+
isRooted(): Promise<boolean>;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=SecurityPack.nitro.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SecurityPack.nitro.d.ts","sourceRoot":"","sources":["../../../../../src/specs/SecurityPack.nitro.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAE/D,MAAM,WAAW,YACf,SAAQ,YAAY,CAAC;IAAE,GAAG,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,QAAQ,CAAA;CAAE,CAAC;IACzD,aAAa,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IACnC,QAAQ,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;CAC9B"}
|
|
@@ -1,3 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Checks whether the app's signing certificate matches any of the given SHA-1
|
|
3
|
+
* fingerprints (hex, case-insensitive).
|
|
4
|
+
*
|
|
5
|
+
* On iOS this always returns `true` because APK signatures are Android-only.
|
|
6
|
+
*/
|
|
1
7
|
export declare function containsSignatures(sigs: string[]): Promise<boolean>;
|
|
8
|
+
/** Returns `true` when the device appears to be rooted (Android) or jailbroken (iOS). */
|
|
2
9
|
export declare function isRooted(): Promise<boolean>;
|
|
3
10
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/index.
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/index.ts"],"names":[],"mappings":"AAmBA;;;;;GAKG;AACH,wBAAsB,kBAAkB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC,CAQzE;AAED,yFAAyF;AACzF,wBAAsB,QAAQ,IAAI,OAAO,CAAC,OAAO,CAAC,CAEjD"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { HybridObject } from 'react-native-nitro-modules';
|
|
2
|
+
export interface SecurityPack extends HybridObject<{
|
|
3
|
+
ios: 'swift';
|
|
4
|
+
android: 'kotlin';
|
|
5
|
+
}> {
|
|
6
|
+
getSignatures(): Promise<string[]>;
|
|
7
|
+
isRooted(): Promise<boolean>;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=SecurityPack.nitro.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SecurityPack.nitro.d.ts","sourceRoot":"","sources":["../../../../../src/specs/SecurityPack.nitro.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAE/D,MAAM,WAAW,YACf,SAAQ,YAAY,CAAC;IAAE,GAAG,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,QAAQ,CAAA;CAAE,CAAC;IACzD,aAAa,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IACnC,QAAQ,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;CAC9B"}
|
package/nitro.json
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "https://nitro.margelo.com/nitro.schema.json",
|
|
3
|
+
"cxxNamespace": ["rnsecuritypack"],
|
|
4
|
+
"ios": {
|
|
5
|
+
"iosModuleName": "RNSecurityPack"
|
|
6
|
+
},
|
|
7
|
+
"android": {
|
|
8
|
+
"androidNamespace": ["rnsecuritypack"],
|
|
9
|
+
"androidCxxLibName": "RNSecurityPack"
|
|
10
|
+
},
|
|
11
|
+
"autolinking": {
|
|
12
|
+
"SecurityPack": {
|
|
13
|
+
"android": {
|
|
14
|
+
"language": "kotlin",
|
|
15
|
+
"implementationClassName": "HybridSecurityPack"
|
|
16
|
+
},
|
|
17
|
+
"ios": {
|
|
18
|
+
"language": "swift",
|
|
19
|
+
"implementationClassName": "HybridSecurityPack"
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
"ignorePaths": ["**/node_modules"]
|
|
24
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
** linguist-generated=true
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
#
|
|
2
|
+
# RNSecurityPack+autolinking.cmake
|
|
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
|
+
# This is a CMake file that adds all files generated by Nitrogen
|
|
9
|
+
# to the current CMake project.
|
|
10
|
+
#
|
|
11
|
+
# To use it, add this to your CMakeLists.txt:
|
|
12
|
+
# ```cmake
|
|
13
|
+
# include(${CMAKE_SOURCE_DIR}/../nitrogen/generated/android/RNSecurityPack+autolinking.cmake)
|
|
14
|
+
# ```
|
|
15
|
+
|
|
16
|
+
# Define a flag to check if we are building properly
|
|
17
|
+
add_definitions(-DBUILDING_RNSECURITYPACK_WITH_GENERATED_CMAKE_PROJECT)
|
|
18
|
+
|
|
19
|
+
# Enable Raw Props parsing in react-native (for Nitro Views)
|
|
20
|
+
add_definitions(-DRN_SERIALIZABLE_STATE)
|
|
21
|
+
|
|
22
|
+
# Add all headers that were generated by Nitrogen
|
|
23
|
+
include_directories(
|
|
24
|
+
"../nitrogen/generated/shared/c++"
|
|
25
|
+
"../nitrogen/generated/android/c++"
|
|
26
|
+
"../nitrogen/generated/android/"
|
|
27
|
+
)
|
|
28
|
+
|
|
29
|
+
# Add all .cpp sources that were generated by Nitrogen
|
|
30
|
+
target_sources(
|
|
31
|
+
# CMake project name (Android C++ library name)
|
|
32
|
+
RNSecurityPack PRIVATE
|
|
33
|
+
# Autolinking Setup
|
|
34
|
+
../nitrogen/generated/android/RNSecurityPackOnLoad.cpp
|
|
35
|
+
# Shared Nitrogen C++ sources
|
|
36
|
+
../nitrogen/generated/shared/c++/HybridSecurityPackSpec.cpp
|
|
37
|
+
# Android-specific Nitrogen C++ sources
|
|
38
|
+
../nitrogen/generated/android/c++/JHybridSecurityPackSpec.cpp
|
|
39
|
+
)
|
|
40
|
+
|
|
41
|
+
# From node_modules/react-native/ReactAndroid/cmake-utils/folly-flags.cmake
|
|
42
|
+
# Used in node_modules/react-native/ReactAndroid/cmake-utils/ReactNative-application.cmake
|
|
43
|
+
target_compile_definitions(
|
|
44
|
+
RNSecurityPack PRIVATE
|
|
45
|
+
-DFOLLY_NO_CONFIG=1
|
|
46
|
+
-DFOLLY_HAVE_CLOCK_GETTIME=1
|
|
47
|
+
-DFOLLY_USE_LIBCPP=1
|
|
48
|
+
-DFOLLY_CFG_NO_COROUTINES=1
|
|
49
|
+
-DFOLLY_MOBILE=1
|
|
50
|
+
-DFOLLY_HAVE_RECVMMSG=1
|
|
51
|
+
-DFOLLY_HAVE_PTHREAD=1
|
|
52
|
+
# Once we target android-23 above, we can comment
|
|
53
|
+
# the following line. NDK uses GNU style stderror_r() after API 23.
|
|
54
|
+
-DFOLLY_HAVE_XSI_STRERROR_R=1
|
|
55
|
+
)
|
|
56
|
+
|
|
57
|
+
# Add all libraries required by the generated specs
|
|
58
|
+
find_package(fbjni REQUIRED) # <-- Used for communication between Java <-> C++
|
|
59
|
+
find_package(ReactAndroid REQUIRED) # <-- Used to set up React Native bindings (e.g. CallInvoker/TurboModule)
|
|
60
|
+
find_package(react-native-nitro-modules REQUIRED) # <-- Used to create all HybridObjects and use the Nitro core library
|
|
61
|
+
|
|
62
|
+
# Link all libraries together
|
|
63
|
+
target_link_libraries(
|
|
64
|
+
RNSecurityPack
|
|
65
|
+
fbjni::fbjni # <-- Facebook C++ JNI helpers
|
|
66
|
+
ReactAndroid::jsi # <-- RN: JSI
|
|
67
|
+
react-native-nitro-modules::NitroModules # <-- NitroModules Core :)
|
|
68
|
+
)
|
|
69
|
+
|
|
70
|
+
# Link react-native (different prefab between RN 0.75 and RN 0.76)
|
|
71
|
+
if(ReactAndroid_VERSION_MINOR GREATER_EQUAL 76)
|
|
72
|
+
target_link_libraries(
|
|
73
|
+
RNSecurityPack
|
|
74
|
+
ReactAndroid::reactnative # <-- RN: Native Modules umbrella prefab
|
|
75
|
+
)
|
|
76
|
+
else()
|
|
77
|
+
target_link_libraries(
|
|
78
|
+
RNSecurityPack
|
|
79
|
+
ReactAndroid::react_nativemodule_core # <-- RN: TurboModules Core
|
|
80
|
+
)
|
|
81
|
+
endif()
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// RNSecurityPack+autolinking.gradle
|
|
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
|
+
/// This is a Gradle file that adds all files generated by Nitrogen
|
|
9
|
+
/// to the current Gradle project.
|
|
10
|
+
///
|
|
11
|
+
/// To use it, add this to your build.gradle:
|
|
12
|
+
/// ```gradle
|
|
13
|
+
/// apply from: '../nitrogen/generated/android/RNSecurityPack+autolinking.gradle'
|
|
14
|
+
/// ```
|
|
15
|
+
|
|
16
|
+
logger.warn("[NitroModules] 🔥 RNSecurityPack is boosted by nitro!")
|
|
17
|
+
|
|
18
|
+
android {
|
|
19
|
+
sourceSets {
|
|
20
|
+
main {
|
|
21
|
+
java.srcDirs += [
|
|
22
|
+
// Nitrogen files
|
|
23
|
+
"${project.projectDir}/../nitrogen/generated/android/kotlin"
|
|
24
|
+
]
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// RNSecurityPackOnLoad.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
|
+
#ifndef BUILDING_RNSECURITYPACK_WITH_GENERATED_CMAKE_PROJECT
|
|
9
|
+
#error RNSecurityPackOnLoad.cpp is not being built with the autogenerated CMakeLists.txt project. Is a different CMakeLists.txt building this?
|
|
10
|
+
#endif
|
|
11
|
+
|
|
12
|
+
#include "RNSecurityPackOnLoad.hpp"
|
|
13
|
+
|
|
14
|
+
#include <jni.h>
|
|
15
|
+
#include <fbjni/fbjni.h>
|
|
16
|
+
#include <NitroModules/HybridObjectRegistry.hpp>
|
|
17
|
+
|
|
18
|
+
#include "JHybridSecurityPackSpec.hpp"
|
|
19
|
+
#include <NitroModules/DefaultConstructableObject.hpp>
|
|
20
|
+
|
|
21
|
+
namespace margelo::nitro::rnsecuritypack {
|
|
22
|
+
|
|
23
|
+
int initialize(JavaVM* vm) {
|
|
24
|
+
return facebook::jni::initialize(vm, []() {
|
|
25
|
+
::margelo::nitro::rnsecuritypack::registerAllNatives();
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
struct JHybridSecurityPackSpecImpl: public jni::JavaClass<JHybridSecurityPackSpecImpl, JHybridSecurityPackSpec::JavaPart> {
|
|
30
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/rnsecuritypack/HybridSecurityPack;";
|
|
31
|
+
static std::shared_ptr<JHybridSecurityPackSpec> create() {
|
|
32
|
+
static const auto constructorFn = javaClassStatic()->getConstructor<JHybridSecurityPackSpecImpl::javaobject()>();
|
|
33
|
+
jni::local_ref<JHybridSecurityPackSpec::JavaPart> javaPart = javaClassStatic()->newObject(constructorFn);
|
|
34
|
+
return javaPart->getJHybridSecurityPackSpec();
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
void registerAllNatives() {
|
|
39
|
+
using namespace margelo::nitro;
|
|
40
|
+
using namespace margelo::nitro::rnsecuritypack;
|
|
41
|
+
|
|
42
|
+
// Register native JNI methods
|
|
43
|
+
margelo::nitro::rnsecuritypack::JHybridSecurityPackSpec::CxxPart::registerNatives();
|
|
44
|
+
|
|
45
|
+
// Register Nitro Hybrid Objects
|
|
46
|
+
HybridObjectRegistry::registerHybridObjectConstructor(
|
|
47
|
+
"SecurityPack",
|
|
48
|
+
[]() -> std::shared_ptr<HybridObject> {
|
|
49
|
+
return JHybridSecurityPackSpecImpl::create();
|
|
50
|
+
}
|
|
51
|
+
);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
} // namespace margelo::nitro::rnsecuritypack
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// RNSecurityPackOnLoad.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
|
+
#include <jni.h>
|
|
9
|
+
#include <functional>
|
|
10
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
11
|
+
|
|
12
|
+
namespace margelo::nitro::rnsecuritypack {
|
|
13
|
+
|
|
14
|
+
[[deprecated("Use registerNatives() instead.")]]
|
|
15
|
+
int initialize(JavaVM* vm);
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Register the native (C++) part of RNSecurityPack, 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.
|
|
21
|
+
* Example:
|
|
22
|
+
* ```cpp (cpp-adapter.cpp)
|
|
23
|
+
* JNIEXPORT jint JNICALL JNI_OnLoad(JavaVM* vm, void*) {
|
|
24
|
+
* return facebook::jni::initialize(vm, []() {
|
|
25
|
+
* // register all RNSecurityPack HybridObjects
|
|
26
|
+
* margelo::nitro::rnsecuritypack::registerNatives();
|
|
27
|
+
* // any other custom registrations go here.
|
|
28
|
+
* });
|
|
29
|
+
* }
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
void registerAllNatives();
|
|
33
|
+
|
|
34
|
+
} // namespace margelo::nitro::rnsecuritypack
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// JHybridSecurityPackSpec.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 "JHybridSecurityPackSpec.hpp"
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
#include <string>
|
|
13
|
+
#include <vector>
|
|
14
|
+
#include <NitroModules/Promise.hpp>
|
|
15
|
+
#include <NitroModules/JPromise.hpp>
|
|
16
|
+
|
|
17
|
+
namespace margelo::nitro::rnsecuritypack {
|
|
18
|
+
|
|
19
|
+
std::shared_ptr<JHybridSecurityPackSpec> JHybridSecurityPackSpec::JavaPart::getJHybridSecurityPackSpec() {
|
|
20
|
+
auto hybridObject = JHybridObject::JavaPart::getJHybridObject();
|
|
21
|
+
auto castHybridObject = std::dynamic_pointer_cast<JHybridSecurityPackSpec>(hybridObject);
|
|
22
|
+
if (castHybridObject == nullptr) [[unlikely]] {
|
|
23
|
+
throw std::runtime_error("Failed to downcast JHybridObject to JHybridSecurityPackSpec!");
|
|
24
|
+
}
|
|
25
|
+
return castHybridObject;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
jni::local_ref<JHybridSecurityPackSpec::CxxPart::jhybriddata> JHybridSecurityPackSpec::CxxPart::initHybrid(jni::alias_ref<jhybridobject> jThis) {
|
|
29
|
+
return makeCxxInstance(jThis);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
std::shared_ptr<JHybridObject> JHybridSecurityPackSpec::CxxPart::createHybridObject(const jni::local_ref<JHybridObject::JavaPart>& javaPart) {
|
|
33
|
+
auto castJavaPart = jni::dynamic_ref_cast<JHybridSecurityPackSpec::JavaPart>(javaPart);
|
|
34
|
+
if (castJavaPart == nullptr) [[unlikely]] {
|
|
35
|
+
throw std::runtime_error("Failed to cast JHybridObject::JavaPart to JHybridSecurityPackSpec::JavaPart!");
|
|
36
|
+
}
|
|
37
|
+
return std::make_shared<JHybridSecurityPackSpec>(castJavaPart);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
void JHybridSecurityPackSpec::CxxPart::registerNatives() {
|
|
41
|
+
registerHybrid({
|
|
42
|
+
makeNativeMethod("initHybrid", JHybridSecurityPackSpec::CxxPart::initHybrid),
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
// Properties
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
// Methods
|
|
50
|
+
std::shared_ptr<Promise<std::vector<std::string>>> JHybridSecurityPackSpec::getSignatures() {
|
|
51
|
+
static const auto method = _javaPart->javaClassStatic()->getMethod<jni::local_ref<JPromise::javaobject>()>("getSignatures");
|
|
52
|
+
auto __result = method(_javaPart);
|
|
53
|
+
return [&]() {
|
|
54
|
+
auto __promise = Promise<std::vector<std::string>>::create();
|
|
55
|
+
__result->cthis()->addOnResolvedListener([=](const jni::alias_ref<jni::JObject>& __boxedResult) {
|
|
56
|
+
auto __result = jni::static_ref_cast<jni::JArrayClass<jni::JString>>(__boxedResult);
|
|
57
|
+
__promise->resolve([&](auto&& __input) {
|
|
58
|
+
size_t __size = __input->size();
|
|
59
|
+
std::vector<std::string> __vector;
|
|
60
|
+
__vector.reserve(__size);
|
|
61
|
+
for (size_t __i = 0; __i < __size; __i++) {
|
|
62
|
+
auto __element = __input->getElement(__i);
|
|
63
|
+
__vector.push_back(__element->toStdString());
|
|
64
|
+
}
|
|
65
|
+
return __vector;
|
|
66
|
+
}(__result));
|
|
67
|
+
});
|
|
68
|
+
__result->cthis()->addOnRejectedListener([=](const jni::alias_ref<jni::JThrowable>& __throwable) {
|
|
69
|
+
jni::JniException __jniError(__throwable);
|
|
70
|
+
__promise->reject(std::make_exception_ptr(__jniError));
|
|
71
|
+
});
|
|
72
|
+
return __promise;
|
|
73
|
+
}();
|
|
74
|
+
}
|
|
75
|
+
std::shared_ptr<Promise<bool>> JHybridSecurityPackSpec::isRooted() {
|
|
76
|
+
static const auto method = _javaPart->javaClassStatic()->getMethod<jni::local_ref<JPromise::javaobject>()>("isRooted");
|
|
77
|
+
auto __result = method(_javaPart);
|
|
78
|
+
return [&]() {
|
|
79
|
+
auto __promise = Promise<bool>::create();
|
|
80
|
+
__result->cthis()->addOnResolvedListener([=](const jni::alias_ref<jni::JObject>& __boxedResult) {
|
|
81
|
+
auto __result = jni::static_ref_cast<jni::JBoolean>(__boxedResult);
|
|
82
|
+
__promise->resolve(static_cast<bool>(__result->value()));
|
|
83
|
+
});
|
|
84
|
+
__result->cthis()->addOnRejectedListener([=](const jni::alias_ref<jni::JThrowable>& __throwable) {
|
|
85
|
+
jni::JniException __jniError(__throwable);
|
|
86
|
+
__promise->reject(std::make_exception_ptr(__jniError));
|
|
87
|
+
});
|
|
88
|
+
return __promise;
|
|
89
|
+
}();
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
} // namespace margelo::nitro::rnsecuritypack
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridSecurityPackSpec.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
|
+
#include <NitroModules/JHybridObject.hpp>
|
|
11
|
+
#include <fbjni/fbjni.h>
|
|
12
|
+
#include "HybridSecurityPackSpec.hpp"
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
namespace margelo::nitro::rnsecuritypack {
|
|
18
|
+
|
|
19
|
+
using namespace facebook;
|
|
20
|
+
|
|
21
|
+
class JHybridSecurityPackSpec: public virtual HybridSecurityPackSpec, public virtual JHybridObject {
|
|
22
|
+
public:
|
|
23
|
+
struct JavaPart: public jni::JavaClass<JavaPart, JHybridObject::JavaPart> {
|
|
24
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/rnsecuritypack/HybridSecurityPackSpec;";
|
|
25
|
+
std::shared_ptr<JHybridSecurityPackSpec> getJHybridSecurityPackSpec();
|
|
26
|
+
};
|
|
27
|
+
struct CxxPart: public jni::HybridClass<CxxPart, JHybridObject::CxxPart> {
|
|
28
|
+
static constexpr auto kJavaDescriptor = "Lcom/margelo/nitro/rnsecuritypack/HybridSecurityPackSpec$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
|
+
};
|
|
35
|
+
|
|
36
|
+
public:
|
|
37
|
+
explicit JHybridSecurityPackSpec(const jni::local_ref<JHybridSecurityPackSpec::JavaPart>& javaPart):
|
|
38
|
+
HybridObject(HybridSecurityPackSpec::TAG),
|
|
39
|
+
JHybridObject(javaPart),
|
|
40
|
+
_javaPart(jni::make_global(javaPart)) {}
|
|
41
|
+
~JHybridSecurityPackSpec() override {
|
|
42
|
+
// Hermes GC can destroy JS objects on a non-JNI Thread.
|
|
43
|
+
jni::ThreadScope::WithClassLoader([&] { _javaPart.reset(); });
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
public:
|
|
47
|
+
inline const jni::global_ref<JHybridSecurityPackSpec::JavaPart>& getJavaPart() const noexcept {
|
|
48
|
+
return _javaPart;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
public:
|
|
52
|
+
// Properties
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
public:
|
|
56
|
+
// Methods
|
|
57
|
+
std::shared_ptr<Promise<std::vector<std::string>>> getSignatures() override;
|
|
58
|
+
std::shared_ptr<Promise<bool>> isRooted() override;
|
|
59
|
+
|
|
60
|
+
private:
|
|
61
|
+
jni::global_ref<JHybridSecurityPackSpec::JavaPart> _javaPart;
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
} // namespace margelo::nitro::rnsecuritypack
|
package/nitrogen/generated/android/kotlin/com/margelo/nitro/rnsecuritypack/HybridSecurityPackSpec.kt
ADDED
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridSecurityPackSpec.kt
|
|
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
|
+
package com.margelo.nitro.rnsecuritypack
|
|
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.Promise
|
|
14
|
+
import com.margelo.nitro.core.HybridObject
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* A Kotlin class representing the SecurityPack HybridObject.
|
|
18
|
+
* Implement this abstract class to create Kotlin-based instances of SecurityPack.
|
|
19
|
+
*/
|
|
20
|
+
@DoNotStrip
|
|
21
|
+
@Keep
|
|
22
|
+
@Suppress(
|
|
23
|
+
"KotlinJniMissingFunction", "unused",
|
|
24
|
+
"RedundantSuppression", "RedundantUnitReturnType", "SimpleRedundantLet",
|
|
25
|
+
"LocalVariableName", "PropertyName", "PrivatePropertyName", "FunctionName"
|
|
26
|
+
)
|
|
27
|
+
abstract class HybridSecurityPackSpec: HybridObject() {
|
|
28
|
+
// Properties
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
// Methods
|
|
32
|
+
@DoNotStrip
|
|
33
|
+
@Keep
|
|
34
|
+
abstract fun getSignatures(): Promise<Array<String>>
|
|
35
|
+
|
|
36
|
+
@DoNotStrip
|
|
37
|
+
@Keep
|
|
38
|
+
abstract fun isRooted(): Promise<Boolean>
|
|
39
|
+
|
|
40
|
+
// Default implementation of `HybridObject.toString()`
|
|
41
|
+
override fun toString(): String {
|
|
42
|
+
return "[HybridObject SecurityPack]"
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
// C++ backing class
|
|
46
|
+
@DoNotStrip
|
|
47
|
+
@Keep
|
|
48
|
+
protected open class CxxPart(javaPart: HybridSecurityPackSpec): HybridObject.CxxPart(javaPart) {
|
|
49
|
+
// C++ JHybridSecurityPackSpec::CxxPart::initHybrid(...)
|
|
50
|
+
external override fun initHybrid(): HybridData
|
|
51
|
+
}
|
|
52
|
+
override fun createCxxPart(): CxxPart {
|
|
53
|
+
return CxxPart(this)
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
companion object {
|
|
57
|
+
protected const val TAG = "HybridSecurityPackSpec"
|
|
58
|
+
}
|
|
59
|
+
}
|
package/nitrogen/generated/android/kotlin/com/margelo/nitro/rnsecuritypack/RNSecurityPackOnLoad.kt
ADDED
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// RNSecurityPackOnLoad.kt
|
|
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
|
+
package com.margelo.nitro.rnsecuritypack
|
|
9
|
+
|
|
10
|
+
import android.util.Log
|
|
11
|
+
|
|
12
|
+
internal class RNSecurityPackOnLoad {
|
|
13
|
+
companion object {
|
|
14
|
+
private const val TAG = "RNSecurityPackOnLoad"
|
|
15
|
+
private var didLoad = false
|
|
16
|
+
/**
|
|
17
|
+
* Initializes the native part of "RNSecurityPack".
|
|
18
|
+
* This method is idempotent and can be called more than once.
|
|
19
|
+
*/
|
|
20
|
+
@JvmStatic
|
|
21
|
+
fun initializeNative() {
|
|
22
|
+
if (didLoad) return
|
|
23
|
+
try {
|
|
24
|
+
Log.i(TAG, "Loading RNSecurityPack C++ library...")
|
|
25
|
+
System.loadLibrary("RNSecurityPack")
|
|
26
|
+
Log.i(TAG, "Successfully loaded RNSecurityPack C++ library!")
|
|
27
|
+
didLoad = true
|
|
28
|
+
} catch (e: Error) {
|
|
29
|
+
Log.e(TAG, "Failed to load RNSecurityPack C++ library! Is it properly installed and linked? " +
|
|
30
|
+
"Is the name correct? (see `CMakeLists.txt`, at `add_library(...)`)", e)
|
|
31
|
+
throw e
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|