#! /usr/bin/env python3 """ We aren't using either the apt or the pip repositories for the youtube_dl as there is a known bug affecting those two versions. The youtube API has changed since their release, causing downloads to fail. Make sure you use the ./setup.sh script to obtain the latest github release of yt_dlp, as this version carries the latest fixes. """ #import youtube_dl import yt_dlp as youtube_dl from streamer import Streamer, is_alive import subprocess import time import sys import os class Tuuube(Streamer): REST_PATH = 'tuuube' def __init__(self, name): super().__init__() self.name = name self.playback = None def source_path(self): return f"/tmp/{self.name}.mp3" def _stream_thread(self): if not os.path.exists(self.source_path()) or not os.path.isfile(self.source_path()): ydl_opts = { 'format': 'bestaudio/best', 'outtmpl': f'/tmp/{self.name}.%(ext)s', # yt_dlp will append %(ext) if not specified, 'postprocessors': [{ # resulting in `/tmp/file.mp3.mp3` :/ 'key': 'FFmpegExtractAudio', 'preferredcodec': 'mp3', 'preferredquality': '192', }], } try: with youtube_dl.YoutubeDL(ydl_opts) as ydl: ydl.download([f'https://www.youtube.com/watch?v={self.name}']) except Exception as e: print(f'File sourcing failed, aborting stream. {e}', file=sys.stderr) self.run = False return self.playback = subprocess.Popen( [ '/usr/bin/ffmpeg', '-re', '-stream_loop', '-1', '-i', self.source_path(), '-c', 'copy', '-f', 'rtsp', self.stream_address('localhost') ], stdin=subprocess.PIPE, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL ) while self.run: if not is_alive(self.playback): print('Playback failed, aborting stream.', file=sys.stderr) break time.sleep(0.1) self.run = False self.playback.kill() self.playback.wait() self.playback = None if __name__ == '__main__': tube = Tuuube('BaW_jenozKc') tube.start_stream() while True: print(tube.is_streaming()) time.sleep(1)