Refactoring webrtc sync handler

This commit is contained in:
Alexey Khit
2023-02-18 11:24:44 +03:00
parent 6b00134575
commit 41cdcb69c6
+33 -74
View File
@@ -15,11 +15,6 @@ import (
"net/http" "net/http"
) )
type jsonSdp struct {
Type string `json:"type"`
Sdp string `json:"sdp"`
}
func Init() { func Init() {
var cfg struct { var cfg struct {
Mod struct { Mod struct {
@@ -145,6 +140,12 @@ func asyncHandler(tr *api.Transport, msg *api.Message) error {
return nil return nil
} }
type SDP struct {
Type string `json:"type"`
Sdp string `json:"sdp"`
}
// syncHandler
func syncHandler(w http.ResponseWriter, r *http.Request) { func syncHandler(w http.ResponseWriter, r *http.Request) {
url := r.URL.Query().Get("src") url := r.URL.Query().Get("src")
stream := streams.Get(url) stream := streams.Get(url)
@@ -152,74 +153,52 @@ func syncHandler(w http.ResponseWriter, r *http.Request) {
return return
} }
mediaType, err := DetermineMediaType(r) var offer string
if err != nil {
log.Error().Err(err).Caller().Msg("DetermineMediaType") ct := r.Header.Get("Content-Type")
return if ct != "" {
ct, _, _ = mime.ParseMediaType(ct)
} }
// get offer if ct == "application/json" {
var v SDP
if err := json.NewDecoder(r.Body).Decode(&v); err != nil {
log.Error().Err(err).Caller().Send()
http.Error(w, err.Error(), http.StatusBadRequest)
return
}
offer = v.Sdp
} else {
body, err := io.ReadAll(r.Body) body, err := io.ReadAll(r.Body)
if err != nil { if err != nil {
log.Error().Err(err).Caller().Msg("ioutil.ReadAll") log.Error().Err(err).Caller().Send()
http.Error(w, err.Error(), http.StatusInternalServerError)
return return
} }
offer = string(body)
offer, err := DeserializeOffer(mediaType, body)
if err != nil {
log.Error().Err(err).Caller().Msg("DeserializeOffer")
return
} }
answer, err := ExchangeSDP(stream, offer, r.UserAgent()) answer, err := ExchangeSDP(stream, offer, r.UserAgent())
if err != nil { if err != nil {
log.Error().Err(err).Caller().Msg("ExchangeSDP") log.Error().Err(err).Caller().Send()
return http.Error(w, err.Error(), http.StatusInternalServerError)
}
response, err := SerializeAnswer(mediaType, answer)
if err != nil {
log.Error().Err(err).Caller().Msg("SerializeAnswer")
return return
} }
// send SDP to client // send SDP to client
if _, err = w.Write(response); err != nil { if ct == "application/json" {
log.Error().Err(err).Caller().Msg("w.Write") w.Header().Set("Content-Type", ct)
}
}
func DetermineMediaType(r *http.Request) (mediaType string, err error) { v := SDP{Sdp: answer, Type: "answer"}
contentType := r.Header.Get("Content-Type") if err = json.NewEncoder(w).Encode(v); err != nil {
if contentType != "" { log.Error().Err(err).Caller().Send()
mediaType, _, err = mime.ParseMediaType(contentType) http.Error(w, err.Error(), http.StatusInternalServerError)
if err != nil {
log.Error().Err(err).Caller().Msg("mime.ParseMediaType")
return
} }
} else { } else {
mediaType = "text/plain" if _, err = w.Write([]byte(answer)); err != nil {
log.Error().Err(err).Caller().Send()
} }
return
}
func DeserializeOffer(mediaType string, body []byte) (offer string, err error) {
switch mediaType {
case "application/json":
var jsonOffer jsonSdp
err = json.Unmarshal(body, &jsonOffer)
if err != nil {
log.Error().Err(err).Caller().Msg("json.Unmarshal")
return
} }
offer = jsonOffer.Sdp
break
default:
offer = string(body)
break
}
return
} }
func ExchangeSDP( func ExchangeSDP(
@@ -274,23 +253,3 @@ func ExchangeSDP(
return return
} }
func SerializeAnswer(mediaType string, answer string) (response []byte, err error) {
switch mediaType {
case "application/json":
jsonAnswer := jsonSdp{
Sdp: answer,
Type: "answer",
}
response, err = json.Marshal(jsonAnswer)
if err != nil {
log.Error().Err(err).Caller().Msg("json.Marshal")
return
}
break
default:
response = []byte(answer)
break
}
return
}