# Copyright (c) 2018 Shotgun Software Inc.
#
# CONFIDENTIAL AND PROPRIETARY
#
# This work is provided "AS IS" and subject to the Shotgun Pipeline Toolkit
# Source Code License included in this distribution package. See LICENSE.
# By accessing, using, copying or modifying this work you indicate your
# agreement to the Shotgun Pipeline Toolkit Source Code License. All rights
# not expressly granted therein are reserved by Shotgun Software Inc.
"""
This hook is used override some of the functionality of the :class:`~sgtk.bootstrap.ToolkitManager`.
It will be instantiated only after a configuration has been selected by the :class:`~sgtk.bootstrap.ToolkitManager`.
Therefore, this hook will not be invoked to download a configuration. However, the Toolkit Core,
applications, frameworks and engines can be downloaded through the hook.
.. warning::
    In order to be able to bootstrap Toolkit regardless of the installation method used, the bootstrap hook needs
    to be stored within the package itself. That's why this core hook is located in ``core/python/tank/bootstrap/hook``
    instead of the usual core hooks location.
"""
from sgtk import get_hook_baseclass
[docs]class Bootstrap(get_hook_baseclass()):
[docs]    def init(
        self, shotgun, pipeline_configuration_id, configuration_descriptor, **kwargs
    ):
        """
        Initializes the hook.
        This method is called right after the bootstrap manager reads this hook and passes in
        information about the pipeline configuration that will be used.
        The default implementation copies the arguments into the attributes named ``shotgun``,
        ``pipeline_configuration_id`` and ``configuration_descriptor``.
        :param shotgun: Connection to the Shotgun site.
        :type shotgun: :class:`~shotgun_api3.Shotgun`
        :param int pipeline_configuration_id: Id of the pipeline configuration we're bootstrapping into.
            If None, the ToolkitManager is bootstrapping into the base configuration.
        :param configuration_descriptor: Configuration the manager is bootstrapping into.
        :type configuration_descriptor: :class:`~sgtk.descriptor.ConfigDescriptor`
        """
        self.shotgun = shotgun
        self.pipeline_configuration_id = pipeline_configuration_id
        self.configuration_descriptor = configuration_descriptor 
[docs]    def can_cache_bundle(self, descriptor):
        """
        Indicates if a bundle can be cached by the :meth:`populate_bundle_cache_entry` method.
        This method is invoked when the bootstrap manager wants to a bundle used by a configuration.
        The default implementation returns ``False``.
        :param descriptor: Descriptor of the bundle that needs to be cached.
        :returns: ``True`` if the bundle cache be cached with this hook, ``False``
                  if not.
        :rtype: bool
        """
        return False 
[docs]    def populate_bundle_cache_entry(self, destination, descriptor, **kwargs):
        """
        Populates an entry from the bundle cache.
        This method will be invoked for every bundle for which :meth:`can_cache_bundle`
        returned ``True``. The hook is responsible for writing the bundle inside
        the destination folder. If an exception is raised by this method, the files
        will be deleted from disk and the bundle cache will be left intact.
        Be careful to properly copy all the files or the cache for this bundle
        will be left in an inconsistent state.
        The default implementation does nothing.
        :param str destination: Folder where the bundle needs to be written. Note
            that this is not the final destination folder inside the bundle cache.
        :param descriptor: Descriptor of the bundle that needs to be cached.
        """
        pass