Files
rkKVM/cmd/kvm/main.go

64 lines
1.3 KiB
Go

package main
import (
"fmt"
"rkkvm/config"
"rkkvm/http/hw/rtc"
"rkkvm/http/hw/stream"
"rkkvm/http/route"
"strings"
"github.com/gin-gonic/gin"
log "github.com/sirupsen/logrus"
)
const ConfigFile = "/etc/rkkvm/rkkvm.yml"
func main() {
if err := config.Load(ConfigFile); err != nil {
config.Init()
if err = config.Save(ConfigFile); err != nil {
log.Error(err)
}
}
cfg := config.Get()
lvl, err := log.ParseLevel(cfg.LogLevel)
if err == nil {
log.SetLevel(lvl)
} else {
log.Println("Failed to parse log level, use default level: info")
}
if cfg.Stream.Source == config.StreamSourceMjpeg {
ustreamer := stream.Init(cfg.UStreamer.Path, strings.Split(cfg.UStreamer.Args, " "))
ustreamer.Start()
//go ustreamer.Watch()
} else if cfg.Stream.Source == config.StreamSourceH264 {
v := stream.InitFFmpeg()
v.Start()
} else {
log.Fatalf("unsupported stream source type: %v", cfg.Stream.Source)
}
webrtc, err := rtc.InitListener(cfg.WebRtc.Host, cfg.WebRtc.Port, 5006)
if err != nil {
log.Fatal(err)
}
defer webrtc.Close()
go webrtc.VideoListenerRead()
go webrtc.AudioListenerRead()
r := gin.Default()
r.Use(gin.Recovery())
route.Api(r)
route.Static(r)
if cfg.NanoKVMUISupport {
route.Auth(r)
route.VM(r)
}
r.Run(fmt.Sprintf(":%d", cfg.Port))
}