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 -*-
|
2013-03-01 23:39:42 +01:00
|
|
|
from __future__ import absolute_import
|
2013-02-12 19:23:56 +01:00
|
|
|
import subprocess
|
|
|
|
import shlex
|
|
|
|
|
2013-03-17 19:55:19 +01:00
|
|
|
from svtplay_dl.log import log
|
2013-12-30 01:35:08 +01:00
|
|
|
from svtplay_dl.utils import is_py2
|
2014-04-21 16:50:24 +02:00
|
|
|
from svtplay_dl.fetcher import VideoRetriever
|
2014-08-20 20:27:45 +02:00
|
|
|
from svtplay_dl.output import output
|
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):
|
2014-05-01 17:13:46 +02:00
|
|
|
def name(self):
|
2014-07-13 15:19:12 +02:00
|
|
|
return "rtmp"
|
2014-05-01 17:13:46 +02:00
|
|
|
|
2014-04-21 16:50:24 +02:00
|
|
|
def download(self):
|
|
|
|
""" Get the stream from RTMP """
|
|
|
|
args = []
|
|
|
|
if self.options.live:
|
|
|
|
args.append("-v")
|
2013-02-12 19:23:56 +01:00
|
|
|
|
2014-04-21 16:50:24 +02:00
|
|
|
if self.options.resume:
|
|
|
|
args.append("-e")
|
2013-02-12 19:23:56 +01:00
|
|
|
|
2014-12-30 21:18:01 +01:00
|
|
|
file_d = output(self.options, "flv", False)
|
2014-10-13 00:14:20 +02:00
|
|
|
if file_d is None:
|
|
|
|
return
|
2014-08-20 20:27:45 +02:00
|
|
|
args += ["-o", self.options.output]
|
2014-04-21 16:50:24 +02:00
|
|
|
if self.options.silent or self.options.output == "-":
|
|
|
|
args.append("-q")
|
|
|
|
if self.options.other:
|
|
|
|
if is_py2:
|
|
|
|
args += shlex.split(self.options.other.encode("utf-8"))
|
|
|
|
else:
|
|
|
|
args += shlex.split(self.options.other)
|
2014-03-09 15:33:13 +01:00
|
|
|
|
2014-04-21 16:50:24 +02:00
|
|
|
if self.options.verbose:
|
|
|
|
args.append("-V")
|
2014-03-09 15:33:13 +01:00
|
|
|
|
2014-04-21 16:50:24 +02:00
|
|
|
command = ["rtmpdump", "-r", self.url] + args
|
|
|
|
log.debug("Running: %s", " ".join(command))
|
|
|
|
try:
|
|
|
|
subprocess.call(command)
|
|
|
|
except OSError as e:
|
|
|
|
log.error("Could not execute rtmpdump: " + e.strerror)
|
2016-03-22 22:28:41 +01:00
|
|
|
return
|
|
|
|
self.finished = True
|
|
|
|
|
2013-02-12 19:23:56 +01:00
|
|
|
|