from couchpotato.core.event import addEvent, fireEvent from couchpotato.core.helpers.variable import mergeDicts from couchpotato.core.logger import CPLog from couchpotato.core.plugins.base import Plugin from couchpotato.environment import Env import os import shutil import traceback log = CPLog(__name__) class MetaDataBase(Plugin): enabled_option = 'meta_enabled' def __init__(self): addEvent('renamer.after', self.create) def create(self, message = None, group = {}): if self.isDisabled(): return log.info('Creating %s metadata.', self.getName()) # Update library to get latest info try: updated_library = fireEvent('library.update', group['library']['identifier'], force = True, single = True) group['library'] = mergeDicts(group['library'], updated_library) except: log.error('Failed to update movie, before creating metadata: %s', traceback.format_exc()) root_name = self.getRootName(group) meta_name = os.path.basename(root_name) root = os.path.dirname(root_name) movie_info = group['library'].get('info') for file_type in ['nfo', 'thumbnail', 'fanart']: try: # Get file path name = getattr(self, 'get' + file_type.capitalize() + 'Name')(meta_name, root) if name and self.conf('meta_' + file_type): # Get file content content = getattr(self, 'get' + file_type.capitalize())(movie_info = movie_info, data = group) if content: log.debug('Creating %s file: %s', (file_type, name)) if os.path.isfile(content): shutil.copy2(content, name) else: self.createFile(name, content) group['renamed_files'].append(name) try: os.chmod(name, Env.getPermission('file')) except: log.debug('Failed setting permissions for %s: %s', (name, traceback.format_exc())) except: log.error('Unable to create %s file: %s', (file_type, traceback.format_exc())) def getRootName(self, data): return def getFanartName(self, name, root): return def getThumbnailName(self, name, root): return def getNfoName(self, name, root): return def getNfo(self, movie_info = {}, data = {}): return def getThumbnail(self, movie_info = {}, data = {}, wanted_file_type = 'poster_original'): file_types = fireEvent('file.types', single = True) for file_type in file_types: if file_type.get('identifier') == wanted_file_type: break # See if it is in current files for cur_file in data['library'].get('files', []): if cur_file.get('type_id') is file_type.get('id') and os.path.isfile(cur_file.get('path')): return cur_file.get('path') # Download using existing info try: images = data['library']['info']['images'][wanted_file_type] file_path = fireEvent('file.download', url = images[0], single = True) return file_path except: pass def getFanart(self, movie_info = {}, data = {}): return self.getThumbnail(movie_info = movie_info, data = data, wanted_file_type = 'backdrop_original')