Skip to content

Document Processing#

ragbits.document_search.ingestion.document_processor.DocumentProcessorRouter #

DocumentProcessorRouter(providers: dict[DocumentType, Callable[[], BaseProvider] | BaseProvider])

The DocumentProcessorRouter is responsible for routing the document to the correct provider based on the document metadata such as the document type.

Source code in packages/ragbits-document-search/src/ragbits/document_search/ingestion/document_processor.py
def __init__(self, providers: dict[DocumentType, Callable[[], BaseProvider] | BaseProvider]):
    self._providers = providers

from_dict_to_providers_config staticmethod #

from_dict_to_providers_config(dict_config: dict[str, ObjectContructionConfig]) -> ProvidersConfig

Creates ProvidersConfig from dictionary that maps document types to the provider configuration.

PARAMETER DESCRIPTION
dict_config

The dictionary with configuration.

TYPE: dict[str, ObjectContructionConfig]

RETURNS DESCRIPTION
ProvidersConfig

ProvidersConfig object.

RAISES DESCRIPTION
InvalidConfigError

If a provider class can't be found or is not the correct type.

Source code in packages/ragbits-document-search/src/ragbits/document_search/ingestion/document_processor.py
@staticmethod
def from_dict_to_providers_config(dict_config: dict[str, ObjectContructionConfig]) -> ProvidersConfig:
    """
    Creates ProvidersConfig from dictionary that maps document types to the provider configuration.

    Args:
        dict_config: The dictionary with configuration.

    Returns:
        ProvidersConfig object.

    Raises:
        InvalidConfigError: If a provider class can't be found or is not the correct type.
    """
    providers_config = {}

    for document_type, config in dict_config.items():
        providers_config[DocumentType(document_type)] = cast(
            Callable[[], BaseProvider] | BaseProvider,
            BaseProvider.subclass_from_config(config),
        )

    return providers_config

from_config classmethod #

from_config(providers_config: ProvidersConfig | None = None) -> DocumentProcessorRouter

Create a DocumentProcessorRouter from a configuration. If the configuration is not provided, the default configuration will be used. If the configuration is provided, it will be merged with the default configuration, overriding the default values for the document types that are defined in the configuration. Example of the configuration: { DocumentType.TXT: YourCustomProviderClass(), DocumentType.PDF: UnstructuredProvider(), }

PARAMETER DESCRIPTION
providers_config

The dictionary with the providers configuration, mapping the document types to the provider class.

TYPE: ProvidersConfig | None DEFAULT: None

RETURNS DESCRIPTION
DocumentProcessorRouter

The DocumentProcessorRouter.

Source code in packages/ragbits-document-search/src/ragbits/document_search/ingestion/document_processor.py
@classmethod
def from_config(cls, providers_config: ProvidersConfig | None = None) -> "DocumentProcessorRouter":
    """
    Create a DocumentProcessorRouter from a configuration. If the configuration is not provided, the default
    configuration will be used. If the configuration is provided, it will be merged with the default configuration,
    overriding the default values for the document types that are defined in the configuration.
    Example of the configuration:
    {
        DocumentType.TXT: YourCustomProviderClass(),
        DocumentType.PDF: UnstructuredProvider(),
    }

    Args:
        providers_config: The dictionary with the providers configuration, mapping the document types to the
            provider class.

    Returns:
        The DocumentProcessorRouter.
    """
    config = copy.deepcopy(DEFAULT_PROVIDERS_CONFIG)
    config.update(providers_config if providers_config is not None else {})

    return cls(providers=config)

get_provider #

get_provider(document_meta: DocumentMeta) -> BaseProvider

Get the provider for the document.

PARAMETER DESCRIPTION
document_meta

The document metadata.

TYPE: DocumentMeta

RETURNS DESCRIPTION
BaseProvider

The provider for processing the document.

RAISES DESCRIPTION
ValueError

If no provider is found for the document type.

Source code in packages/ragbits-document-search/src/ragbits/document_search/ingestion/document_processor.py
def get_provider(self, document_meta: DocumentMeta) -> BaseProvider:
    """
    Get the provider for the document.

    Args:
        document_meta: The document metadata.

    Returns:
        The provider for processing the document.

    Raises:
        ValueError: If no provider is found for the document type.
    """
    provider_class_or_provider = self._providers.get(document_meta.document_type)
    if provider_class_or_provider is None:
        raise ValueError(f"No provider found for the document type {document_meta.document_type}")
    elif isinstance(provider_class_or_provider, BaseProvider):
        provider = provider_class_or_provider
    else:
        provider = provider_class_or_provider()
    return provider