Add fragment blueprint + sync shared: micro-frontend infrastructure
All checks were successful
Build and Deploy / build-and-deploy (push) Successful in 45s
All checks were successful
Build and Deploy / build-and-deploy (push) Successful in 45s
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
3
app.py
3
app.py
@@ -8,7 +8,7 @@ from jinja2 import FileSystemLoader, ChoiceLoader
|
|||||||
from shared.infrastructure.factory import create_base_app
|
from shared.infrastructure.factory import create_base_app
|
||||||
from shared.services.registry import services
|
from shared.services.registry import services
|
||||||
|
|
||||||
from bp import register_account_bp, register_auth_bp
|
from bp import register_account_bp, register_auth_bp, register_fragments
|
||||||
|
|
||||||
|
|
||||||
async def account_context() -> dict:
|
async def account_context() -> dict:
|
||||||
@@ -51,6 +51,7 @@ def create_app() -> "Quart":
|
|||||||
# --- blueprints ---
|
# --- blueprints ---
|
||||||
app.register_blueprint(register_auth_bp())
|
app.register_blueprint(register_auth_bp())
|
||||||
app.register_blueprint(register_account_bp())
|
app.register_blueprint(register_account_bp())
|
||||||
|
app.register_blueprint(register_fragments())
|
||||||
|
|
||||||
return app
|
return app
|
||||||
|
|
||||||
|
|||||||
@@ -1,2 +1,3 @@
|
|||||||
from .account.routes import register as register_account_bp
|
from .account.routes import register as register_account_bp
|
||||||
from .auth.routes import register as register_auth_bp
|
from .auth.routes import register as register_auth_bp
|
||||||
|
from .fragments import register_fragments
|
||||||
|
|||||||
1
bp/fragments/__init__.py
Normal file
1
bp/fragments/__init__.py
Normal file
@@ -0,0 +1 @@
|
|||||||
|
from .routes import register as register_fragments
|
||||||
BIN
bp/fragments/__pycache__/routes.cpython-312.pyc
Normal file
BIN
bp/fragments/__pycache__/routes.cpython-312.pyc
Normal file
Binary file not shown.
34
bp/fragments/routes.py
Normal file
34
bp/fragments/routes.py
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
"""Account app fragment endpoints.
|
||||||
|
|
||||||
|
Exposes HTML fragments at ``/internal/fragments/<type>`` for consumption
|
||||||
|
by other coop apps via the fragment client.
|
||||||
|
"""
|
||||||
|
|
||||||
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from quart import Blueprint, Response, request
|
||||||
|
|
||||||
|
from shared.infrastructure.fragments import FRAGMENT_HEADER
|
||||||
|
|
||||||
|
|
||||||
|
def register():
|
||||||
|
bp = Blueprint("fragments", __name__, url_prefix="/internal/fragments")
|
||||||
|
|
||||||
|
_handlers: dict[str, object] = {}
|
||||||
|
|
||||||
|
@bp.before_request
|
||||||
|
async def _require_fragment_header():
|
||||||
|
if not request.headers.get(FRAGMENT_HEADER):
|
||||||
|
return Response("", status=403)
|
||||||
|
|
||||||
|
@bp.get("/<fragment_type>")
|
||||||
|
async def get_fragment(fragment_type: str):
|
||||||
|
handler = _handlers.get(fragment_type)
|
||||||
|
if handler is None:
|
||||||
|
return Response("", status=200, content_type="text/html")
|
||||||
|
html = await handler()
|
||||||
|
return Response(html, status=200, content_type="text/html")
|
||||||
|
|
||||||
|
bp._fragment_handlers = _handlers
|
||||||
|
|
||||||
|
return bp
|
||||||
2
shared
2
shared
Submodule shared updated: e7d180912b...b882770828
Reference in New Issue
Block a user