1
0
mirror of https://github.com/algora-io/tv.git synced 2024-11-26 01:00:20 +02:00
Open source Twitch for developers
Go to file
2024-03-22 18:00:24 +03:00
assets add route /:channel_handle/:video_id (#9) 2024-03-11 23:40:26 +03:00
config add read replicas & dns clustering for distributed elixir nodes (#7) 2024-03-11 21:55:17 +03:00
lib increase segment duration to 2 seconds 2024-03-22 18:00:12 +03:00
priv add read replicas & dns clustering for distributed elixir nodes (#7) 2024-03-11 21:55:17 +03:00
rel initial commit 2024-02-29 22:31:42 +03:00
scripts backfill more video data 2024-03-07 03:27:01 +03:00
.credo.exs initial commit 2024-02-29 22:31:42 +03:00
.dockerignore initial commit 2024-02-29 22:31:42 +03:00
.env.example initial commit 2024-02-29 22:31:42 +03:00
.formatter.exs initial commit 2024-02-29 22:31:42 +03:00
.gitignore initial commit 2024-02-29 22:31:42 +03:00
.iex.exs initial commit 2024-02-29 22:31:42 +03:00
Dockerfile initial commit 2024-02-29 22:31:42 +03:00
fiex add script for opening an IEx shell into the server 2024-03-06 19:26:07 +03:00
fly.toml update fly vm specs 2024-03-22 18:00:24 +03:00
LICENSE initial commit 2024-02-29 22:31:42 +03:00
mix.exs update dependency 2024-03-12 03:25:20 +03:00
mix.lock add read replicas & dns clustering for distributed elixir nodes (#7) 2024-03-11 21:55:17 +03:00
README.md add more charts 2024-03-11 21:44:08 +03:00

Logo

Algora TV

The interactive livestreaming & video sharing service for developers.
Website · Discord · Twitter · YouTube · Issues

Architecture

graph
    Streamers{Streamers} --> Fly
    Fly[Elixir App - Fly] --> RTMP
    Fly --> Web[Web Server - Phoenix]
    Fly --> Db[Postgres - Fly]
    RTMP[RTMP Server - Membrane] -->|First mile delivery| Tigris[Object Storage - Tigris]
    Viewers{Viewers} -->|Last mile delivery| Tigris
    Viewers --> Fly
graph
    Encoder{Encoder} -->|RTMP packets| Source[RTMP Source]
    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]
    CMAFMuxerVideo --> HLSSink
    CMAFMuxerAudio --> HLSSink
    HLSSink[HLS Sink] --> Tigris{Tigris Object Storage}
graph
    App[Application] --> RTMP[RTMP Server]
    App --> Endpoint[Web Server]
    App --> Repo[Ecto Repo]
    App --> Telemetry
    App --> PubSub
    App --> Presence
    App --> DNSCluster[DNS Cluster]
    App --> FlyRPC[Fly RPC]

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

Development

Setup

  1. Clone the repo into a public GitHub repository (or fork https://github.com/algora-io/tv/fork).

    git clone https://github.com/algora-io/tv.git
    
  2. Go to the project folder

    cd tv
    
  3. Install dependencies with mix

    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

    mix ecto.setup
    
  6. Start your development server

    env $(cat .env | xargs -L 1) iex -S mix phx.server
    

License

Distributed under the AGPLv3 License. See LICENSE for more information.

Acknowledgements

Special thanks to these amazing projects which help power Algora TV: