mirror of
				https://git.sr.ht/~tsileo/microblog.pub
				synced 2025-06-05 21:59:23 +02:00 
			
		
		
		
	HTML error page
This commit is contained in:
		
							
								
								
									
										34
									
								
								app/main.py
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								app/main.py
									
									
									
									
									
								
							| @@ -21,6 +21,7 @@ from fastapi import FastAPI | |||||||
| from fastapi import Form | from fastapi import Form | ||||||
| from fastapi import Request | from fastapi import Request | ||||||
| from fastapi import Response | from fastapi import Response | ||||||
|  | from fastapi.exception_handlers import http_exception_handler | ||||||
| from fastapi.exceptions import HTTPException | from fastapi.exceptions import HTTPException | ||||||
| from fastapi.responses import FileResponse | from fastapi.responses import FileResponse | ||||||
| from fastapi.responses import PlainTextResponse | from fastapi.responses import PlainTextResponse | ||||||
| @@ -36,6 +37,7 @@ from sqlalchemy.orm import joinedload | |||||||
| from starlette.background import BackgroundTask | from starlette.background import BackgroundTask | ||||||
| from starlette.datastructures import Headers | from starlette.datastructures import Headers | ||||||
| from starlette.datastructures import MutableHeaders | from starlette.datastructures import MutableHeaders | ||||||
|  | from starlette.exceptions import HTTPException as StarletteHTTPException | ||||||
| from starlette.responses import JSONResponse | from starlette.responses import JSONResponse | ||||||
| from starlette.types import Message | from starlette.types import Message | ||||||
| from uvicorn.middleware.proxy_headers import ProxyHeadersMiddleware  # type: ignore | from uvicorn.middleware.proxy_headers import ProxyHeadersMiddleware  # type: ignore | ||||||
| @@ -62,6 +64,7 @@ from app.config import USERNAME | |||||||
| from app.config import is_activitypub_requested | from app.config import is_activitypub_requested | ||||||
| from app.config import verify_csrf_token | from app.config import verify_csrf_token | ||||||
| from app.database import AsyncSession | from app.database import AsyncSession | ||||||
|  | from app.database import async_session | ||||||
| from app.database import get_db_session | from app.database import get_db_session | ||||||
| from app.incoming_activities import new_ap_incoming_activity | from app.incoming_activities import new_ap_incoming_activity | ||||||
| from app.templates import is_current_user_admin | from app.templates import is_current_user_admin | ||||||
| @@ -202,6 +205,37 @@ logger_format = ( | |||||||
| logger.add(sys.stdout, format=logger_format, level="DEBUG" if DEBUG else "INFO") | logger.add(sys.stdout, format=logger_format, level="DEBUG" if DEBUG else "INFO") | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @app.exception_handler(StarletteHTTPException) | ||||||
|  | async def custom_http_exception_handler( | ||||||
|  |     request: Request, | ||||||
|  |     exc: StarletteHTTPException, | ||||||
|  | ) -> templates.TemplateResponse | JSONResponse: | ||||||
|  |     accept_value = request.headers.get("accept") | ||||||
|  |     if ( | ||||||
|  |         accept_value | ||||||
|  |         and accept_value.startswith("text/html") | ||||||
|  |         and 400 <= exc.status_code < 600 | ||||||
|  |     ): | ||||||
|  |         async with async_session() as db_session: | ||||||
|  |             title = ( | ||||||
|  |                 { | ||||||
|  |                     404: "Oops, nothing to see here", | ||||||
|  |                     500: "Opps, somethine went wrong", | ||||||
|  |                 } | ||||||
|  |             ).get(exc.status_code, exc.detail) | ||||||
|  |             try: | ||||||
|  |                 return await templates.render_template( | ||||||
|  |                     db_session, | ||||||
|  |                     request, | ||||||
|  |                     "error.html", | ||||||
|  |                     {"title": title}, | ||||||
|  |                     status_code=exc.status_code, | ||||||
|  |                 ) | ||||||
|  |             finally: | ||||||
|  |                 await db_session.close() | ||||||
|  |     return await http_exception_handler(request, exc) | ||||||
|  |  | ||||||
|  |  | ||||||
| class ActivityPubResponse(JSONResponse): | class ActivityPubResponse(JSONResponse): | ||||||
|     media_type = "application/activity+json" |     media_type = "application/activity+json" | ||||||
|  |  | ||||||
|   | |||||||
| @@ -196,6 +196,17 @@ main { | |||||||
|     max-width: 1000px; |     max-width: 1000px; | ||||||
|     margin: 30px auto; |     margin: 30px auto; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .centered { | ||||||
|  |   display: flex; | ||||||
|  |   justify-content: center; | ||||||
|  |   align-items: center; | ||||||
|  |   position: absolute; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  |   top: 0; | ||||||
|  | } | ||||||
|  |  | ||||||
| footer { | footer { | ||||||
|   width: 100%; |   width: 100%; | ||||||
|   max-width: 1000px; |   max-width: 1000px; | ||||||
|   | |||||||
| @@ -1,8 +1,7 @@ | |||||||
| {%- import "utils.html" as utils with context -%} | {%- import "utils.html" as utils with context -%} | ||||||
| {% extends "layout.html" %} | {% extends "layout.html" %} | ||||||
| {% block content %} | {% block content %} | ||||||
| <div style="display:grid;height:80%;"> | <div class="centered"> | ||||||
| <div style="margin:auto;"> |  | ||||||
| {% if error %} | {% if error %} | ||||||
| <p class="primary-color">Invalid password.</p> | <p class="primary-color">Invalid password.</p> | ||||||
| {% endif %} | {% endif %} | ||||||
| @@ -13,5 +12,4 @@ | |||||||
| <input type="submit" value="login"> | <input type="submit" value="login"> | ||||||
| </form> | </form> | ||||||
| </div> | </div> | ||||||
| </div> |  | ||||||
| {% endblock %} | {% endblock %} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user