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 (
    Annotated,
    Optional,
    Union,
)

from pydantic import (
    Field,
    field_validator,
)

from galaxy.files.models import (
    BaseFileSourceConfiguration,
    BaseFileSourceTemplateConfiguration,
    FilesSourceRuntimeContext,
)
from galaxy.util.config_templates import TemplateExpansion
from ._pyfilesystem2 import PyFilesystem2FilesSource


class WebDavFileSourceTemplateConfiguration(BaseFileSourceTemplateConfiguration):
    url: Union[str, TemplateExpansion, None] = None
    root: Optional[Union[str, TemplateExpansion]] = None
    login: Optional[Union[str, TemplateExpansion]] = None
    password: Optional[Union[str, TemplateExpansion]] = None
    temp_path: Optional[Union[str, TemplateExpansion]] = None
    use_temp_files: Union[bool, TemplateExpansion] = True


class WebDavFileSourceConfiguration(BaseFileSourceConfiguration):
    # Override url field to make it required for WebDAV - we keep a default but validate it's provided
    url: Annotated[
        str,
        Field(
            None,
            title="WebDAV URL",
            description="The URL of the WebDAV server. This is required for WebDAV file sources.",
        ),
    ] = None  # type: ignore[assignment]
    root: Optional[str] = None
    login: Optional[str] = None
    password: Optional[str] = None
    temp_path: Optional[str] = None
    use_temp_files: bool = True  # Default to True to avoid memory issues with large files.

    @field_validator("url")
    @classmethod
    def validate_url_required(cls, v):
        if v is None or v == "":
            raise ValueError("url is required for WebDAV file source")
        return v


[docs] class WebDavFilesSource(PyFilesystem2FilesSource[WebDavFileSourceTemplateConfiguration, WebDavFileSourceConfiguration]): plugin_type = "webdav" required_module = WebDAVFS required_package = "fs.webdavfs" allow_key_error_on_empty_directories = True template_config_class = WebDavFileSourceTemplateConfiguration resolved_config_class = WebDavFileSourceConfiguration def _open_fs(self, context: FilesSourceRuntimeContext[WebDavFileSourceConfiguration]): if WebDAVFS is None: raise self.required_package_exception config = context.config file_sources_config = self._file_sources_config use_temp_files = config.use_temp_files if 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: temp_path = config.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_") config.temp_path = temp_path config.use_temp_files = use_temp_files handle = WebDAVFS( url=config.url, root=config.root, login=config.login, password=config.password, temp_path=config.temp_path, use_temp_files=config.use_temp_files, ) return handle
__all__ = ("WebDavFilesSource",)