1
0
mirror of https://github.com/algora-io/tv.git synced 2024-11-16 00:58:59 +02:00
algora-tv/README.md

128 lines
2.9 KiB
Markdown
Raw Normal View History

2024-02-29 21:31:42 +02:00
<!-- PROJECT LOGO -->
<p align="center">
<a href="https://github.com/algora-io/tv">
<img src="https://user-images.githubusercontent.com/17045339/231901505-2936b331-3716-4418-9386-4a5d9cb694ba.svg" alt="Logo">
</a>
<h3 align="center">Algora TV</h3>
<p align="center">
The interactive livestreaming & video sharing service for developers.
<br />
<a href="https://tv.algora.io">Website</a>
·
<a href="https://algora.io/discord">Discord</a>
·
<a href="https://twitter.com/algoraio">Twitter</a>
·
<a href="https://www.youtube.com/@algora-io">YouTube</a>
·
<a href="https://github.com/algora-io/tv/issues">Issues</a>
</p>
</p>
## Architecture
2024-04-01 20:03:06 +02:00
### Overview
2024-02-29 21:31:42 +02:00
```mermaid
graph
2024-03-11 20:44:08 +02:00
Streamers{Streamers} --> Fly
2024-04-01 20:03:06 +02:00
Fly[Fly<br>Elixir App] --> RTMP
Fly --> Web[Phoenix<br>Web Server]
Fly --> Db[Fly<br>Postgres]
RTMP[Membrane<br>RTMP Server] -->|First mile delivery| Tigris[Tigris<br>Object Storage]
2024-02-29 21:31:42 +02:00
Viewers{Viewers} -->|Last mile delivery| Tigris
Viewers --> Fly
```
2024-04-01 20:03:06 +02:00
### Livestream pipeline
2024-03-11 20:44:08 +02:00
```mermaid
graph
2024-04-01 20:03:06 +02:00
Encoder{Encoder<br>e.g. OBS} -->|RTMP| Source[FLV Demuxer]
2024-03-11 20:44:08 +02:00
Source -->|video| H264Parser[H264 Parser]
Source -->|audio| AACParser[AAC Parser]
H264Parser --> H264Payloader[H264 Payloader]
AACParser --> AACPayloader[AAC Payloader]
H264Payloader --> CMAFMuxerVideo[CMAF Muxer]
AACPayloader --> CMAFMuxerAudio[CMAF Muxer]
2024-04-01 20:03:06 +02:00
CMAFMuxerVideo --> fMP4
CMAFMuxerAudio --> fMP4
fMP4[Fragmented MP4] -->|HLS| Tigris{Tigris Object Storage}
2024-03-11 20:44:08 +02:00
```
2024-02-29 21:31:42 +02:00
<!-- GETTING STARTED -->
## Getting Started
To get a local copy up and running, please follow these steps.
### Prerequisites
Here is what you need to be able to run Algora TV.
- Elixir (Version: >=1.12)
- OTP
- PostgreSQL
2024-04-01 20:03:06 +02:00
- FFmpeg
2024-02-29 21:31:42 +02:00
## Development
### Setup
1. Clone the repo into a public GitHub repository (or fork https://github.com/algora-io/tv/fork).
```sh
git clone https://github.com/algora-io/tv.git
```
2. Go to the project folder
```sh
cd tv
```
3. Install dependencies with mix
```sh
mix deps.get
```
4. Set up your `.env` file
- Duplicate `.env.example` to `.env`
- Add your environment variables in the `.env` file
5. Create and migrate your database with mix
```sh
mix ecto.setup
```
6. Start your development server
```sh
env $(cat .env | xargs -L 1) iex -S mix phx.server
```
<!-- LICENSE -->
## License
Distributed under the [AGPLv3 License](https://github.com/algora-io/tv/blob/main/LICENSE). See `LICENSE` for more information.
<!-- ACKNOWLEDGEMENTS -->
## Acknowledgements
Special thanks to these amazing projects which help power Algora TV:
- [Tigris](https://www.tigrisdata.com/)
- [Fly.io](https://fly.io/)
- [Phoenix Framework](https://www.phoenixframework.org/)
- [Ecto](https://github.com/elixir-ecto/ecto)
- [Membrane](https://membrane.stream/)
- [FFmpeg](https://ffmpeg.org/)
- [Tailwind CSS](https://tailwindcss.com/)