From 3ea3721f59120d23ccaac88e3c1b3271c69252b6 Mon Sep 17 00:00:00 2001 From: Thulinma Date: Thu, 9 Nov 2017 15:55:24 +0100 Subject: [PATCH] Fix Facebook resume support --- src/output/output_rtmp.cpp | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/src/output/output_rtmp.cpp b/src/output/output_rtmp.cpp index 2e8d0d28..de4bad31 100644 --- a/src/output/output_rtmp.cpp +++ b/src/output/output_rtmp.cpp @@ -137,6 +137,16 @@ namespace Mist{ bool OutRTMP::onFinish(){ MEDIUM_MSG("Finishing stream %s, %s", streamName.c_str(), myConn?"while connected":"already disconnected"); if (myConn){ + if (isRecording()){ + AMF::Object amfreply("container", AMF::AMF0_DDV_CONTAINER); + amfreply.addContent(AMF::Object("", "deleteStream")); //status reply + amfreply.addContent(AMF::Object("", (double)6)); //transaction ID + amfreply.addContent(AMF::Object("", (double)0, AMF::AMF0_NULL)); //null - command info + amfreply.addContent(AMF::Object("", (double)1)); //No clue. But OBS sends this, too. + sendCommand(amfreply, 20, 1); + myConn.close(); + return false; + } myConn.SendNow(RTMPStream::SendUSR(1, 1)); //send UCM StreamEOF (1), stream 1 AMF::Object amfreply("container", AMF::AMF0_DDV_CONTAINER); amfreply.addContent(AMF::Object("", "onStatus")); //status reply