react-native-webrtc-nitro 1.1.0 → 1.2.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/android/src/main/java/com/webrtc/HybridCamera.kt +0 -1
- package/android/src/main/java/com/webrtc/HybridMicrophone.kt +0 -1
- package/android/src/main/java/com/webrtc/HybridPermissions.kt +95 -0
- package/cpp/Hybrid/HybridMediaDevices.cpp +23 -19
- package/ios/HybridCamera.swift +1 -3
- package/ios/HybridMicrophone.swift +1 -3
- package/ios/HybridPermissions.swift +63 -0
- package/lib/commonjs/index.js +11 -0
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/specs/Permissions.nitro.js +9 -0
- package/lib/commonjs/specs/Permissions.nitro.js.map +1 -0
- package/lib/module/index.js +1 -0
- package/lib/module/index.js.map +1 -1
- package/lib/module/specs/Permissions.nitro.js +6 -0
- package/lib/module/specs/Permissions.nitro.js.map +1 -0
- package/lib/typescript/src/index.d.ts +1 -0
- package/lib/typescript/src/index.d.ts.map +1 -1
- package/lib/typescript/src/specs/Permissions.nitro.d.ts +17 -0
- package/lib/typescript/src/specs/Permissions.nitro.d.ts.map +1 -0
- package/nitro.json +4 -0
- package/nitrogen/generated/android/Webrtc+autolinking.cmake +2 -0
- package/nitrogen/generated/android/WebrtcOnLoad.cpp +10 -0
- package/nitrogen/generated/android/c++/JHybridPermissionsSpec.cpp +91 -0
- package/nitrogen/generated/android/c++/JHybridPermissionsSpec.hpp +66 -0
- package/nitrogen/generated/android/c++/JPermissionDescriptor.hpp +58 -0
- package/nitrogen/generated/android/c++/JPermissionName.hpp +59 -0
- package/nitrogen/generated/android/c++/JPermissionState.hpp +62 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/webrtc/HybridPermissionsSpec.kt +62 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/webrtc/PermissionDescriptor.kt +38 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/webrtc/PermissionName.kt +21 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/webrtc/PermissionState.kt +22 -0
- package/nitrogen/generated/ios/Webrtc-Swift-Cxx-Bridge.cpp +25 -0
- package/nitrogen/generated/ios/Webrtc-Swift-Cxx-Bridge.hpp +63 -0
- package/nitrogen/generated/ios/Webrtc-Swift-Cxx-Umbrella.hpp +14 -0
- package/nitrogen/generated/ios/WebrtcAutolinking.mm +8 -0
- package/nitrogen/generated/ios/WebrtcAutolinking.swift +15 -0
- package/nitrogen/generated/ios/c++/HybridPermissionsSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridPermissionsSpecSwift.hpp +92 -0
- package/nitrogen/generated/ios/swift/Func_void_PermissionState.swift +47 -0
- package/nitrogen/generated/ios/swift/HybridPermissionsSpec.swift +57 -0
- package/nitrogen/generated/ios/swift/HybridPermissionsSpec_cxx.swift +157 -0
- package/nitrogen/generated/ios/swift/PermissionDescriptor.swift +36 -0
- package/nitrogen/generated/ios/swift/PermissionName.swift +40 -0
- package/nitrogen/generated/ios/swift/PermissionState.swift +44 -0
- package/nitrogen/generated/shared/c++/HybridPermissionsSpec.cpp +22 -0
- package/nitrogen/generated/shared/c++/HybridPermissionsSpec.hpp +68 -0
- package/nitrogen/generated/shared/c++/PermissionDescriptor.hpp +76 -0
- package/nitrogen/generated/shared/c++/PermissionName.hpp +76 -0
- package/nitrogen/generated/shared/c++/PermissionState.hpp +80 -0
- package/package.json +4 -5
- package/src/index.ts +1 -0
- package/src/specs/Permissions.nitro.ts +22 -0
- package/android/src/main/java/com/webrtc/Permission.kt +0 -58
- package/ios/Permission.swift +0 -26
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "react-native-webrtc-nitro",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.2.0",
|
|
4
4
|
"description": "Nitro WebRTC module for React Native",
|
|
5
5
|
"main": "./lib/commonjs/index.js",
|
|
6
6
|
"module": "./lib/module/index.js",
|
|
@@ -14,8 +14,7 @@
|
|
|
14
14
|
"build": "pnpm run typecheck && bob build",
|
|
15
15
|
"codegen": "nitrogen --logLevel=\"debug\" && pnpm run build && node post-script.js",
|
|
16
16
|
"lint": "pnpm run lint:cpp",
|
|
17
|
-
"lint:cpp": "find cpp -path cpp/__tests__/build -prune -o \\( -name \"*.cpp\" -o -name \"*.h\" -o -name \"*.hpp\" \\) -type f -print0 | xargs -0 clang-format -n --Werror -style=file"
|
|
18
|
-
"outtt": "which clang-format"
|
|
17
|
+
"lint:cpp": "find cpp -path cpp/__tests__/build -prune -o \\( -name \"*.cpp\" -o -name \"*.h\" -o -name \"*.hpp\" \\) -type f -print0 | xargs -0 clang-format -n --Werror -style=file"
|
|
19
18
|
},
|
|
20
19
|
"keywords": [
|
|
21
20
|
"react-native",
|
|
@@ -61,8 +60,8 @@
|
|
|
61
60
|
"clang-format-node": "^2.0.5",
|
|
62
61
|
"conventional-changelog-conventionalcommits": "^9.1.0",
|
|
63
62
|
"nitrogen": "0.31.10",
|
|
64
|
-
"react": "19.
|
|
65
|
-
"react-native": "0.
|
|
63
|
+
"react": "19.1.1",
|
|
64
|
+
"react-native": "0.82.1",
|
|
66
65
|
"react-native-builder-bob": "^0.40.16",
|
|
67
66
|
"react-native-nitro-modules": "0.31.10",
|
|
68
67
|
"semantic-release": "^25.0.2",
|
package/src/index.ts
CHANGED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { type HybridObject } from 'react-native-nitro-modules'
|
|
2
|
+
import { NitroModules } from 'react-native-nitro-modules'
|
|
3
|
+
|
|
4
|
+
export type PermissionState = 'denied' | 'granted' | 'prompt'
|
|
5
|
+
type PermissionName = 'camera' | 'microphone'
|
|
6
|
+
|
|
7
|
+
export interface PermissionDescriptor {
|
|
8
|
+
name: PermissionName
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
interface Permissions extends HybridObject<{
|
|
12
|
+
ios: 'swift'
|
|
13
|
+
android: 'kotlin'
|
|
14
|
+
}> {
|
|
15
|
+
query(permissionDesc: PermissionDescriptor): Promise<PermissionState>
|
|
16
|
+
request(permissionDesc: PermissionDescriptor): Promise<PermissionState>
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
const PermissionsExport =
|
|
20
|
+
NitroModules.createHybridObject<Permissions>('Permissions')
|
|
21
|
+
type PermissionsExport = Permissions
|
|
22
|
+
export { PermissionsExport as Permissions }
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
package com.webrtc
|
|
2
|
-
|
|
3
|
-
import android.content.pm.PackageManager
|
|
4
|
-
import androidx.core.content.ContextCompat
|
|
5
|
-
import com.facebook.react.modules.core.PermissionAwareActivity
|
|
6
|
-
import com.facebook.react.modules.core.PermissionListener
|
|
7
|
-
import kotlin.random.Random
|
|
8
|
-
import kotlinx.coroutines.CompletableDeferred
|
|
9
|
-
import com.margelo.nitro.NitroModules
|
|
10
|
-
|
|
11
|
-
suspend fun requestPermission(permission: String) {
|
|
12
|
-
val context = NitroModules.applicationContext
|
|
13
|
-
?: throw RuntimeException("ReactApplicationContext is not available")
|
|
14
|
-
|
|
15
|
-
val currentActivity = context.currentActivity
|
|
16
|
-
?: throw RuntimeException("No current Activity")
|
|
17
|
-
|
|
18
|
-
if (ContextCompat.checkSelfPermission(context, permission)
|
|
19
|
-
== PackageManager.PERMISSION_GRANTED
|
|
20
|
-
) {
|
|
21
|
-
return
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
if (currentActivity !is PermissionAwareActivity) {
|
|
25
|
-
throw RuntimeException("Current activity doesn't support permissions")
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
val code = Random.nextInt(0, 65535)
|
|
29
|
-
val deferred = CompletableDeferred<Unit>()
|
|
30
|
-
|
|
31
|
-
val listener = object : PermissionListener {
|
|
32
|
-
override fun onRequestPermissionsResult(
|
|
33
|
-
requestCode: Int,
|
|
34
|
-
permissions: Array<String>,
|
|
35
|
-
grantResults: IntArray
|
|
36
|
-
): Boolean {
|
|
37
|
-
if (requestCode != code) return false
|
|
38
|
-
|
|
39
|
-
if (permissions.isEmpty() || grantResults.isEmpty() ||
|
|
40
|
-
grantResults[0] != PackageManager.PERMISSION_GRANTED
|
|
41
|
-
) {
|
|
42
|
-
deferred.completeExceptionally(
|
|
43
|
-
RuntimeException("Permission denied by user")
|
|
44
|
-
)
|
|
45
|
-
} else {
|
|
46
|
-
deferred.complete(Unit)
|
|
47
|
-
}
|
|
48
|
-
return true
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
currentActivity.requestPermissions(
|
|
53
|
-
arrayOf(permission),
|
|
54
|
-
code,
|
|
55
|
-
listener
|
|
56
|
-
)
|
|
57
|
-
deferred.await()
|
|
58
|
-
}
|
package/ios/Permission.swift
DELETED
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import AVFoundation
|
|
2
|
-
import Foundation
|
|
3
|
-
import NitroModules
|
|
4
|
-
|
|
5
|
-
public func requestPermission(for mediaType: AVMediaType) async throws {
|
|
6
|
-
let status = AVCaptureDevice.authorizationStatus(for: mediaType)
|
|
7
|
-
switch status {
|
|
8
|
-
case .authorized:
|
|
9
|
-
return
|
|
10
|
-
case .notDetermined:
|
|
11
|
-
let granted = await withCheckedContinuation { (continuation) in
|
|
12
|
-
AVCaptureDevice.requestAccess(for: mediaType) { ok in
|
|
13
|
-
continuation.resume(returning: ok)
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
if granted {
|
|
17
|
-
return
|
|
18
|
-
} else {
|
|
19
|
-
throw RuntimeError.error(withMessage: "Permission not allowed")
|
|
20
|
-
}
|
|
21
|
-
case .denied, .restricted:
|
|
22
|
-
throw RuntimeError.error(withMessage: "Permission not allowed")
|
|
23
|
-
@unknown default:
|
|
24
|
-
throw RuntimeError.error(withMessage: "Permission not allowed")
|
|
25
|
-
}
|
|
26
|
-
}
|