Adds API for create and delete stream
This commit is contained in:
+29
-6
@@ -9,6 +9,8 @@ import (
|
|||||||
"github.com/rs/zerolog"
|
"github.com/rs/zerolog"
|
||||||
"net"
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"os"
|
||||||
|
"strconv"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Init() {
|
func Init() {
|
||||||
@@ -38,7 +40,8 @@ func Init() {
|
|||||||
HandleFunc("/api/frame.mp4", frameHandler)
|
HandleFunc("/api/frame.mp4", frameHandler)
|
||||||
HandleFunc("/api/frame.raw", frameHandler)
|
HandleFunc("/api/frame.raw", frameHandler)
|
||||||
HandleFunc("/api/stack", stackHandler)
|
HandleFunc("/api/stack", stackHandler)
|
||||||
HandleFunc("/api/stats", statsHandler)
|
HandleFunc("/api/streams", streamsHandler)
|
||||||
|
HandleFunc("/api/exit", exitHandler)
|
||||||
HandleFunc("/api/ws", apiWS)
|
HandleFunc("/api/ws", apiWS)
|
||||||
|
|
||||||
// ensure we can listen without errors
|
// ensure we can listen without errors
|
||||||
@@ -69,19 +72,39 @@ var basePath string
|
|||||||
var log zerolog.Logger
|
var log zerolog.Logger
|
||||||
var wsHandlers = make(map[string]WSHandler)
|
var wsHandlers = make(map[string]WSHandler)
|
||||||
|
|
||||||
func statsHandler(w http.ResponseWriter, _ *http.Request) {
|
func streamsHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
v := map[string]interface{}{
|
src := r.URL.Query().Get("src")
|
||||||
"streams": streams.All(),
|
|
||||||
|
switch r.Method {
|
||||||
|
case "PUT":
|
||||||
|
streams.Get(src)
|
||||||
|
return
|
||||||
|
case "DELETE":
|
||||||
|
streams.Delete(src)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
var v interface{}
|
||||||
|
if src != "" {
|
||||||
|
v = streams.Get(src)
|
||||||
|
} else {
|
||||||
|
v = streams.All()
|
||||||
}
|
}
|
||||||
data, err := json.Marshal(v)
|
data, err := json.Marshal(v)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error().Err(err).Msg("[api.stats] marshal")
|
log.Error().Err(err).Msg("[api.streams] marshal")
|
||||||
}
|
}
|
||||||
if _, err = w.Write(data); err != nil {
|
if _, err = w.Write(data); err != nil {
|
||||||
log.Error().Err(err).Msg("[api.stats] write")
|
log.Error().Err(err).Msg("[api.streams] write")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func exitHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
|
s := r.URL.Query().Get("code")
|
||||||
|
code, _ := strconv.Atoi(s)
|
||||||
|
os.Exit(code)
|
||||||
|
}
|
||||||
|
|
||||||
func apiWS(w http.ResponseWriter, r *http.Request) {
|
func apiWS(w http.ResponseWriter, r *http.Request) {
|
||||||
ctx := new(Context)
|
ctx := new(Context)
|
||||||
if err := ctx.Upgrade(w, r); err != nil {
|
if err := ctx.Upgrade(w, r); err != nil {
|
||||||
|
|||||||
@@ -34,6 +34,10 @@ func Get(name string) *Stream {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func Delete(name string) {
|
||||||
|
delete(streams, name)
|
||||||
|
}
|
||||||
|
|
||||||
func All() map[string]interface{} {
|
func All() map[string]interface{} {
|
||||||
all := map[string]interface{}{}
|
all := map[string]interface{}{}
|
||||||
for name, stream := range streams {
|
for name, stream := range streams {
|
||||||
|
|||||||
Reference in New Issue
Block a user