from __future__ import unicode_literals
import youtube_dl
import os
import logging

logger = logging.getLogger(__name__)


class MyLogger(object):
    def debug(self, msg): pass
    def warning(self, msg): pass
    def error(self, msg):
        logger.error(msg)



class YouTubeDownloader:
    def __init__(self) -> None:
        pass


    def post_download_hook(self, ret_code):
        # print(ret_code)
        if ret_code['status'] == 'finished':
            file_loc = ret_code["filename"]
            fname = os.path.basename(file_loc)
            self.article_object.file_name = fname


    def save_video(self, article_object):
        """Saves video accoring to url and save path"""
        self.article_object = article_object
        url = article_object.article_url
        logger.info("Saving new video")
        file_path = os.path.join(article_object.save_path, article_object.fname_template)
        ydl_opts = {
            'format': 'best[height<=720]',
            'outtmpl': f"{file_path}.%(ext)s", # basically the filename from the object, but with a custom extension depending on the download
            'logger': MyLogger(),
            'progress_hooks': [self.post_download_hook],
            'updatetime': False
        }
        try:
            with youtube_dl.YoutubeDL(ydl_opts) as ydl:
                ydl.download([url])
                # article file name is updated in self.post_download_hook
        except Exception as e:
            logger.error(f"Youtube download crashed: {e}")
            article_object.file_name = ""

        return article_object