Compare commits

...

3 Commits

Author SHA1 Message Date
Alexey Khit
5460e194e8 Update loggers 2022-09-06 07:08:35 +03:00
Alexey Khit
e4f565f343 Fix H264 in RTSP processing 2022-09-06 07:00:22 +03:00
Alexey Khit
6b274f2a37 Adds Hass stream info to log 2022-09-06 06:36:13 +03:00
3 changed files with 19 additions and 20 deletions

View File

@@ -26,7 +26,7 @@ func Init() {
app.LoadConfig(&conf)
log = app.GetLogger("api")
log = app.GetLogger("hass")
// support https://www.home-assistant.io/integrations/rtsp_to_webrtc/
api.HandleFunc("/static", func(w http.ResponseWriter, r *http.Request) {
@@ -78,6 +78,7 @@ func Init() {
continue
}
log.Info().Str("url", "hass:" + entrie.Title).Msg("[hass] load stream")
//streams.Get("hass:" + entrie.Title)
}
}

View File

@@ -69,7 +69,7 @@ func offerHandler(ctx *api.Context, msg *streamer.Message) {
return
}
log.Debug().Str("src", src).Msg("[webrtc] new consumer")
log.Debug().Str("url", src).Msg("[webrtc] new consumer")
var err error

View File

@@ -37,32 +37,34 @@ func RTPDepay(track *streamer.Track) streamer.WrapperFunc {
return nil
}
for {
for len(units) > 0 {
i := int(binary.BigEndian.Uint32(units)) + 4
unitAVC := units[:i]
unit := units[:i] // NAL Unit with AVC header
units = units[i:]
unitType := NALUType(unitAVC)
unitType := NALUType(unit)
//fmt.Printf("[H264] type: %2d, size: %6d\n", unitType, i)
switch unitType {
case NALUTypeSPS:
//println("new SPS")
sps = unitAVC
return nil
sps = unit
continue
case NALUTypePPS:
//println("new PPS")
pps = unitAVC
return nil
pps = unit
continue
}
// ffmpeg with `-tune zerolatency` enable option `-x264opts sliced-threads=1`
// and every NALU will be sliced to multiple NALUs
if !packet.Marker {
buffer = append(buffer, unitAVC...)
return nil
buffer = append(buffer, unit...)
continue
}
if buffer != nil {
buffer = append(buffer, unitAVC...)
unitAVC = buffer
buffer = append(buffer, unit...)
unit = buffer
buffer = nil
}
@@ -86,17 +88,13 @@ func RTPDepay(track *streamer.Track) streamer.WrapperFunc {
clone = *packet
clone.Version = RTPPacketVersionAVC
clone.Payload = unitAVC
clone.Payload = unit
if err = push(&clone); err != nil {
return err
}
if len(units) == i {
return nil
}
units = units[i:]
}
return nil
}
}
}