Add fragment blueprint + sync shared: micro-frontend infrastructure
All checks were successful
Build and Deploy / build-and-deploy (push) Successful in 1m56s
All checks were successful
Build and Deploy / build-and-deploy (push) Successful in 1m56s
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
2
app.py
2
app.py
@@ -15,6 +15,7 @@ from bp import (
|
|||||||
register_admin,
|
register_admin,
|
||||||
register_menu_items,
|
register_menu_items,
|
||||||
register_snippets,
|
register_snippets,
|
||||||
|
register_fragments,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@@ -73,6 +74,7 @@ def create_app() -> "Quart":
|
|||||||
app.register_blueprint(register_admin("/settings"))
|
app.register_blueprint(register_admin("/settings"))
|
||||||
app.register_blueprint(register_menu_items())
|
app.register_blueprint(register_menu_items())
|
||||||
app.register_blueprint(register_snippets())
|
app.register_blueprint(register_snippets())
|
||||||
|
app.register_blueprint(register_fragments())
|
||||||
|
|
||||||
# --- KV admin endpoints ---
|
# --- KV admin endpoints ---
|
||||||
@app.get("/settings/kv/<key>")
|
@app.get("/settings/kv/<key>")
|
||||||
|
|||||||
@@ -2,3 +2,4 @@ from .blog.routes import register as register_blog_bp
|
|||||||
from .admin.routes import register as register_admin
|
from .admin.routes import register as register_admin
|
||||||
from .menu_items.routes import register as register_menu_items
|
from .menu_items.routes import register as register_menu_items
|
||||||
from .snippets.routes import register as register_snippets
|
from .snippets.routes import register as register_snippets
|
||||||
|
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
|
||||||
36
bp/fragments/routes.py
Normal file
36
bp/fragments/routes.py
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
"""Blog 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")
|
||||||
|
|
||||||
|
# Registry of fragment handlers: type -> async callable returning HTML str
|
||||||
|
_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")
|
||||||
|
|
||||||
|
# Store handlers dict on blueprint so app code can register handlers
|
||||||
|
bp._fragment_handlers = _handlers
|
||||||
|
|
||||||
|
return bp
|
||||||
2
shared
2
shared
Submodule shared updated: e7d180912b...b882770828
Reference in New Issue
Block a user