Source code for org.views.exceptionviews

from __future__ import annotations

from onegov.core.security import Public
from onegov.org import _, OrgApp
from onegov.org.layout import DefaultLayout
from onegov.user.auth import Auth
from webob.exc import HTTPForbidden, HTTPNotFound


from typing import TYPE_CHECKING
if TYPE_CHECKING:
    from onegov.core.types import RenderData
    from onegov.org.request import OrgRequest
    from webob import Response


@OrgApp.html(model=HTTPForbidden, permission=Public, template='forbidden.pt')
[docs] def handle_forbidden( self: HTTPForbidden, request: OrgRequest, layout: DefaultLayout | None = None ) -> RenderData: """ If a view is forbidden, the request is redirected to the login view. There, the user may login to the site and be redirected back to the originally forbidden view. """ @request.after def set_status_code(response: Response) -> None: response.status_code = self.code # pass along 403 layout = layout or DefaultLayout(self, request) return { 'layout': layout, 'title': _('Access Denied'), 'login_url': request.link( Auth.from_request_path(request), name='login') }
@OrgApp.html(model=HTTPNotFound, permission=Public, template='notfound.pt')
[docs] def handle_notfound( self: HTTPNotFound, request: OrgRequest, layout: DefaultLayout | None = None ) -> RenderData: @request.after def set_status_code(response: Response) -> None: response.status_code = self.code # pass along 404 return { 'layout': layout or DefaultLayout(self, request), 'title': _('Not Found'), }