Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/livepeer/webrtmp-sdk
SDK for streaming media via RTMP from the web.
https://github.com/livepeer/webrtmp-sdk
Last synced: 2 months ago
JSON representation
SDK for streaming media via RTMP from the web.
- Host: GitHub
- URL: https://github.com/livepeer/webrtmp-sdk
- Owner: livepeer
- License: mit
- Created: 2021-09-15T18:16:55.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-08-07T18:07:15.000Z (over 1 year ago)
- Last Synced: 2024-08-02T17:31:40.885Z (6 months ago)
- Language: TypeScript
- Size: 263 KB
- Stars: 12
- Watchers: 8
- Forks: 9
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-livepeer - WebRTMP sample app
README
# [[ DEPRECATED ]] webrtmp-sdk [![npm version](https://badge.fury.io/js/@livepeer%2Fwebrtmp-sdk.svg)](https://badge.fury.io/js/@livepeer%2Fwebrtmp-sdk)
> THIS SDK IS DEPRECATED. REACT DEVELOPERS SHOULD USE THE [NEW BROADCAST SDK](https://docs.livepeer.org/reference/livepeer-js/Broadcast), AND ALL OTHER DEVELOPERS SHOULD FOLLOW THIS [GUIDE ON WEBRTC BROADCASTING](https://docs.livepeer.org/guides/developing/stream-via-browser.en-US#adding-broadcasting-with-plain-webrtc)
JavaScript SDK for streaming media via RTMP from the Web. Originally designed
for [Livepeer.com](livepeer.com), but can be used for any other service by
running your own [webrtmp-server](https://github.com/livepeer/webrtmp-server).> This SDK works best on Chrome Desktop, as it currently only supports WebSocket on H.264-capable browsers. We are working on WebRTC support to allow the use of non-Chrome and non-Desktop browsers. Check out the [Browser Support](#browser-support) section for more.
## Installation
### CDN
Add the following script tag to the header of your HTML file:
```html
```
The API will be available as a global named `webRTMP`:
```js
const { Client } = webRTMP
```### Package Managers
#### yarn
```sh
yarn add @livepeer/webrtmp-sdk
```#### npm
```sh
npm install @livepeer/webrtmp-sdk
```The API can then be imported as a regular module:
```js
const { Client } = require('webrtmp-sdk')
```## Usage
In order to stream through Livepeer, you are going to need a secret `streamKey`,
which can be obtained by following these steps:1) Create Livepeer Account at [livepeer.com](https://www.livepeer.com);
2) Go to the Livepeer [Streams Dashboard](https://www.livepeer.com/dashboard/streams);
3) Create a stream;
4) Grab the stream key and replace the `{{STREAM_KEY}}` in the example below.```js
const client = new Client()async function start() {
const streamKey = '{{STREAM_KEY}}'const stream = await navigator.mediaDevices.getUserMedia({
video: true,
audio: true
})const session = client.cast(stream, streamKey)
session.on('open', () => {
console.log('Stream started.')
})session.on('close', () => {
console.log('Stream stopped.')
})session.on('error', (err) => {
console.log('Stream error.', err.message)
})
}start()
```> **NOTE:** If you have multiple streaming users you will need a separate
> `streamKey` for each of them. So you should have a backend service
> programmatically create a stream through Livepeer API and return the
> `streamKey` for your front-end. Check out [Livepeer API
> Documentation](https://livepeer.com/docs/guides) on how to [get an API
> key](https://livepeer.com/docs/guides/start-live-streaming/api-key) and then
> how to [create a stream](https://livepeer.com/docs/guides/start-live-streaming/create-a-stream).## Browser Support
We provide a utility function to check whether the current browser is supported by the SDK:
```js
const { isSupported } = require('@livepeer/webrtmp-sdk')if (!isSupported()) {
alert('webrtmp-sdk is not currently supported on this browser')
}
```## Examples
The `examples` folder at the root of this repository contains two projects:
- [webrtmp-static](examples/webrtmp-static), implemented in vanilla HTML, CSS
and JavaScript. Check it out on
[CodePen](https://codepen.io/samuelmtimbo/pen/QWgaZGL).
- [webrtmp-react](examples/webrtmp-react), implemented with React (created
using [create-react-app](https://github.com/facebook/create-react-app)).For a full working example, check out [justcast.it](https://justcast.it) ([source
code](https://github.com/victorges/justcast.it)).## Contributing
Pull Requests are always welcome!
## License
MIT