mirror of
https://github.com/ynput/ayon-core.git
synced 2025-12-26 05:42:15 +01:00
190 lines
5.5 KiB
Python
190 lines
5.5 KiB
Python
import os
|
|
import logging
|
|
|
|
from openpype.settings import get_system_settings, get_project_settings
|
|
from openpype.pipeline import legacy_io
|
|
from openpype.pipeline.plugin_discover import (
|
|
discover,
|
|
register_plugin,
|
|
register_plugin_path,
|
|
deregister_plugin,
|
|
deregister_plugin_path
|
|
)
|
|
from .utils import get_representation_path_from_context
|
|
|
|
|
|
class LoaderPlugin(list):
|
|
"""Load representation into host application
|
|
|
|
Arguments:
|
|
context (dict): avalon-core:context-1.0
|
|
name (str, optional): Use pre-defined name
|
|
namespace (str, optional): Use pre-defined namespace
|
|
|
|
.. versionadded:: 4.0
|
|
This class was introduced
|
|
|
|
"""
|
|
|
|
families = list()
|
|
representations = list()
|
|
order = 0
|
|
is_multiple_contexts_compatible = False
|
|
|
|
options = []
|
|
|
|
log = logging.getLogger("SubsetLoader")
|
|
log.propagate = True
|
|
|
|
def __init__(self, context):
|
|
self.fname = self.filepath_from_context(context)
|
|
|
|
@classmethod
|
|
def apply_settings(cls, project_settings, system_settings):
|
|
host_name = os.environ.get("AVALON_APP")
|
|
plugin_type = "load"
|
|
plugin_type_settings = (
|
|
project_settings
|
|
.get(host_name, {})
|
|
.get(plugin_type, {})
|
|
)
|
|
global_type_settings = (
|
|
project_settings
|
|
.get("global", {})
|
|
.get(plugin_type, {})
|
|
)
|
|
if not global_type_settings and not plugin_type_settings:
|
|
return
|
|
|
|
plugin_name = cls.__name__
|
|
|
|
plugin_settings = None
|
|
# Look for plugin settings in host specific settings
|
|
if plugin_name in plugin_type_settings:
|
|
plugin_settings = plugin_type_settings[plugin_name]
|
|
|
|
# Look for plugin settings in global settings
|
|
elif plugin_name in global_type_settings:
|
|
plugin_settings = global_type_settings[plugin_name]
|
|
|
|
if not plugin_settings:
|
|
return
|
|
|
|
print(">>> We have preset for {}".format(plugin_name))
|
|
for option, value in plugin_settings.items():
|
|
if option == "enabled" and value is False:
|
|
setattr(cls, "active", False)
|
|
print(" - is disabled by preset")
|
|
else:
|
|
setattr(cls, option, value)
|
|
print(" - setting `{}`: `{}`".format(option, value))
|
|
|
|
@classmethod
|
|
def get_representations(cls):
|
|
return cls.representations
|
|
|
|
@classmethod
|
|
def filepath_from_context(cls, context):
|
|
return get_representation_path_from_context(context)
|
|
|
|
def load(self, context, name=None, namespace=None, options=None):
|
|
"""Load asset via database
|
|
|
|
Arguments:
|
|
context (dict): Full parenthood of representation to load
|
|
name (str, optional): Use pre-defined name
|
|
namespace (str, optional): Use pre-defined namespace
|
|
options (dict, optional): Additional settings dictionary
|
|
|
|
"""
|
|
raise NotImplementedError("Loader.load() must be "
|
|
"implemented by subclass")
|
|
|
|
def update(self, container, representation):
|
|
"""Update `container` to `representation`
|
|
|
|
Arguments:
|
|
container (avalon-core:container-1.0): Container to update,
|
|
from `host.ls()`.
|
|
representation (dict): Update the container to this representation.
|
|
|
|
"""
|
|
raise NotImplementedError("Loader.update() must be "
|
|
"implemented by subclass")
|
|
|
|
def remove(self, container):
|
|
"""Remove a container
|
|
|
|
Arguments:
|
|
container (avalon-core:container-1.0): Container to remove,
|
|
from `host.ls()`.
|
|
|
|
Returns:
|
|
bool: Whether the container was deleted
|
|
|
|
"""
|
|
|
|
raise NotImplementedError("Loader.remove() must be "
|
|
"implemented by subclass")
|
|
|
|
@classmethod
|
|
def get_options(cls, contexts):
|
|
"""
|
|
Returns static (cls) options or could collect from 'contexts'.
|
|
|
|
Args:
|
|
contexts (list): of repre or subset contexts
|
|
Returns:
|
|
(list)
|
|
"""
|
|
return cls.options or []
|
|
|
|
|
|
class SubsetLoaderPlugin(LoaderPlugin):
|
|
"""Load subset into host application
|
|
Arguments:
|
|
context (dict): avalon-core:context-1.0
|
|
name (str, optional): Use pre-defined name
|
|
namespace (str, optional): Use pre-defined namespace
|
|
"""
|
|
|
|
def __init__(self, context):
|
|
pass
|
|
|
|
|
|
def discover_loader_plugins(project_name=None):
|
|
from openpype.lib import Logger
|
|
|
|
log = Logger.get_logger("LoaderDiscover")
|
|
plugins = discover(LoaderPlugin)
|
|
if not project_name:
|
|
project_name = legacy_io.active_project()
|
|
system_settings = get_system_settings()
|
|
project_settings = get_project_settings(project_name)
|
|
for plugin in plugins:
|
|
try:
|
|
plugin.apply_settings(project_settings, system_settings)
|
|
except Exception:
|
|
log.warning(
|
|
"Failed to apply settings to loader {}".format(
|
|
plugin.__name__
|
|
),
|
|
exc_info=True
|
|
)
|
|
return plugins
|
|
|
|
|
|
def register_loader_plugin(plugin):
|
|
return register_plugin(LoaderPlugin, plugin)
|
|
|
|
|
|
def deregister_loader_plugin(plugin):
|
|
deregister_plugin(LoaderPlugin, plugin)
|
|
|
|
|
|
def deregister_loader_plugin_path(path):
|
|
deregister_plugin_path(LoaderPlugin, path)
|
|
|
|
|
|
def register_loader_plugin_path(path):
|
|
return register_plugin_path(LoaderPlugin, path)
|