0

Update WIP backend arch document

This commit is contained in:
Gabe Kangas 2023-02-23 11:59:44 -08:00
parent 1c53659de4
commit 38b8fd0065
No known key found for this signature in database
GPG Key ID: 4345B2060657F330

View File

@ -1,10 +1,30 @@
# Owncast Backend Architecture # Owncast Backend Architecture
Work in progress documentation detailing the backend architecture of Owncast. This is a work in progress document detailing the future backend architecture of Owncast. It should be seen as a living document until a refactor of the backend is complete.
## Structure ## Dependencies
WIP Dependencies are services that are required across the application. This can be things like the chat service or a data repository for config values or user data.
Note: A better name that "dependencies" might be clearer. Perhaps "services" or "providers".
TODO: Have a complete list of dependencies.
### Data Repositories
The repository pattern provides a layer of abstraction between the application and the data store, allowing the application to interact with the data store through a well-defined interface, rather than directly accessing the data store. This helps to decouple the application from the data store.
TODO: List out the repositories and what they do.
Learn more about the [repository pattern](https://techinscribed.com/different-approaches-to-pass-database-connection-into-controllers-in-golang/).
### Application Controller
The `AppController` has references to all the dependencies and serves as an arbiter between consumers of these services and the services themselves.
A reference to the `AppController` is passed in to the all the core functionality in the application and each package would have its own interface that `AppController` implements. This can include getting access to dependency services like getting access to the chat service, getting access to the config repository values or knowing application state such as if a stream is live or how many viewers are watching via metrics.
TODO: Show examples of how the application is passed in to packages and how to reference dependencies through it.
## Diagram ## Diagram
@ -14,6 +34,8 @@ WIP
%% for a cheat sheet on creating this diagram. %% for a cheat sheet on creating this diagram.
%% Paste this document in https://mermaid.live as a quick way to edit. %% Paste this document in https://mermaid.live as a quick way to edit.
%% TODO: Add links between nodes and the actual code.
%% This is a graph style diagram, Top Down. %% This is a graph style diagram, Top Down.
graph TD graph TD
@ -23,25 +45,31 @@ graph TD
subgraph VideoPipeline[Video Pipeline] subgraph VideoPipeline[Video Pipeline]
VideoTranscoder(fa:fa-video Video Transcoder) VideoTranscoder(fa:fa-video Video Transcoder)
RTMPService[fa:fa-video RTMP Service] RTMPService[fa:fa-video RTMP Service]
FFMpeg[fa:fa-video ffmpeg]
end end
subgraph ChatService[fa:fa-comment Chat Service] subgraph ChatService[fa:fa-comment Chat Service]
end end
subgraph Dependencies subgraph Dependencies
subgraph Webhooks[fa:fa-webhook Webhooks] OutboundWebhooks[Outbound]
InboundWebhooks[Inbound]
OutboundWebhooks[Outbound]
end
App{Application} App{Application}
ChatService--->App ChatService--->App
Webhooks--->App Webhooks--->App
ConfigRepository(fa:fa-hard-drive Config Repository)--->App ConfigRepository(fa:fa-hard-drive Config Repository)--->App
UserRepository(fa:fa-hard-drive User Repository)--->App UserRepository(fa:fa-hard-drive User Repository)--->App
APRepository(fa:fa-hard-drive ActivityPub Repository)--->App
NotificationsRepository(fa:fa-hard-drive Notifications Repository)--->App
ChatRepository(fa:fa-hard-drive Chat Repository)
Database(fa:fa-hard-drive Database)--->ConfigRepository Database(fa:fa-hard-drive Database)--->ConfigRepository
Database--->UserRepository Database--->UserRepository
Database--->APRepository
Database--->NotificationsRepository
ChatRepository-->ChatService
ApplicationState(fa:fa-list Application State)--->App ApplicationState(fa:fa-list Application State)--->App
GeoIP(fa:fa-globe GeoIP Lookup)--->App GeoIP(fa:fa-globe GeoIP Lookup)--->App
Statistics(fa:fa-list Statistics)--->App Statistics(fa:fa-list Statistics)--->App
@ -69,8 +97,6 @@ end
subgraph WebServer[Web Server] subgraph WebServer[Web Server]
ActivityPubHandlers[fa:fa-file ActivityPub Handlers] ActivityPubHandlers[fa:fa-file ActivityPub Handlers]
StaticFiles((fa:fa-file Static Files))
WebSocket[WebSocket]
subgraph WebAssets[Web Assets] subgraph WebAssets[Web Assets]
EmbeddedStaticFiles((fa:fa-file Embedded\nStatic Assets)) EmbeddedStaticFiles((fa:fa-file Embedded\nStatic Assets))
@ -80,8 +106,9 @@ subgraph WebServer[Web Server]
end end
subgraph HTTPHandlers[fa:fa-browser HTTP Handlers] subgraph HTTPHandlers[fa:fa-browser HTTP Handlers]
subgraph AdminAPIs[Admin APIs] AdminAPIs[Admin APIs]
end ThirdPartyAPIs[3rd Party APIs]
WebSocket[WebSocket]
subgraph ChatAPIs[Chat APIs] subgraph ChatAPIs[Chat APIs]
ChatUserRegistration[Chat User Registration] ChatUserRegistration[Chat User Registration]
Emoji[Emojis] Emoji[Emojis]
@ -106,17 +133,10 @@ subgraph Streamer
BroadcastingSoftware>fa:fa-video BroadcastingSoftware] BroadcastingSoftware>fa:fa-video BroadcastingSoftware]
end end
subgraph Viewer
VideoPlayer[fa:fa-video Video Player]
WebBrowser[fa:fa-browser Web Browser]
end
%% All the services and packages require access %% All the services and packages require access
%% to dependencies through a Application reference. %% to dependencies through a Application reference.
App-.->HTTPHandlers App-.->HTTPHandlers
App-.->RTMPService App-.->VideoPipeline
App-.->ActivityPub App-.->ActivityPub
App-.->Authentication App-.->Authentication
App-.Stream went\nonline.->Notifications App-.Stream went\nonline.->Notifications
@ -126,8 +146,6 @@ LocalStorage--HLS-->OnDiskStaticFiles
RTMPService>RTMP Ingest]--RTMP-->VideoTranscoder RTMPService>RTMP Ingest]--RTMP-->VideoTranscoder
VideoTranscoder--HLS-->VideoStorageProviders VideoTranscoder--HLS-->VideoStorageProviders
VideoTranscoder--RTMP-->FFMpeg
FFMpeg--HLS-->VideoTranscoder
%% Viewers %% Viewers
VideoPlayer-->VideoStorageProviders VideoPlayer-->VideoStorageProviders
@ -151,8 +169,10 @@ classDef storage fill:#42bea6,color:#fff
class App bigtext class App bigtext
class UserRepository repository class UserRepository repository
class ConfigRepository repository class ConfigRepository repository
class APRepository repository
class NotificationsRepository repository
class ChatRepository repository
class WebSocket inbound
class HTTPHandlers inbound class HTTPHandlers inbound
class ActivityPubInboundHandlers inbound class ActivityPubInboundHandlers inbound
class InboundWebhooks inbound class InboundWebhooks inbound