Source code for fsi.path

from __future__ import annotations

from datetime import datetime
from uuid import UUID

from onegov.fsi import FsiApp
from onegov.fsi.collections.attendee import CourseAttendeeCollection
from onegov.fsi.collections.audit import AuditCollection
from onegov.fsi.collections.course import CourseCollection
from onegov.fsi.collections.course_event import (
    CourseEventCollection, PastCourseEventCollection)
from onegov.fsi.collections.notification_template import (
    CourseNotificationTemplateCollection)
from onegov.fsi.collections.subscription import SubscriptionsCollection
from onegov.fsi.models.course import Course
from onegov.fsi.models.course_attendee import CourseAttendee
from onegov.fsi.models.course_event import CourseEvent
from onegov.fsi.models.course_notification_template import (
    CourseNotificationTemplate)
from onegov.fsi.models.course_subscription import CourseSubscription


from typing import TYPE_CHECKING
if TYPE_CHECKING:
    from onegov.fsi.request import FsiRequest


@FsiApp.path(model=Course, path='/fsi/course/{id}', converters={'id': UUID})
[docs] def get_course_details(request: FsiRequest, id: UUID) -> Course | None: return CourseCollection(request.session).by_id(id)
@FsiApp.path( model=CourseEvent, path='/fsi/event/{id}', converters={'id': UUID} )
[docs] def get_course_event_details( request: FsiRequest, id: UUID ) -> CourseEvent | None: return CourseEventCollection( request.session, show_hidden=request.is_manager, show_locked=True ).by_id(id)
@FsiApp.path( model=PastCourseEventCollection, path='/fsi/past-events', converters={ 'course_id': UUID, 'page': int, 'show_hidden': bool } )
[docs] def get_past_events_view( request: FsiRequest, page: int = 0, show_hidden: bool = False, course_id: UUID | None = None, ) -> PastCourseEventCollection: if not request.is_manager and show_hidden: show_hidden = False return PastCourseEventCollection( request.session, page=page, show_hidden=show_hidden, course_id=course_id, show_locked=True )
@FsiApp.path( model=CourseEventCollection, path='/fsi/events', converters={ 'page': int, 'from_date': datetime, 'upcoming_only': bool, 'past_only': bool, 'course_id': UUID, 'limit': int, 'show_hidden': bool, 'sort_desc': bool } )
[docs] def get_events_view( request: FsiRequest, page: int = 0, from_date: datetime | None = None, upcoming_only: bool = False, past_only: bool = False, limit: int | None = None, show_hidden: bool = True, course_id: UUID | None = None, sort_desc: bool = False ) -> CourseEventCollection: if not request.is_manager and show_hidden: show_hidden = False return CourseEventCollection( request.session, page=page, from_date=from_date, upcoming_only=upcoming_only, past_only=past_only, limit=limit, show_hidden=show_hidden, course_id=course_id, sort_desc=sort_desc, show_locked=True )
@FsiApp.path( model=CourseCollection, path='/fsi/courses', converters={'show_hidden_from_public': bool} )
[docs] def get_courses( request: FsiRequest, show_hidden_from_public: bool ) -> CourseCollection: if not request.is_admin: show_hidden_from_public = False return CourseCollection( request.session, auth_attendee=request.attendee, show_hidden_from_public=show_hidden_from_public )
@FsiApp.path( model=CourseAttendeeCollection, path='/fsi/attendees', converters={ 'page': int, 'exclude_external': bool, 'external_only': bool, 'editors_only': bool, 'admins_ony': bool, } )
[docs] def get_attendees( request: FsiRequest, page: int = 0, exclude_external: bool = False, external_only: bool = False, editors_only: bool = False, admins_only: bool = False ) -> CourseAttendeeCollection: """This collection has permission private, so no members can see it""" return CourseAttendeeCollection( request.session, page, exclude_external=exclude_external, external_only=external_only, auth_attendee=request.attendee, editors_only=editors_only, admins_only=admins_only )
@FsiApp.path( model=CourseAttendee, path='/fsi/attendee/{id}', converters={'id': UUID} )
[docs] def get_attendee_details( request: FsiRequest, id: UUID ) -> CourseAttendee | None: return CourseAttendeeCollection(request.session).by_id(id)
@FsiApp.path( model=CourseNotificationTemplateCollection, path='/fsi/templates', converters={'course_event_id': UUID} )
[docs] def get_notification_templates( request: FsiRequest, course_event_id: UUID | None = None ) -> CourseNotificationTemplateCollection: return CourseNotificationTemplateCollection( request.session, course_event_id=course_event_id)
@FsiApp.path( model=CourseNotificationTemplate, path='/fsi/template/{id}', converters={'id': UUID} )
[docs] def get_template_details( request: FsiRequest, id: UUID ) -> CourseNotificationTemplate | None: return CourseNotificationTemplateCollection(request.session).by_id(id)
@FsiApp.path( model=SubscriptionsCollection, path='/fsi/reservations', converters={ 'attendee_id': UUID, 'course_event_id': UUID, 'external_only': bool, 'page': int } )
[docs] def get_reservations( request: FsiRequest, course_event_id: UUID | None = None, attendee_id: UUID | None = None, external_only: bool = False, page: int = 0 ) -> SubscriptionsCollection: if not attendee_id: if not request.is_manager: # check if someone has permission to see all subscriptions attendee_id = request.attendee_id # can be none....still, so not protected, use permissions elif attendee_id != request.attendee_id and not request.is_manager: attendee_id = request.attendee_id return SubscriptionsCollection( request.session, attendee_id=attendee_id, course_event_id=course_event_id, external_only=external_only, auth_attendee=request.attendee, page=page )
@FsiApp.path( model=CourseSubscription, path='/fsi/reservation/{id}', converters={'id': UUID} )
[docs] def get_reservation_details( request: FsiRequest, id: UUID ) -> CourseSubscription | None: return SubscriptionsCollection(request.session).by_id(id)
@FsiApp.path( model=AuditCollection, path='/fsi/audit', converters={ 'course_id': UUID, 'organisations': [str], 'page': int } )
[docs] def get_audit( request: FsiRequest, course_id: UUID | None, organisations: list[str], page: int = 0, letter: str | None = None ) -> AuditCollection | None: if request.attendee is None: return None return AuditCollection( request.session, course_id, auth_attendee=request.attendee, organisations=organisations, page=page, letter=letter )