owncast/main.go

84 lines
1.5 KiB
Go
Raw Normal View History

2020-05-24 03:57:49 +03:00
package main
import (
"encoding/json"
2020-05-24 03:57:49 +03:00
"net/http"
2020-06-02 02:53:31 +03:00
"strconv"
2020-05-24 03:57:49 +03:00
icore "github.com/ipfs/interface-go-ipfs-core"
2020-05-24 03:57:49 +03:00
log "github.com/sirupsen/logrus"
)
var ipfs icore.CoreAPI
2020-06-02 02:53:31 +03:00
var configuration = getConfig()
var server *Server
var online = false
2020-05-30 04:08:33 +03:00
func main() {
2020-06-02 02:53:31 +03:00
checkConfig(configuration)
// resetDirectories()
2020-05-30 04:08:33 +03:00
2020-06-02 02:53:31 +03:00
var hlsDirectoryPath = configuration.PublicHLSPath
2020-06-02 02:53:31 +03:00
log.Println("Starting up. Please wait...")
if configuration.IPFS.Enabled {
hlsDirectoryPath = configuration.PrivateHLSPath
enableIPFS()
go monitorVideoContent(hlsDirectoryPath, configuration, &ipfs)
}
2020-05-24 03:57:49 +03:00
go startChatServer()
startRTMPService()
}
2020-06-02 02:53:31 +03:00
func enableIPFS() {
log.Println("Enabling IPFS support...")
ipfsInstance, node, _ := createIPFSInstance()
ipfs = *ipfsInstance
createIPFSDirectory(ipfsInstance, "./hls")
go startIPFSNode(ipfs, node)
}
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-02 02:53:31 +03:00
log.Fatal(http.ListenAndServe(":"+strconv.Itoa(configuration.WebServerPort), nil))
}
func getStatus(w http.ResponseWriter, r *http.Request) {
status := Status{
Online: online,
ViewerCount: server.ClientCount(),
}
json.NewEncoder(w).Encode(status)
}
func streamConnected() {
online = true
}
func streamDisconnected() {
online = false
}
func viewerAdded() {
}
func viewerRemoved() {
}