1
0
mirror of https://github.com/spaam/svtplay-dl.git synced 2024-11-28 06:04:17 +01:00
svtplay-dl/lib/svtplay_dl/fetcher/rtmp.py

47 lines
1.3 KiB
Python
Raw Normal View History

2013-03-02 21:26:28 +01:00
# ex:ts=4:sw=4:sts=4:et
# -*- tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*-
from __future__ import absolute_import
2013-02-12 19:23:56 +01:00
import subprocess
import shlex
from svtplay_dl.log import log
2014-04-21 16:50:24 +02:00
from svtplay_dl.fetcher import VideoRetriever
2018-05-13 01:45:40 +02:00
from svtplay_dl.utils.output import output, formatname
2013-02-12 19:23:56 +01:00
2015-09-15 20:10:32 +02:00
2014-04-21 16:50:24 +02:00
class RTMP(VideoRetriever):
2018-05-25 22:47:26 +02:00
@property
def name(self):
2014-07-13 15:19:12 +02:00
return "rtmp"
2014-04-21 16:50:24 +02:00
def download(self):
""" Get the stream from RTMP """
2018-05-13 01:45:23 +02:00
self.output_extention = "flv"
2014-04-21 16:50:24 +02:00
args = []
2018-05-13 13:06:45 +02:00
if self.config.get("live"):
2014-04-21 16:50:24 +02:00
args.append("-v")
2013-02-12 19:23:56 +01:00
2018-05-13 13:06:45 +02:00
if self.config.get("resume"):
2014-04-21 16:50:24 +02:00
args.append("-e")
2013-02-12 19:23:56 +01:00
2018-05-08 22:46:11 +02:00
file_d = output(self.output, self.config, "flv", False)
if file_d is None:
return
2018-05-13 01:45:40 +02:00
args += ["-o", formatname(self.output, self.config, "flv")]
if self.config.get("silent"):
2014-04-21 16:50:24 +02:00
args.append("-q")
2018-05-08 22:46:11 +02:00
if self.kwargs.get("other"):
args += shlex.split(self.kwargs.pop("other"))
2018-05-08 22:46:11 +02:00
if self.config.get("verbose"):
2014-04-21 16:50:24 +02:00
args.append("-V")
2014-04-21 16:50:24 +02:00
command = ["rtmpdump", "-r", self.url] + args
log.debug("Running: {0}".format(" ".join(command)))
2014-04-21 16:50:24 +02:00
try:
subprocess.call(command)
except OSError as e:
log.error("Could not execute rtmpdump: {0}".format(e.strerror))
return
self.finished = True