Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/apiko-dev/amazon-ivs-react-native-broadcast
A React Native wrapper for the Amazon IVS iOS and Android broadcast SDKs
https://github.com/apiko-dev/amazon-ivs-react-native-broadcast
amazon broadcast ivs react-native sdk
Last synced: about 2 months ago
JSON representation
A React Native wrapper for the Amazon IVS iOS and Android broadcast SDKs
- Host: GitHub
- URL: https://github.com/apiko-dev/amazon-ivs-react-native-broadcast
- Owner: apiko-dev
- License: mit
- Created: 2022-03-02T09:21:10.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2023-09-11T07:51:04.000Z (over 1 year ago)
- Last Synced: 2024-10-31T19:57:22.822Z (2 months ago)
- Topics: amazon, broadcast, ivs, react-native, sdk
- Language: Java
- Homepage:
- Size: 641 KB
- Stars: 26
- Watchers: 11
- Forks: 14
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# **Amazon IVS React Native Broadcast**
A React Native wrapper for the Amazon IVS iOS and Android broadcast SDKs.
[![npm version](https://badge.fury.io/js/amazon-ivs-react-native-broadcast.svg)](https://www.npmjs.com/package/amazon-ivs-react-native-broadcast)
[![npm](https://img.shields.io/npm/dt/amazon-ivs-react-native-broadcast.svg)](https://www.npmjs.com/package/amazon-ivs-react-native-broadcast)
[![MIT](https://img.shields.io/dub/l/vibe-d.svg)](https://opensource.org/licenses/MIT)
[![Platform - Android](https://img.shields.io/badge/platform-Android-3ddc84.svg?style=flat&logo=android)](https://www.android.com)
[![Platform - iOS](https://img.shields.io/badge/platform-iOS-000.svg?style=flat&logo=apple)](https://developer.apple.com/ios)β οΈ _Note that the current module implementation doesn't support full functionality provided by Amazon IVS iOS and Android broadcast SDKs._
β οΈ _Apps using `amazon-ivs-react-native-broadcast` must target **iOS 11** and **Android 12 (API 31)**._
---
π [Read more](https://docs.aws.amazon.com/ivs/latest/userguide/broadcast.html) about broadcasting to Amazon IVS.
π [See](https://docs.aws.amazon.com/ivs/latest/userguide/streaming-config.html) Amazon IVS streaming configuration guideline.
## Installation
```sh
$ yarn add amazon-ivs-react-native-broadcast
# --- or ---
$ npm install amazon-ivs-react-native-broadcast
$ cd ios && pod install && cd ..
```# `IVSBroadcastCameraView` component
Allows consumers to stream video from an active phone camera.
## β οΈ Requirements
An application must request permission to access the userβs camera and microphone. This isn't specific to the component but required for any application that needs access to the cameras and microphones.
#### **iOS**
Add `NSCameraUsageDescription` and `NSMicrophoneUsageDescription` keys to the `Info.plist` file:
```xml
...
NSCameraUsageDescription
In order to stream your awesome video, allow access to camera please
NSMicrophoneUsageDescription
In order to stream your awesome audio, allow access to microphone please
...
```#### **Android**
Add `CAMERA` and `RECORD_AUDIO` permissions to the `AndroidManifest.xml` file:
```xml
......
```> β οΈ _On devices before SDK version 23, the permissions are automatically granted if they appear in the manifest, so check should always result to `true` and request should always resolve to `PermissionsAndroid.RESULTS.GRANTED`, however if your app is installed on a device that runs Android 6.0 or higher, **you must request** the \_dangerous permissions_ at runtime manually.\_
Example of requesting Android dangerous permissions at runtime could be found in the [`./example/src/index.android.tsx`](./example/src/index.android.tsx) file.
## API
| Props | Type | iOS | Android |
| :------------------------------------------------------------------------------: | :------------------------: | :-: | :-----: |
| [`rtmpsUrl`](./docs/api-documentation.md#rtmpsurl) | `string?` | β | β |
| [`streamKey`](./docs/api-documentation.md#streamkey) | `string?` | β | β |
| [`configurationPreset`](./docs/api-documentation.md#configurationpreset) | `ConfigurationPreset?` | β | β |
| [`videoConfig`](./docs/api-documentation.md#videoconfig) | `IVideoConfig?` | β | β |
| [`audioConfig`](./docs/api-documentation.md#audioconfig) | `IAudioConfig?` | β | β |
| [`logLevel`](./docs/api-documentation.md#loglevel) | `LogLevel?` | β | β |
| [`sessionLogLevel`](./docs/api-documentation.md#sessionloglevel) | `LogLevel?` | β | β |
| [`cameraPreviewAspectMode`](./docs/api-documentation.md#camerapreviewaspectmode) | `CameraPreviewAspectMode?` | β | β |
| [`isCameraPreviewMirrored`](./docs/api-documentation.md#iscamerapreviewmirrored) | `boolean?` | β | β |
| [`cameraPosition`](./docs/api-documentation.md#cameraposition) | `CameraPosition?` | β | β |
| [`isMuted`](./docs/api-documentation.md#ismuted) | `boolean?` | β | β || Handlers | Type | iOS | Android |
| :----------------------------------------------------------------------------------------------: | :-----------------------------------------------------------------------: | :-: | :-----: |
| [`onError`](./docs/api-documentation.md#onerror) | `(errorMessage: string): void?` | β | β |
| [`onBroadcastError`](./docs/api-documentation.md#onbroadcasterror) | `(error: IBroadcastSessionError): void?` | β | β |
| [`onIsBroadcastReady`](./docs/api-documentation.md#onisbroadcastready) | `(isReady: boolean): void?` | β | β |
| [`onBroadcastAudioStats`](./docs/api-documentation.md#onbroadcastaudiostats) | `(audioStats: IAudioStats): void?` | β | β |
| [`onBroadcastStateChanged`](./docs/api-documentation.md#onbroadcaststatechanged) | `(stateStatus: StateStatusUnion, metadata?: StateChangedMetadata): void?` | β | β |
| [`onTransmissionStatisticsChanged`](./docs/api-documentation.md#ontransmissionstatisticschanged) | `(transmissionStatistics: ITransmissionStatistics): void?` | β | β |
| [`onAudioSessionInterrupted`](./docs/api-documentation.md#onaudiosessioninterrupted) | `(): void?` | β | π« |
| [`onAudioSessionResumed`](./docs/api-documentation.md#onaudiosessionresumed) | `(): void?` | β | π« |
| [`onMediaServicesWereLost`](./docs/api-documentation.md#onmediaserviceswerelost) | `(): void?` | β | π« |
| [`onMediaServicesWereReset`](./docs/api-documentation.md#onmediaserviceswerereset) | `(): void?` | β | π« || Methods | Type | iOS | Android |
| :------------------------------------------: | :------------------------------------: | :-: | :-----: |
| [`start`](./docs/api-documentation.md#start) | `(options?: StartMethodOptions): void` | β | β |
| [`stop`](./docs/api-documentation.md#stop) | `(): void` | β | β |π Read more detailed [API documentation](docs/api-documentation.md).
π [iOS](https://docs.aws.amazon.com/ivs/latest/userguide/broadcast-ios.html#broadcast-ios-issues) and [Android](https://docs.aws.amazon.com/ivs/latest/userguide/broadcast-android.html#broadcast-android-issues) known issues and workarounds.
## Usage
A complex usage could be found in the [`./example/src/App.tsx`](./example/src/App.tsx) file or just go to the [`./example`](./example/) folder and read _Setting up and running application_ section how to set up and run the example app to see `IVSBroadcastCameraView` component in action.
---
## License
[MIT](LICENSE)
## Credits
This project has been built and is maintained thanks to the support from [Apiko](https://apiko.com/).