0
owncast/main.go

91 lines
1.9 KiB
Go
Raw Normal View History

2020-05-23 17:57:49 -07:00
package main
import (
"encoding/json"
2020-05-23 17:57:49 -07:00
"net/http"
2020-06-01 16:53:31 -07:00
"strconv"
2020-05-23 17:57:49 -07:00
log "github.com/sirupsen/logrus"
)
var storage ChunkStorage
2020-06-01 16:53:31 -07:00
var configuration = getConfig()
var server *Server
2020-06-10 23:52:55 -07:00
var stats *Stats
var usingExternalStorage = false
2020-05-29 18:08:33 -07:00
func main() {
2020-06-01 16:53:31 -07:00
log.Println("Starting up. Please wait...")
2020-06-09 01:52:15 -07:00
resetDirectories(configuration)
checkConfig(configuration)
2020-06-10 23:52:55 -07:00
stats = getSavedStats()
stats.Setup()
2020-06-01 16:53:31 -07:00
if configuration.IPFS.Enabled {
storage = &IPFSStorage{}
2020-06-03 01:34:05 -07:00
usingExternalStorage = true
} else if configuration.S3.Enabled {
storage = &S3Storage{}
usingExternalStorage = true
}
2020-06-03 01:34:05 -07:00
if usingExternalStorage {
storage.Setup(configuration)
2020-06-09 01:52:15 -07:00
// hlsDirectoryPath = configuration.PrivateHLSPath
go monitorVideoContent(configuration.PrivateHLSPath, configuration, storage)
2020-06-01 16:53:31 -07:00
}
2020-05-23 17:57:49 -07:00
go startChatServer()
startRTMPService()
}
func startChatServer() {
// log.SetFlags(log.Lshortfile)
// websocket server
server = NewServer("/entry")
go server.Listen()
// static files
http.Handle("/", http.FileServer(http.Dir("webroot")))
http.HandleFunc("/status", getStatus)
log.Printf("Starting public web server on port %d", configuration.WebServerPort)
2020-06-01 16:53:31 -07:00
log.Fatal(http.ListenAndServe(":"+strconv.Itoa(configuration.WebServerPort), nil))
}
func getStatus(w http.ResponseWriter, r *http.Request) {
status := Status{
2020-06-10 23:52:55 -07:00
Online: stats.IsStreamConnected(),
ViewerCount: stats.GetViewerCount(),
OverallMaxViewerCount: stats.GetOverallMaxViewerCount(),
SessionMaxViewerCount: stats.GetSessionMaxViewerCount(),
}
json.NewEncoder(w).Encode(status)
}
func streamConnected() {
2020-06-10 23:52:55 -07:00
stats.StreamConnected()
chunkPath := configuration.PublicHLSPath
if usingExternalStorage {
chunkPath = configuration.PrivateHLSPath
}
startThumbnailGenerator(chunkPath)
}
func streamDisconnected() {
2020-06-10 23:52:55 -07:00
stats.StreamDisconnected()
}
func viewerAdded() {
2020-06-10 23:52:55 -07:00
stats.SetViewerCount(server.ClientCount())
}
func viewerRemoved() {
2020-06-10 23:52:55 -07:00
stats.SetViewerCount(server.ClientCount())
}