Sindbad~EG File Manager
�
'ٜg*
� �l � d Z ddlmZ ddlZej
rddlmZ ddlmZ ddlm Z G d� d� Z
y) aY
Application Dispatcher
======================
This middleware creates a single WSGI application that dispatches to
multiple other WSGI applications mounted at different URL paths.
A common example is writing a Single Page Application, where you have a
backend API and a frontend written in JavaScript that does the routing
in the browser rather than requesting different pages from the server.
The frontend is a single HTML and JS file that should be served for any
path besides "/api".
This example dispatches to an API app under "/api", an admin app
under "/admin", and an app that serves frontend files for all other
requests::
app = DispatcherMiddleware(serve_frontend, {
'/api': api_app,
'/admin': admin_app,
})
In production, you might instead handle this at the HTTP server level,
serving files or proxying to application servers based on location. The
API and admin apps would each be deployed with a separate WSGI server,
and the static files would be served directly by the HTTP server.
.. autoclass:: DispatcherMiddleware
:copyright: 2007 Pallets
:license: BSD-3-Clause
� )�annotationsN)�
StartResponse)�WSGIApplication)�WSGIEnvironmentc �: � e Zd ZdZ d dd�Z dd�Zy)�DispatcherMiddlewareaJ Combine multiple applications as a single WSGI application.
Requests are dispatched to an application based on the path it is
mounted under.
:param app: The WSGI application to dispatch to if the request
doesn't match a mounted path.
:param mounts: Maps path prefixes to applications for dispatching.
Nc �( � || _ |xs i | _ y �N)�app�mounts)�selfr r s �I/usr/local/lib/python3.12/site-packages/werkzeug/middleware/dispatcher.py�__init__zDispatcherMiddleware.__init__6 s � �
����l���� c �L � |j dd� }d}d|v r?|| j v r| j | }nG|j dd� \ }}d|� |� �}d|v r�?| j j || j � }|j dd� }||z |d<