Full notification infrastructure with in-app, email, Slack, and Teams channels: Backend: - NotificationConfig, NotificationLog, Notification models + migration - Notification service with event routing, channel delivery, retry logic - 9 API endpoints (config CRUD + in-app notifications) - APScheduler retry job with exponential backoff (30s, 2m, 10m) - Wired into escalation, proposal approval, and knowledge flywheel - Pydantic event key validation, cross-tenant protection on recipients Frontend: - TypeScript types + API client for all notification endpoints - NotificationsPanel: bell icon with unread badge, dropdown, mark-read - NotificationSettings: channel config, event toggles, test, delete confirm - Notifications tab on IntegrationsPage - ARIA attributes, Escape handler, settings link on panel Review fixes (13 issues resolved): - notify() no longer commits/rolls back caller's transaction (critical) - retry_failed_notifications returns count instead of None (critical) - NotificationSettings moved inside dedicated tab (critical) - target_user_ids scoped by account_id (security) - Email loop collects all failures before raising - Slack webhook validates response body - events_enabled rejects unknown event keys - link column widened to String(500) - Dead code removed from _auto_reinforce - Delete confirmation, ARIA, Escape key support Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
78 lines
3.5 KiB
Python
78 lines
3.5 KiB
Python
from fastapi import APIRouter
|
|
from app.api.endpoints import auth, trees, sessions, sidebar, invite, categories, tags, folders, step_categories, steps, admin, accounts, webhooks, shares, shared, tree_markdown
|
|
from app.api.endpoints import admin_dashboard, admin_audit, admin_plan_limits, admin_feature_flags, admin_settings, admin_categories
|
|
from app.api.endpoints import ratings, analytics
|
|
from app.api.endpoints import target_lists
|
|
from app.api.endpoints import maintenance_schedules
|
|
from app.api.endpoints import feedback
|
|
from app.api.endpoints import ai_builder
|
|
from app.api.endpoints import ai_fix
|
|
from app.api.endpoints import ai_chat
|
|
from app.api.endpoints import copilot
|
|
from app.api.endpoints import assistant_chat
|
|
from app.api.endpoints import survey
|
|
from app.api.endpoints import admin_survey
|
|
from app.api.endpoints import tree_transfer
|
|
from app.api.endpoints import ai_suggestions
|
|
from app.api.endpoints import kb_accelerator
|
|
from app.api.endpoints import beta_signup
|
|
from app.api.endpoints import scripts
|
|
from app.api.endpoints import integrations
|
|
from app.api.endpoints import onboarding
|
|
from app.api.endpoints import branding
|
|
from app.api.endpoints import supporting_data
|
|
from app.api.endpoints import ai_sessions
|
|
from app.api.endpoints import flow_proposals
|
|
from app.api.endpoints import flowpilot_analytics
|
|
from app.api.endpoints import notifications
|
|
|
|
api_router = APIRouter()
|
|
|
|
api_router.include_router(auth.router)
|
|
api_router.include_router(trees.router)
|
|
api_router.include_router(sidebar.router)
|
|
api_router.include_router(sessions.router)
|
|
api_router.include_router(invite.router)
|
|
api_router.include_router(categories.router)
|
|
api_router.include_router(tags.router)
|
|
api_router.include_router(folders.router)
|
|
api_router.include_router(step_categories.router)
|
|
api_router.include_router(steps.router)
|
|
api_router.include_router(admin.router)
|
|
api_router.include_router(admin_dashboard.router)
|
|
api_router.include_router(admin_audit.router)
|
|
api_router.include_router(admin_plan_limits.router)
|
|
api_router.include_router(admin_feature_flags.router)
|
|
api_router.include_router(admin_settings.router)
|
|
api_router.include_router(admin_categories.router)
|
|
api_router.include_router(accounts.router)
|
|
api_router.include_router(webhooks.router)
|
|
api_router.include_router(shares.router)
|
|
api_router.include_router(shared.router) # Public endpoints (no auth)
|
|
api_router.include_router(tree_markdown.router)
|
|
api_router.include_router(ratings.router)
|
|
api_router.include_router(analytics.router)
|
|
api_router.include_router(target_lists.router)
|
|
api_router.include_router(maintenance_schedules.router)
|
|
api_router.include_router(feedback.router)
|
|
api_router.include_router(ai_builder.router)
|
|
api_router.include_router(ai_fix.router)
|
|
api_router.include_router(ai_chat.router)
|
|
api_router.include_router(copilot.router)
|
|
api_router.include_router(assistant_chat.router)
|
|
api_router.include_router(survey.router)
|
|
api_router.include_router(admin_survey.router)
|
|
api_router.include_router(tree_transfer.router)
|
|
api_router.include_router(ai_suggestions.router)
|
|
api_router.include_router(kb_accelerator.router)
|
|
api_router.include_router(beta_signup.router)
|
|
api_router.include_router(scripts.router)
|
|
api_router.include_router(integrations.router)
|
|
api_router.include_router(onboarding.router)
|
|
api_router.include_router(branding.router)
|
|
api_router.include_router(supporting_data.router)
|
|
api_router.include_router(ai_sessions.router)
|
|
api_router.include_router(flow_proposals.router)
|
|
api_router.include_router(flowpilot_analytics.router)
|
|
api_router.include_router(notifications.router)
|