Source code for wsgidav.mw.base_mw

# -*- coding: utf-8 -*-
"""
Abstract base middleware class (optional use).
"""
from abc import ABC, abstractmethod

from wsgidav.util import NO_DEFAULT, get_dict_value

__docformat__ = "reStructuredText"


[docs] class BaseMiddleware(ABC): """Abstract base middleware class (optional). Note: this is a convenience class, that *may* be used to implement WsgiDAV middlewares. However it is not a reqiuement: any object that implements the WSGI specification can be added to the stack. Derived classes in WsgiDAV include:: wsgidav.dir_browser.WsgiDavDirBrowser wsgidav.mw.debug_filter.WsgiDavDebugFilter wsgidav.error_printer.ErrorPrinter wsgidav.http_authenticator.HTTPAuthenticator wsgidav.request_resolver.RequestResolver """ def __init__(self, wsgidav_app, next_app, config): self.wsgidav_app = wsgidav_app self.next_app = next_app self.config = config self.verbose = config.get("verbose", 3)
[docs] @abstractmethod def __call__(self, environ, start_response): raise NotImplementedError
def __repr__(self): return "{}.{}".format(self.__module__, self.__class__.__name__)
[docs] def is_disabled(self): """Optionally return True to skip this module on startup.""" return False
[docs] def get_config(self, key_path: str, default=NO_DEFAULT): """Optionally return True to skip this module on startup.""" res = get_dict_value(self.config, key_path, default) return res