# Change: Add iCal Subscription Export ## Why Users want to subscribe to their La Suite Calendars calendars from external applications (Apple Calendar, Google Calendar, Thunderbird, Outlook, etc.) using standard iCal URLs. Currently, external access is not supported due to the API-key authentication model, preventing users from accessing their calendars outside the web application. ## What Changes - Add a standalone `CalendarSubscriptionToken` Django model that stores: - Owner (user) reference - CalDAV path directly (no FK to Calendar model) - Calendar display name - Token UUID and metadata - Create a public Django endpoint `/ical/.ics` that: - Validates the token (no user authentication required) - Proxies the request to SabreDAV using the stored caldav_path and owner email - Returns the ICS generated by SabreDAV's `ICSExportPlugin` - Enable SabreDAV's `ICSExportPlugin` in `server.php` - Add standalone Django REST API endpoint `/api/v1.0/subscription-tokens/`: - POST to create token with `{ caldav_path, calendar_name }` - GET/DELETE by-path to manage existing tokens - Permission verification via caldav_path (user's email must be in path) - Add UI in the calendar context menu to obtain and copy the subscription URL - Frontend extracts CalDAV path from calendar URL - Modal auto-creates token on open ## Architecture Approach **URL format:** `https://calendars.example.com/ical/.ics` **Key design decision:** The token model is **standalone** and stores the CalDAV path directly, avoiding the need to synchronize CalDAV calendars with Django. This follows the same pattern as Google Calendar and Outlook: - Short, clean URL - Token in URL path acts as authentication (no username/password) - Reuses SabreDAV's ICSExportPlugin for RFC 5545 compliant ICS generation See `design.md` for detailed technical flow. ## Impact - **Affected specs**: New capability `ical-subscription-export` - **Affected code**: - `docker/sabredav/server.php` - Add ICSExportPlugin - `src/backend/core/models.py` - New CalendarSubscriptionToken model (standalone) - `src/backend/core/api/viewsets.py` - New SubscriptionTokenViewSet - `src/backend/core/api/viewsets_ical.py` - New ICalExportView - `src/frontend/apps/calendars/` - UI for subscription URL with caldavPath - **Security**: Tokens are random UUIDs; URLs should be treated as secrets - **Database**: New Django table for subscription tokens - **No breaking changes** to existing functionality ## Out of Scope (Future Work) - Subscribing TO external calendars from within La Suite Calendars (import) - CalDAV access with HTTP Basic authentication - Public (unauthenticated) calendar sharing without token