coolify/resources/views
Andras Bacsai 90ddbb3572 feat(security): support expiration on API tokens with warning notifications
Add optional expiration to personal API tokens. Users pick a duration
(1/7/30/60/90 days or Never) at creation time. Expired tokens are
rejected by Sanctum, pruned hourly by sanctum:prune-expired, and a
team notification fires ~24h before expiry so owners can rotate
before API calls start failing.

- ApiTokens Livewire component stores expires_at from expiresInDays
- Rework issued-tokens UI from card grid to table (matches other views)
- New ApiTokenExpirationWarningJob scheduled hourly (idempotent via RateLimiter)
- New ApiTokenExpiringNotification (email/discord/telegram/slack/pushover)
- api_token_expiring added to alwaysSendEvents so users cannot silence
  expiry warnings from the per-event notification toggle UI
- sanctum:prune-expired cadence moved from daily to hourly

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-04-20 14:28:38 +02:00
..
auth test: add Pest browser testing with SQLite :memory: schema 2026-02-11 15:25:47 +01:00
components chore(swarm): mark docker swarm as deprecated 2026-04-17 23:41:39 +02:00
emails feat(security): support expiration on API tokens with warning notifications 2026-04-20 14:28:38 +02:00
errors chore: prepare for PR 2026-03-03 12:37:06 +01:00
invitation refactor: split invitation endpoint into GET (show) and POST (accept) 2026-03-26 14:30:27 +01:00
layouts fix(forms): use Alpine state for password visibility toggles 2026-03-29 20:47:36 +02:00
livewire feat(security): support expiration on API tokens with warning notifications 2026-04-20 14:28:38 +02:00
server
source Add toggleable wire:navigate SPA navigation with prefetching 2025-12-17 12:09:13 +01:00
vendor/mail Update version numbers and fix UI styling 2024-03-25 16:42:41 +01:00