Warning

This document is for an in-development version of Galaxy. You can alternatively view this page in the latest release if it exists or view the top of the latest release's documentation.

Source code for galaxy.files.sources.webdav

try:
    from webdavfs.webdavfs import WebDAVFS
except ImportError:
    WebDAVFS = None

import tempfile
from typing import (
    cast,
    Optional,
    Union,
)

from typing_extensions import NotRequired

from . import (
    FilesSourceOptions,
    FilesSourceProperties,
)
from ._pyfilesystem2 import PyFilesystem2FilesSource


class WebDavFilesSourceProperties(FilesSourceProperties, total=False):
    use_temp_files: NotRequired[Optional[bool]]
    temp_path: NotRequired[Optional[str]]


[docs]class WebDavFilesSource(PyFilesystem2FilesSource): plugin_type = "webdav" required_module = WebDAVFS required_package = "fs.webdavfs" allow_key_error_on_empty_directories = True def _open_fs(self, user_context=None, opts: Optional[FilesSourceOptions] = None): props = cast(WebDavFilesSourceProperties, self._serialization_props(user_context)) file_sources_config = self._file_sources_config use_temp_files = props.pop("use_temp_files", None) if use_temp_files is None and file_sources_config and file_sources_config.webdav_use_temp_files is not None: use_temp_files = file_sources_config.webdav_use_temp_files if use_temp_files is None: # Default to True to avoid memory issues with large files. use_temp_files = True if use_temp_files: temp_path = props.get("temp_path") if temp_path is None and file_sources_config and file_sources_config.tmp_dir: temp_path = file_sources_config.tmp_dir if temp_path is None: temp_path = tempfile.mkdtemp(prefix="webdav_") props["temp_path"] = temp_path props["use_temp_files"] = use_temp_files extra_props: Union[FilesSourceProperties, dict] = opts.extra_props or {} if opts else {} handle = WebDAVFS(**{**props, **extra_props}) return handle
__all__ = ("WebDavFilesSource",)