More missing lib fixes and MediaInfo cleanup

This commit is contained in:
Tim Bentley 2018-11-18 17:29:47 +00:00
parent 77613086bf
commit a3d0dc28de
7 changed files with 41 additions and 62 deletions

View File

@ -49,7 +49,8 @@ class LogMixin(object):
setattr(self, name, self.logging_wrapper(m, self)) setattr(self, name, self.logging_wrapper(m, self))
return self._logger return self._logger
def logging_wrapper(self, func, parent): @staticmethod
def logging_wrapper(func, parent):
""" """
Code to added debug wrapper to work on called functions within a decorated class. Code to added debug wrapper to work on called functions within a decorated class.
""" """

View File

@ -54,11 +54,17 @@ class PluginManager(RegistryBase, LogMixin, RegistryProperties):
def bootstrap_initialise(self): def bootstrap_initialise(self):
""" """
Bootstrap all the plugin manager functions Bootstrap all the plugin manager functions
Scan a directory for objects inheriting from the ``Plugin`` class.
""" """
self.find_plugins() glob_pattern = os.path.join('plugins', '*', '[!.]*plugin.py')
# hook methods have to happen after find_plugins. Find plugins needs extension_loader(glob_pattern)
# the controllers hence the hooks have moved from setupUI() to here plugin_classes = Plugin.__subclasses__()
# Find and insert settings tabs for p in plugin_classes:
try:
p()
self.log_debug('Loaded plugin {plugin}'.format(plugin=str(p)))
except TypeError:
self.log_exception('Failed to load plugin {plugin}'.format(plugin=str(p)))
def bootstrap_post_set_up(self): def bootstrap_post_set_up(self):
""" """
@ -86,20 +92,6 @@ class PluginManager(RegistryBase, LogMixin, RegistryProperties):
plugin.app_startup() plugin.app_startup()
self.application.process_events() self.application.process_events()
def find_plugins(self):
"""
Scan a directory for objects inheriting from the ``Plugin`` class.
"""
glob_pattern = os.path.join('plugins', '*', '[!.]*plugin.py')
extension_loader(glob_pattern)
plugin_classes = Plugin.__subclasses__()
for p in plugin_classes:
try:
p()
self.log_debug('Loaded plugin {plugin}'.format(plugin=str(p)))
except TypeError:
self.log_exception('Failed to load plugin {plugin}'.format(plugin=str(p)))
@staticmethod @staticmethod
def hook_media_manager(): def hook_media_manager():
""" """

View File

@ -32,6 +32,7 @@ import uuid
from PyQt5 import QtGui from PyQt5 import QtGui
from openlp.core.state import State
from openlp.core.common import md5_hash from openlp.core.common import md5_hash
from openlp.core.common.applocation import AppLocation from openlp.core.common.applocation import AppLocation
from openlp.core.common.i18n import translate from openlp.core.common.i18n import translate
@ -441,7 +442,7 @@ class ServiceItem(RegistryProperties):
self.processor = header.get('processor', None) self.processor = header.get('processor', None)
self.has_original_files = True self.has_original_files = True
self.metadata = header.get('item_meta_data', []) self.metadata = header.get('item_meta_data', [])
if 'background_audio' in header: if 'background_audio' in header and State().check_preconditions('media'):
self.background_audio = [] self.background_audio = []
for file_path in header['background_audio']: for file_path in header['background_audio']:
# In OpenLP 3.0 we switched to storing Path objects in JSON files # In OpenLP 3.0 we switched to storing Path objects in JSON files
@ -688,7 +689,7 @@ class ServiceItem(RegistryProperties):
self.is_valid = False self.is_valid = False
break break
elif self.is_command(): elif self.is_command():
if self.is_capable(ItemCapabilities.IsOptical): if self.is_capable(ItemCapabilities.IsOptical) and State().check_preconditions('media'):
if not os.path.exists(frame['title']): if not os.path.exists(frame['title']):
self.is_valid = False self.is_valid = False
break break

View File

@ -50,7 +50,7 @@ class MediaType(object):
Folder = 5 Folder = 5
class MediaInfo(object): class ItemMediaInfo(object):
""" """
This class hold the media related info This class hold the media related info
""" """

View File

@ -45,7 +45,7 @@ from openlp.core.lib.serviceitem import ItemCapabilities
from openlp.core.lib.ui import critical_error_message_box from openlp.core.lib.ui import critical_error_message_box
from openlp.core.ui import DisplayControllerType from openlp.core.ui import DisplayControllerType
from openlp.core.ui.icons import UiIcons from openlp.core.ui.icons import UiIcons
from openlp.core.ui.media import MediaState, MediaInfo, MediaType, parse_optical_path from openlp.core.ui.media import MediaState, ItemMediaInfo, MediaType, parse_optical_path
from openlp.core.ui.media.endpoint import media_endpoint from openlp.core.ui.media.endpoint import media_endpoint
from openlp.core.ui.media.vlcplayer import VlcPlayer, get_vlc from openlp.core.ui.media.vlcplayer import VlcPlayer, get_vlc
from openlp.core.widgets.toolbar import OpenLPToolbar from openlp.core.widgets.toolbar import OpenLPToolbar
@ -172,7 +172,7 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
State().update_pre_conditions("mediacontroller", True) State().update_pre_conditions("mediacontroller", True)
else: else:
State().missing_text("mediacontroller", translate('OpenLP.SlideController', State().missing_text("mediacontroller", translate('OpenLP.SlideController',
"VLC or pymediainfo are missing so you are unable to play any media")) "VLC or pymediainfo are missing, so you are unable to play any media"))
self._generate_extensions_lists() self._generate_extensions_lists()
return True return True
@ -182,12 +182,14 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
""" """
display = self._define_display(self.display_controllers[DisplayControllerType.Live]) display = self._define_display(self.display_controllers[DisplayControllerType.Live])
if DisplayControllerType.Live in self.current_media_players: if DisplayControllerType.Live in self.current_media_players:
print("media_state_live if")
self.current_media_players[DisplayControllerType.Live].resize(display) self.current_media_players[DisplayControllerType.Live].resize(display)
self.current_media_players[DisplayControllerType.Live].update_ui(display) self.current_media_players[DisplayControllerType.Live].update_ui(display)
self.tick(self.display_controllers[DisplayControllerType.Live]) self.tick(self.display_controllers[DisplayControllerType.Live])
if self.current_media_players[DisplayControllerType.Live].get_live_state() is not MediaState.Playing: if self.current_media_players[DisplayControllerType.Live].get_live_state() is not MediaState.Playing:
self.live_timer.stop() self.live_timer.stop()
else: else:
print("media_state_live else")
self.live_timer.stop() self.live_timer.stop()
self.media_stop(self.display_controllers[DisplayControllerType.Live]) self.media_stop(self.display_controllers[DisplayControllerType.Live])
if self.display_controllers[DisplayControllerType.Live].media_info.can_loop_playback: if self.display_controllers[DisplayControllerType.Live].media_info.can_loop_playback:
@ -199,12 +201,14 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
""" """
display = self._define_display(self.display_controllers[DisplayControllerType.Preview]) display = self._define_display(self.display_controllers[DisplayControllerType.Preview])
if DisplayControllerType.Preview in self.current_media_players: if DisplayControllerType.Preview in self.current_media_players:
print("media_state_preview if")
self.current_media_players[DisplayControllerType.Preview].resize(display) self.current_media_players[DisplayControllerType.Preview].resize(display)
self.current_media_players[DisplayControllerType.Preview].update_ui(display) self.current_media_players[DisplayControllerType.Preview].update_ui(display)
self.tick(self.display_controllers[DisplayControllerType.Preview]) self.tick(self.display_controllers[DisplayControllerType.Preview])
if self.current_media_players[DisplayControllerType.Preview].get_preview_state() is not MediaState.Playing: if self.current_media_players[DisplayControllerType.Preview].get_preview_state() is not MediaState.Playing:
self.preview_timer.stop() self.preview_timer.stop()
else: else:
print("media_state_preview else")
self.preview_timer.stop() self.preview_timer.stop()
self.media_stop(self.display_controllers[DisplayControllerType.Preview]) self.media_stop(self.display_controllers[DisplayControllerType.Preview])
if self.display_controllers[DisplayControllerType.Preview].media_info.can_loop_playback: if self.display_controllers[DisplayControllerType.Preview].media_info.can_loop_playback:
@ -225,7 +229,7 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
:param controller: First element is the controller which should be used :param controller: First element is the controller which should be used
""" """
controller.media_info = MediaInfo() controller.media_info = ItemMediaInfo()
# Build a Media ToolBar # Build a Media ToolBar
controller.mediabar = OpenLPToolbar(controller) controller.mediabar = OpenLPToolbar(controller)
controller.mediabar.add_toolbar_action('playbackPlay', text='media_playback_play', controller.mediabar.add_toolbar_action('playbackPlay', text='media_playback_play',
@ -332,7 +336,7 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
controller = self.display_controllers[source] controller = self.display_controllers[source]
# stop running videos # stop running videos
self.media_reset(controller) self.media_reset(controller)
controller.media_info = MediaInfo() controller.media_info = ItemMediaInfo()
controller.media_info.volume = controller.volume_slider.value() controller.media_info.volume = controller.volume_slider.value()
controller.media_info.is_background = video_behind_text controller.media_info.is_background = video_behind_text
# background will always loop video. # background will always loop video.
@ -353,7 +357,7 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
else: else:
log.debug('video is not optical and live') log.debug('video is not optical and live')
controller.media_info.length = service_item.media_length controller.media_info.length = service_item.media_length
is_valid = self._check_file_type(controller, display, service_item) is_valid = self._check_file_type(controller, display)
display.override['theme'] = '' display.override['theme'] = ''
display.override['video'] = True display.override['video'] = True
if controller.media_info.is_background: if controller.media_info.is_background:
@ -373,7 +377,7 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
else: else:
log.debug('video is not optical and preview') log.debug('video is not optical and preview')
controller.media_info.length = service_item.media_length controller.media_info.length = service_item.media_length
is_valid = self._check_file_type(controller, display, service_item) is_valid = self._check_file_type(controller, display)
if not is_valid: if not is_valid:
# Media could not be loaded correctly # Media could not be loaded correctly
critical_error_message_box(translate('MediaPlugin.MediaItem', 'Unsupported File'), critical_error_message_box(translate('MediaPlugin.MediaItem', 'Unsupported File'),
@ -437,7 +441,7 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
# stop running videos # stop running videos
self.media_reset(controller) self.media_reset(controller)
# Setup media info # Setup media info
controller.media_info = MediaInfo() controller.media_info = ItemMediaInfo()
controller.media_info.file_info = QtCore.QFileInfo(filename) controller.media_info.file_info = QtCore.QFileInfo(filename)
if audio_track == -1 and subtitle_track == -1: if audio_track == -1 and subtitle_track == -1:
controller.media_info.media_type = MediaType.CD controller.media_info.media_type = MediaType.CD
@ -461,33 +465,12 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
controller.media_info.media_type = MediaType.DVD controller.media_info.media_type = MediaType.DVD
return True return True
def _get_used_players(self, service_item): def _check_file_type(self, controller, display):
"""
Find the player for a given service item
:param service_item: where the information is about the media and required player
:return: player description
"""
return self.vlc_player
# If no player, we can't play
# if not used_players:
# return False
# default_player = [used_players]
# if service_item.processor and service_item.processor != UiStrings().Automatic:
# # check to see if the player is usable else use the default one.
# if service_item.processor.lower() not in used_players:
# used_players = default_player
# else:
# used_players = [service_item.processor.lower()]
# return used_players
def _check_file_type(self, controller, display, service_item):
""" """
Select the correct media Player type from the prioritized Player list Select the correct media Player type from the prioritized Player list
:param controller: First element is the controller which should be used :param controller: First element is the controller which should be used
:param display: Which display to use :param display: Which display to use
:param service_item: The ServiceItem containing the details to be played.
""" """
for file in controller.media_info.file_info: for file in controller.media_info.file_info:
if file.is_file: if file.is_file:
@ -516,7 +499,6 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
self.current_media_players[controller.controller_type] = player self.current_media_players[controller.controller_type] = player
controller.media_info.media_type = MediaType.Video controller.media_info.media_type = MediaType.Video
return True return True
# no valid player found
return False return False
def media_play_msg(self, msg, status=True): def media_play_msg(self, msg, status=True):

View File

@ -23,17 +23,13 @@
The Media plugin The Media plugin
""" """
import logging import logging
import re
from PyQt5 import QtCore from PyQt5 import QtCore
from openlp.core.state import State from openlp.core.state import State
from openlp.core.api.http import register_endpoint from openlp.core.api.http import register_endpoint
from openlp.core.common import check_binary_exists
from openlp.core.common.applocation import AppLocation
from openlp.core.common.i18n import translate from openlp.core.common.i18n import translate
from openlp.core.ui.icons import UiIcons from openlp.core.ui.icons import UiIcons
from openlp.core.common.path import Path
from openlp.core.lib import build_icon from openlp.core.lib import build_icon
from openlp.core.lib.plugin import Plugin, StringContent from openlp.core.lib.plugin import Plugin, StringContent
from openlp.plugins.media.endpoint import api_media_endpoint, media_endpoint from openlp.plugins.media.endpoint import api_media_endpoint, media_endpoint

View File

@ -25,6 +25,7 @@ import os
from PyQt5 import QtCore, QtWidgets from PyQt5 import QtCore, QtWidgets
from sqlalchemy.sql import and_, or_ from sqlalchemy.sql import and_, or_
from openlp.core.state import State
from openlp.core.common.applocation import AppLocation from openlp.core.common.applocation import AppLocation
from openlp.core.common.i18n import UiStrings, translate, get_natural_key from openlp.core.common.i18n import UiStrings, translate, get_natural_key
from openlp.core.ui.icons import UiIcons from openlp.core.ui.icons import UiIcons
@ -35,7 +36,7 @@ from openlp.core.lib import ServiceItemContext, check_item_selected, create_sepa
from openlp.core.lib.mediamanageritem import MediaManagerItem from openlp.core.lib.mediamanageritem import MediaManagerItem
from openlp.core.lib.plugin import PluginStatus from openlp.core.lib.plugin import PluginStatus
from openlp.core.lib.serviceitem import ItemCapabilities from openlp.core.lib.serviceitem import ItemCapabilities
from openlp.core.lib.ui import create_widget_action from openlp.core.lib.ui import create_widget_action, critical_error_message_box
from openlp.plugins.songs.forms.editsongform import EditSongForm from openlp.plugins.songs.forms.editsongform import EditSongForm
from openlp.plugins.songs.forms.songexportform import SongExportForm from openlp.plugins.songs.forms.songexportform import SongExportForm
from openlp.plugins.songs.forms.songimportform import SongImportForm from openlp.plugins.songs.forms.songimportform import SongImportForm
@ -632,11 +633,17 @@ class SongMediaItem(MediaManagerItem):
service_item.xml_version = self.open_lyrics.song_to_xml(song) service_item.xml_version = self.open_lyrics.song_to_xml(song)
# Add the audio file to the service item. # Add the audio file to the service item.
if song.media_files: if song.media_files:
if State().check_preconditions('media'):
service_item.add_capability(ItemCapabilities.HasBackgroundAudio) service_item.add_capability(ItemCapabilities.HasBackgroundAudio)
service_item.background_audio = [m.file_path for m in song.media_files] service_item.background_audio = [m.file_path for m in song.media_files]
service_item.metadata.append('<em>{label}:</em> {media}'. service_item.metadata.append('<em>{label}:</em> {media}'.
format(label=translate('SongsPlugin.MediaItem', 'Media'), format(label=translate('SongsPlugin.MediaItem', 'Media'),
media=service_item.background_audio)) media=service_item.background_audio))
else:
critical_error_message_box(
translate('SongsPlugin.MediaItem', 'Missing Audio Software'),
translate('SongsPlugin.MediaItem',
'Unable to play background music for Song and audio is not configured'))
return True return True
def generate_footer(self, item, song): def generate_footer(self, item, song):