Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stasel/WebRTC
Unofficial distribution of up to date WebRTC framework binaries for iOS and macOS
https://github.com/stasel/WebRTC
ios macos objcective-c swift webrtc
Last synced: 2 months ago
JSON representation
Unofficial distribution of up to date WebRTC framework binaries for iOS and macOS
- Host: GitHub
- URL: https://github.com/stasel/WebRTC
- Owner: stasel
- License: other
- Created: 2021-02-24T21:12:56.000Z (almost 4 years ago)
- Default Branch: latest
- Last Pushed: 2024-07-31T20:05:40.000Z (6 months ago)
- Last Synced: 2024-08-01T00:03:50.980Z (6 months ago)
- Topics: ios, macos, objcective-c, swift, webrtc
- Language: Shell
- Homepage:
- Size: 93.8 KB
- Stars: 364
- Watchers: 15
- Forks: 77
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome - WebRTC - Unofficial distribution of up to date WebRTC framework binaries for iOS and macOS. (OOM-Leaks-Crash / RTC)
README
# WebRTC Binaries for iOS and macOS
[![Latest version](https://img.shields.io/github/v/release/stasel/webrtc)](https://github.com/stasel/WebRTC/releases)
[![Release Date](https://img.shields.io/github/release-date/stasel/webrtc)](https://github.com/stasel/WebRTC/releases)
[![Total Downloads](https://img.shields.io/github/downloads/stasel/webrtc/total)](https://github.com/stasel/WebRTC/releases)
[![Cocoapods](https://img.shields.io/cocoapods/v/WebRTC-lib)](https://cocoapods.org/pods/WebRTC-lib)This repository contains unofficial distribution of WebRTC framework binaries for iOS and macOS.
Since version M80, Google has [deprecated](https://groups.google.com/g/discuss-webrtc/c/Ozvbd0p7Q1Y/m/M4WN2cRKCwAJ?pli=1) their mobile binary libraries distributions (Was officially using the [GoogleWebRTC pod](https://cocoapods.org/pods/GoogleWebRTC)). To get the most up to date WebRTC library, you can compile it on your own, or you can use precompiled binaries from here or other sources.
## 📦 Releases
The binary releases correspond with official Chromium releases and branches as specified in the [Chromium dashboard](https://chromiumdash.appspot.com/branches).## 💡 Things to know
* All binaries in this repository are compiled from the official WebRTC [source code](https://webrtc.googlesource.com/src/) without any modifications to the source code or to the output binaries.
* Dynamic framework (xcframework format) which contains multiple binaries for macOS and iOS.
* Since [Xcode 14](https://developer.apple.com/documentation/Xcode-Release-Notes/xcode-14-release-notes), bitcode is deprecated. Version M103 and above does not include bitcode.## 📢 Requirements
* iOS 12+
* macOS 10.11+
* macOS Catalyst 11.0+## 📀 Binaries included
| **Platform / arch** | arm64 | x86_x64 |
|---------------------|--------|---------|
| **iOS (device)** | ✅ | N/A |
| **iOS (simulator)** | ✅ | ✅ |
| **macOS** | ✅ | ✅ |
| **macOS Catalyst** | ✅ | ✅ |*Looking for 32 bit binaries? Please use [Version M94](https://github.com/stasel/WebRTC/releases/tag/94.0.0) or lower*
## 🚚 Installation
### Swift package manager
Xcode has a built-in support for Swift package manager. You can easily add the package by selecting File > Swift Packages > Add Package Dependency. Read more in [Apple documentation](https://developer.apple.com/documentation/xcode/adding_package_dependencies_to_your_app).Or, you can add the following dependency to your `Package.swift` file:
```swift
dependencies: [
.package(url: "https://github.com/stasel/WebRTC.git", .upToNextMajor("130.0.0"))
]
```Use the `latest` branch to get the most up to date binary:
```swift
dependencies: [
.package(url: "https://github.com/stasel/WebRTC.git", branch: "latest")
]
```### Cocoapods
Add the following line to your `Podfile`:
```
pod 'WebRTC-lib'
```And then run
```
pod install
````
Read more about Cocoapods: https://cocoapods.org### Carthage
**Requires Carthage version 0.38 or higher**Add the following dependency to the `Cartfile` in your project:
```
binary "https://raw.githubusercontent.com/stasel/WebRTC/latest/WebRTC.json"
```
Then update the dependencies using the following command:
```
carthage update --use-xcframeworks
```
And finally, add the xcframework located in `./Carthage/Build/WebRTC.xcframework` to your target(s) embedded frameworks.Read more about Carthage: https://github.com/Carthage/Carthage
### Manual
1. Download the framework from the [releases](https://github.com/stasel/WebRTC/releases) section.
2. Unzip the file.
3. Add the xcframework to your target(s) embedded frameworks.## 👷 Usage
To import WebRTC to your code add the following import statement
```swift
import WebRTC
```If you wish to see how to use WebRTC I highly recommend checking out my WebRTC demo iOS app: https://github.com/stasel/WebRTC-iOS
## 🛠Compile your own WebRTC Frameworks
If you wish to compile your own WebRTC binary framework, please refer to the following official guide:
https://webrtc.googlesource.com/src/+/refs/heads/main/docs/native-code/ios/README.mdYou can also take a look at the [build script](scripts/build.sh) I created for more details.
## 📃 License
* BSD 3-Clause License
* WebRTC License: https://webrtc.org/support/license