firefighter-incident 0.0.9__tar.gz → 0.0.11__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/PKG-INFO +1 -1
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/_version.py +2 -2
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/avatar/avatar.py +1 -1
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/card/card.py +1 -1
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/export_button/export_button.py +1 -1
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/form/form.py +2 -2
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/form_field/form_field.py +1 -1
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/messages/messages.py +1 -1
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/modal/modal.py +1 -1
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/forms/select_impact.py +1 -1
- firefighter_incident-0.0.11/firefighter/incidents/migrations/0017_reorder_impact_types.py +28 -0
- firefighter_incident-0.0.11/firefighter/incidents/migrations/0018_update_impactlevel_names.py +48 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/open.py +125 -52
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/opening/select_impact.py +38 -5
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_slack/views/modals/test_open.py +25 -8
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/.gitignore +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/LICENSE +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/README.md +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/admin.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/apps.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/authentication.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/migrations/0001_initial.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/migrations/0002_alter_apitokenproxy_options.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/migrations/0003_alter_apitokenproxy_options.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/models.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/permissions.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/renderer.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/serializers.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/urls.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/_base.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/components.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/environments.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/groups.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/incident_cost_types.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/incident_costs.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/incidents.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/severities.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/avatar/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/avatar/avatar.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/card/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/card/card.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/export_button/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/export_button/export_button.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/form/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/form/form.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/form_field/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/form_field/form_field.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/messages/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/messages/messages.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/modal/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/modal/modal.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/admin.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/apps.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/client.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/management/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/management/commands/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/management/commands/sort_postmortems.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/management/commands/sort_runbooks.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/management/commands/sync_postmortems.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/management/commands/sync_runbooks.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/migrations/0001_initial_oss.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/models.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/serializers.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/service.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/signals/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/signals/incident_updated.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/tables.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/tasks/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/tasks/archive_postmortems.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/tasks/sort_runbooks.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/tasks/sync_pages_content.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/tasks/sync_postmortems.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/tasks/sync_runbooks.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/templates/oncall_team.xml +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/templates/pages/runbook_list.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/urls.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/views/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/views/api.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/views/postmortem/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/views/postmortem/postmortem_detail.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/views/runbook/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/confluence/views/runbook/runbook_list.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/admin.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/apps.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/asgi.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/celery_client.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/fields_forms_widgets.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/filters.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/formats/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/formats/en/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/formats/en/formats.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/http_client.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/management/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/management/commands/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/management/commands/task.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/middleware.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/components/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/components/api.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/components/caches.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/components/celery.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/components/common.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/components/confluence.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/components/jira_app.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/components/logging.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/components/pagerduty.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/components/raid.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/components/slack.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/environments/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/environments/dev.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/environments/prod.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/settings_builder.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/settings/settings_utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/sso.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/tables_utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/templates/admin/base.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/templates/admin/login.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/templates/admin/send_message_conversation.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/templates/robots.txt +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/urls.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/views.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/firefighter/wsgi.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/admin.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/apps.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/enums.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/factories.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/forms/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/forms/close_incident.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/forms/create_incident.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/forms/edit.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/forms/update_key_events.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/forms/update_roles.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/forms/update_status.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/forms/utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/menus.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0001_initial_oss.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0002_alter_severity_name_alter_user_password_featureteam.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0003_delete_featureteam.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0004_incidentupdate_environment.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0005_enable_from_p1_to_p5_priority.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0006_update_group_names.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0007_update_component_name.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0008_impact_level.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0009_update_sla.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0010_update_components.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0011_update_incidents.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0012_alter_impactlevel.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0013_add_missing_component.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0014_update_components_slack_groups.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0015_update_impact_level.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/0016_update_business_incidents_and_level.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/component.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/environment.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/group.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/impact.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/incident.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/incident_cost.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/incident_cost_type.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/incident_membership.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/incident_role_type.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/incident_update.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/metric_type.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/milestone_type.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/priority.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/severity.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/models/user.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/signals.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/css/incident.css +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/css/main.css +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/css/main.min.css +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/css/tailwind.css +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/favicon/android-chrome-192x192.png +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/favicon/android-chrome-512x512.png +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/favicon/apple-touch-icon.png +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/favicon/favicon-16x16.png +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/favicon/favicon-32x32.png +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/favicon/favicon.ico +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/favicon/site.webmanifest +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/gameday.png +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/logo-firefighter.png +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/p1.png +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/p2.png +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/p3.png +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/p4.png +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/img/p5.png +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/js/main.js +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/static/js/main.min.js +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/tables.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/tasks/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/tasks/updateoncall.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/incidents/errors/base.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/incidents/filter.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/incidents/table/priority_column.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/incidents/table/status_column.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/incidents/table.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/incidents/widgets/form_container.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/incidents/widgets/grouped_checkbox_nested.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/incidents/widgets/input_option.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/index.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/created_at_help.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/environment_pill.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/footer.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/header.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/incident_card.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/incident_metrics.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/incident_timeline.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/incident_update_key_events_view.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/incident_update_key_events_view_modal.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/partial_table_list_paginated.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/priority_icon.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/priority_pill.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/status_pill.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/table.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/user_card.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/partials/user_tooltip.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/layouts/view_filters.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/pages/component_detail.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/pages/component_list.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/pages/dashboard.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/pages/docs_metrics.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/pages/incident_create.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/pages/incident_detail.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/pages/incident_list.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/pages/incident_role_types_detail.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/pages/incident_role_types_list.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/pages/incident_statistics.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/pages/incident_statistics_partial.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/pages/incident_update_key_events_form.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/templates/pages/user_detail.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/urls.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/components/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/components/details.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/components/list.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/date_filter.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/date_utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/docs/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/docs/metrics.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/docs/role_types.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/errors.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/reports.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/users/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/users/details.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/incidents/views/views.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/jira_app/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/jira_app/admin.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/jira_app/apps.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/jira_app/client.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/jira_app/migrations/0001_initial_oss.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/jira_app/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/jira_app/models.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/jira_app/tasks/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/jira_app/tasks/sync_users_jira.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/jira_app/types.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/jira_app/utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/logging/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/logging/custom_json_formatter.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/logging/pretty_formatter.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/admin.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/apps.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/client.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/forms/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/forms/create_pagerduty_incident.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/migrations/0001_initial_oss.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/models.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/service.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/signals/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/signals/get_invites_from_pagerduty.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/signals/incident_channel_done_oncall.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/tasks/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/tasks/fetch_oncall.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/tasks/fetch_services.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/tasks/fetch_users.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/tasks/trigger_oncall.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/templates/pages/oncall_list.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/templates/pages/oncall_trigger.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/templates/partials/trigger_oncall_form_view.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/templates/partials/trigger_oncall_form_view_modal.html +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/urls.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/views/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/views/oncall_list.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/pagerduty/views/oncall_trigger.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/admin.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/apps.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/client.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/forms.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/messages.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/migrations/0001_initial_oss.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/migrations/0002_featureteam_remove_qualifierrotation_jira_user_and_more.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/models.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/resources.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/serializers.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/service.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/signals/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/signals/incident_created.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/signals/incident_updated.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/tasks/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/types.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/urls.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/views/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/raid/views/open_normal.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/admin.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/apps.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/factories.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/forms/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/forms/sos_form.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/management/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/management/commands/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/management/commands/generate_manifest.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/messages/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/messages/base.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/messages/slack_messages.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/migrations/0001_initial_oss.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/migrations/0002_usergroup_tag.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/migrations/0003_alter_usergroup_tag.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/migrations/0004_alter_usergroup_components.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/models/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/models/conversation.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/models/incident_channel.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/models/message.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/models/sos.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/models/user.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/models/user_group.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/rules.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/signals/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/signals/create_incident_conversation.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/signals/get_users.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/signals/handle_incident_channel_done.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/signals/incident_closed.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/signals/incident_updated.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/signals/postmortem_created.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/signals/roles_reminders.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/slack_app.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/slack_incident_context.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/slack_templating.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/tasks/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/tasks/fetch_conversations_members.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/tasks/reminder_postmortem.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/tasks/send_message.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/tasks/send_reminders.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/tasks/sync_users.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/tasks/update_usergroups_members.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/tasks/update_users.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/urls.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/actions_and_shortcuts.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/channel_archive.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/channel_id_changed.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/channel_rename.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/channel_shared.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/channel_unarchive.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/channel_unshared.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/commands.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/home.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/member_joined_channel.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/member_left_channel.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/message.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/message_deleted.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/events/reaction_added.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/base_modal/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/base_modal/base.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/base_modal/base_mixins.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/base_modal/form_utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/base_modal/mixins.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/base_modal/modal_utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/close.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/downgrade_workflow.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/edit.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/key_event_message.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/opening/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/opening/check_current_incidents.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/opening/details/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/opening/details/critical.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/opening/set_details.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/opening/types.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/postmortem.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/select.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/send_sos.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/status.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/trigger_oncall.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/update.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/update_roles.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/update_status.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/views.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_fixtures/incidents/components.json +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_fixtures/incidents/environments.json +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_fixtures/incidents/groups.json +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_fixtures/incidents/impact_level.json +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_fixtures/incidents/impact_type.json +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_fixtures/incidents/incident_role_type.json +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_fixtures/incidents/metric_type.json +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_fixtures/incidents/milestone_type.json +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_fixtures/incidents/priorities.json +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_fixtures/incidents/severities.json +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_fixtures/raid/area.json +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/__init__.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/conftest.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_api/test_api_landbot.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_api/test_api_urls.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_confluence/test_confluence_utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_firefighter/test_firefighter_utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_firefighter/test_logging.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_firefighter/test_urls.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_incidents/test_forms/test_form_select_impact.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_incidents/test_forms/test_form_utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_incidents/test_forms/test_update_key_events.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_incidents/test_incident_urls.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_incidents/test_models/test_incident_model.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_incidents/test_models/test_migrations/test_incident_migrations.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_incidents/test_utils/test_date_utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_incidents/test_views/test_incident_detail_view.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_incidents/test_views/test_index_view.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_raid/test_raid_client_users.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_raid/test_raid_transitions.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_raid/test_raid_utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_slack/conftest.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_slack/test_models/test_conversations.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_slack/test_models/test_incident_channel.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_slack/test_models/test_slack_user.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_slack/test_slack_utils.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_slack/views/modals/test_close.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_slack/views/modals/test_send_sos.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_slack/views/modals/test_status.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter_tests/test_slack/views/modals/test_update_status.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/gunicorn.conf.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/main.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/manage.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/package-lock.json +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/package.json +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/pyproject.toml +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/scripts/gen_credits.py +0 -0
- {firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/scripts/hatch_build.py +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: firefighter-incident
|
|
3
|
-
Version: 0.0.
|
|
3
|
+
Version: 0.0.11
|
|
4
4
|
Summary: Incident Management tool made for Slack using Django
|
|
5
5
|
Project-URL: Repository, https://github.com/ManoManoTech/firefighter-incident
|
|
6
6
|
Project-URL: Documentation, https://manomanotech.github.io/firefighter-incident/latest/
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/avatar/avatar.py
RENAMED
|
@@ -25,7 +25,7 @@ class Kwargs(TypedDict, total=False):
|
|
|
25
25
|
|
|
26
26
|
|
|
27
27
|
@component.register("avatar")
|
|
28
|
-
class Avatar(component.Component):
|
|
28
|
+
class Avatar(component.Component):
|
|
29
29
|
template_name = "avatar/avatar.html"
|
|
30
30
|
|
|
31
31
|
def get_context_data(self, user: User, **kwargs: Any) -> Data:
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/card/card.py
RENAMED
|
@@ -14,7 +14,7 @@ class Data(TypedDict, total=False):
|
|
|
14
14
|
|
|
15
15
|
|
|
16
16
|
@component.register("card")
|
|
17
|
-
class Card(component.Component):
|
|
17
|
+
class Card(component.Component):
|
|
18
18
|
template_name = "card/card.html"
|
|
19
19
|
|
|
20
20
|
def get_context_data(self, *args: Any, **kwargs: Unpack[Data]) -> Data:
|
|
@@ -27,7 +27,7 @@ class Kwargs(TypedDict, total=False):
|
|
|
27
27
|
|
|
28
28
|
|
|
29
29
|
@component.register("export_button")
|
|
30
|
-
class ExportButton(component.Component):
|
|
30
|
+
class ExportButton(component.Component):
|
|
31
31
|
template_name = "export_button/export_button.html"
|
|
32
32
|
|
|
33
33
|
def get_context_data(
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/form/form.py
RENAMED
|
@@ -19,8 +19,8 @@ class Data(TypedDict):
|
|
|
19
19
|
|
|
20
20
|
|
|
21
21
|
@component.register("form")
|
|
22
|
-
class
|
|
22
|
+
class FormComponent(component.Component):
|
|
23
23
|
template_name = "form/form.html"
|
|
24
24
|
|
|
25
|
-
def get_context_data(self, form: forms.Form, **kwargs: Any) -> Data:
|
|
25
|
+
def get_context_data(self, form: forms.Form, **kwargs: Any) -> Data:
|
|
26
26
|
return Data(form=form)
|
|
@@ -22,7 +22,7 @@ class Kwargs(TypedDict, total=True):
|
|
|
22
22
|
|
|
23
23
|
|
|
24
24
|
@component.register("form_field")
|
|
25
|
-
class FormField(component.Component):
|
|
25
|
+
class FormField(component.Component):
|
|
26
26
|
template_name = "form_field/form_field.html"
|
|
27
27
|
|
|
28
28
|
def get_context_data(
|
|
@@ -14,7 +14,7 @@ class Data(TypedDict):
|
|
|
14
14
|
|
|
15
15
|
|
|
16
16
|
@component.register("messages")
|
|
17
|
-
class
|
|
17
|
+
class MessagesComponent(component.Component):
|
|
18
18
|
template_name = "messages/messages.html"
|
|
19
19
|
|
|
20
20
|
def get_context_data(self, messages: BaseStorage, **kwargs: Any) -> Data:
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/modal/modal.py
RENAMED
|
@@ -28,7 +28,7 @@ class Slots(TypedDict):
|
|
|
28
28
|
|
|
29
29
|
|
|
30
30
|
@component.register("modal")
|
|
31
|
-
class Modal(component.Component):
|
|
31
|
+
class Modal(component.Component):
|
|
32
32
|
template_name = "modal/modal.html"
|
|
33
33
|
|
|
34
34
|
def get_context_data(self, *args: Any, **kwargs: Unpack[Kwargs]) -> Data:
|
|
@@ -39,7 +39,7 @@ class SelectImpactForm(forms.Form):
|
|
|
39
39
|
|
|
40
40
|
super().__init__(*args, **kwargs)
|
|
41
41
|
|
|
42
|
-
for impact_type in ImpactType.objects.all().order_by("
|
|
42
|
+
for impact_type in ImpactType.objects.all().order_by("order"):
|
|
43
43
|
field_name = f"set_impact_type_{impact_type.value}"
|
|
44
44
|
self.fields[field_name] = forms.ModelChoiceField(
|
|
45
45
|
label=impact_type.emoji + " " + impact_type.name,
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
# Generated by ChatGPT on 2024-06-24
|
|
2
|
+
from django.db import migrations
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
def reorder_impact_types(apps, schema_editor):
|
|
6
|
+
ImpactType = apps.get_model("incidents", "ImpactType")
|
|
7
|
+
# On suppose que les valeurs sont :
|
|
8
|
+
# business_impact, customers_impact, sellers_impact, employees_impact
|
|
9
|
+
order_map = {
|
|
10
|
+
"business_impact": 1,
|
|
11
|
+
"customers_impact": 2,
|
|
12
|
+
"sellers_impact": 3,
|
|
13
|
+
"employees_impact": 4,
|
|
14
|
+
}
|
|
15
|
+
for value, order in order_map.items():
|
|
16
|
+
impact_type = ImpactType.objects.filter(value=value).first()
|
|
17
|
+
if impact_type:
|
|
18
|
+
impact_type.order = order
|
|
19
|
+
impact_type.save(update_fields=["order"])
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
class Migration(migrations.Migration):
|
|
23
|
+
dependencies = [
|
|
24
|
+
("incidents", "0016_update_business_incidents_and_level"),
|
|
25
|
+
]
|
|
26
|
+
operations = [
|
|
27
|
+
migrations.RunPython(reorder_impact_types),
|
|
28
|
+
]
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
# Generated by ChatGPT on 2024-06-24
|
|
2
|
+
from django.db import migrations
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
def update_impactlevel_names(apps, schema_editor):
|
|
6
|
+
ImpactType = apps.get_model("incidents", "ImpactType")
|
|
7
|
+
ImpactLevel = apps.get_model("incidents", "ImpactLevel")
|
|
8
|
+
|
|
9
|
+
# Map: (impact_type.value, impact_level.value) -> new name
|
|
10
|
+
updates = {
|
|
11
|
+
("business_impact", "HT"): "Critical Impact (>5% BV loss)",
|
|
12
|
+
("business_impact", "HI"): "Major Impact (<5% BV loss)",
|
|
13
|
+
("business_impact", "MD"): "Uncertain Business Impact",
|
|
14
|
+
("business_impact", "LO"): "Low Impact not measurable",
|
|
15
|
+
("business_impact", "LT"): "Very Low Impact not measurable",
|
|
16
|
+
("customers_impact", "HT"): "Critical issue for many customers",
|
|
17
|
+
("customers_impact", "HI"): "Major issue for many customers",
|
|
18
|
+
("customers_impact", "MD"): "Major issue for few customers",
|
|
19
|
+
("customers_impact", "LO"): "Minor issue for customers",
|
|
20
|
+
("customers_impact", "LT"): "Cosmetic minor issue for customers",
|
|
21
|
+
("sellers_impact", "HT"): "Critical issue for many sellers",
|
|
22
|
+
("sellers_impact", "HI"): "Major issue for many sellers",
|
|
23
|
+
("sellers_impact", "MD"): "Major issue for few sellers",
|
|
24
|
+
("sellers_impact", "LO"): "Minor issue for sellers",
|
|
25
|
+
("sellers_impact", "LT"): "Cosmetic minor issue for sellers",
|
|
26
|
+
("employees_impact", "MD"): "Departments fully blocked",
|
|
27
|
+
("employees_impact", "LO"): "Some employees affected",
|
|
28
|
+
("employees_impact", "LT"): "Degraded service for employees",
|
|
29
|
+
("employees_impact", "NO"): "No impact for employees",
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
for (impact_type_value, level_value), new_name in updates.items():
|
|
33
|
+
impact_type = ImpactType.objects.filter(value=impact_type_value).first()
|
|
34
|
+
if not impact_type:
|
|
35
|
+
continue
|
|
36
|
+
impact_level = ImpactLevel.objects.filter(impact_type=impact_type, value=level_value).first()
|
|
37
|
+
if impact_level:
|
|
38
|
+
impact_level.name = new_name
|
|
39
|
+
impact_level.save(update_fields=["name"])
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
class Migration(migrations.Migration):
|
|
43
|
+
dependencies = [
|
|
44
|
+
("incidents", "0017_reorder_impact_types"),
|
|
45
|
+
]
|
|
46
|
+
operations = [
|
|
47
|
+
migrations.RunPython(update_impactlevel_names),
|
|
48
|
+
]
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/slack/views/modals/open.py
RENAMED
|
@@ -12,7 +12,6 @@ from django.utils.translation import ngettext
|
|
|
12
12
|
from slack_sdk.models.blocks.basic_components import MarkdownTextObject, Option
|
|
13
13
|
from slack_sdk.models.blocks.block_elements import ButtonElement, StaticSelectElement
|
|
14
14
|
from slack_sdk.models.blocks.blocks import (
|
|
15
|
-
ActionsBlock,
|
|
16
15
|
Block,
|
|
17
16
|
ContextBlock,
|
|
18
17
|
DividerBlock,
|
|
@@ -23,6 +22,7 @@ from slack_sdk.models.views import View
|
|
|
23
22
|
from firefighter.firefighter.utils import is_during_office_hours
|
|
24
23
|
from firefighter.incidents.enums import IncidentStatus
|
|
25
24
|
from firefighter.incidents.forms.select_impact import SelectImpactForm
|
|
25
|
+
from firefighter.incidents.models.impact import ImpactType
|
|
26
26
|
from firefighter.incidents.models.incident import Incident
|
|
27
27
|
from firefighter.incidents.models.priority import Priority
|
|
28
28
|
from firefighter.slack.slack_app import SlackApp
|
|
@@ -73,7 +73,9 @@ class OpenModal(SlackModal):
|
|
|
73
73
|
# 1. Check if impact form is good
|
|
74
74
|
is_impact_form_valid: bool = self._check_impact_form(open_incident_context)
|
|
75
75
|
|
|
76
|
-
# 2.
|
|
76
|
+
# 2. Auto-determine response type based on priority
|
|
77
|
+
self._auto_set_response_type(open_incident_context)
|
|
78
|
+
|
|
77
79
|
incident_type_value: str | None = open_incident_context.get(
|
|
78
80
|
"incident_type", None
|
|
79
81
|
)
|
|
@@ -180,11 +182,18 @@ class OpenModal(SlackModal):
|
|
|
180
182
|
SelectImpactModal,
|
|
181
183
|
)
|
|
182
184
|
|
|
185
|
+
# Check if we have actual impacts (not all "NO") by checking if response_type is set
|
|
186
|
+
has_real_impacts = open_incident_context.get("response_type") is not None
|
|
187
|
+
|
|
188
|
+
# Show ✅ only if form is valid AND has real impacts, otherwise 📝
|
|
189
|
+
emoji = "✅" if impact_form_done and has_real_impacts else "📝"
|
|
190
|
+
button_text = "Edit impacts" if impact_form_done and has_real_impacts else "Set impacts"
|
|
191
|
+
|
|
183
192
|
return [
|
|
184
193
|
SectionBlock(
|
|
185
|
-
text=f"{
|
|
194
|
+
text=f"{emoji} First, define the incident impacts and priority.",
|
|
186
195
|
accessory=ButtonElement(
|
|
187
|
-
text=
|
|
196
|
+
text=button_text,
|
|
188
197
|
action_id=SelectImpactModal.push_action,
|
|
189
198
|
value=json.dumps(open_incident_context, cls=SlackFormJSONEncoder),
|
|
190
199
|
),
|
|
@@ -370,58 +379,79 @@ class OpenModal(SlackModal):
|
|
|
370
379
|
|
|
371
380
|
return is_valid, details_form_class, details_form
|
|
372
381
|
|
|
382
|
+
@staticmethod
|
|
383
|
+
def _auto_set_response_type(open_incident_context: OpeningData) -> None:
|
|
384
|
+
"""Auto-determine response type based on priority from impact form."""
|
|
385
|
+
impact_form_data = open_incident_context.get("impact_form_data")
|
|
386
|
+
if not impact_form_data:
|
|
387
|
+
# Clear response_type and priority if no impact data
|
|
388
|
+
open_incident_context.pop("response_type", None)
|
|
389
|
+
open_incident_context.pop("priority", None)
|
|
390
|
+
return
|
|
391
|
+
|
|
392
|
+
impact_form = SelectImpactForm(impact_form_data)
|
|
393
|
+
if not impact_form.is_valid():
|
|
394
|
+
# Clear response_type and priority if form is invalid
|
|
395
|
+
open_incident_context.pop("response_type", None)
|
|
396
|
+
open_incident_context.pop("priority", None)
|
|
397
|
+
return
|
|
398
|
+
|
|
399
|
+
priority_value = impact_form.suggest_priority_from_impact()
|
|
400
|
+
|
|
401
|
+
# If no impacts are selected (all set to "NO"), don't set priority/response_type
|
|
402
|
+
# Priority value 6 corresponds to LevelChoices.NONE.priority
|
|
403
|
+
if priority_value == 6:
|
|
404
|
+
open_incident_context.pop("response_type", None)
|
|
405
|
+
open_incident_context.pop("priority", None)
|
|
406
|
+
return
|
|
407
|
+
|
|
408
|
+
priority = Priority.objects.get(value=priority_value)
|
|
409
|
+
|
|
410
|
+
# Set priority in context
|
|
411
|
+
open_incident_context["priority"] = priority
|
|
412
|
+
|
|
413
|
+
# Set response type based on priority recommendation
|
|
414
|
+
if priority.recommended_response_type:
|
|
415
|
+
open_incident_context["response_type"] = cast("ResponseType | None", priority.recommended_response_type)
|
|
416
|
+
else:
|
|
417
|
+
# Default fallback: P1/P2/P3 = critical, P4/P5 = normal
|
|
418
|
+
response_type = cast("ResponseType", "critical" if priority_value < 4 else "normal")
|
|
419
|
+
open_incident_context["response_type"] = response_type
|
|
420
|
+
|
|
373
421
|
@staticmethod
|
|
374
422
|
def _build_response_type_blocks(open_incident_context: OpeningData) -> list[Block]:
|
|
375
423
|
selected_response_type = open_incident_context.get("response_type")
|
|
376
424
|
if selected_response_type not in {"critical", "normal"}:
|
|
377
425
|
return []
|
|
378
426
|
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
)
|
|
382
|
-
elements: list[ButtonElement] = []
|
|
383
|
-
|
|
384
|
-
for response_type in response_types:
|
|
385
|
-
if response_type != selected_response_type:
|
|
386
|
-
continue
|
|
387
|
-
|
|
388
|
-
is_selected = (
|
|
389
|
-
open_incident_context.get("response_type") == response_type
|
|
390
|
-
or len(INCIDENT_TYPES) == 1
|
|
391
|
-
)
|
|
392
|
-
style: str | None = "primary" if is_selected else None
|
|
393
|
-
text = (
|
|
394
|
-
":slack: Slack :jira_new: Jira ticket"
|
|
395
|
-
if response_type == "critical"
|
|
396
|
-
else ":jira_new: Jira ticket"
|
|
397
|
-
)
|
|
398
|
-
button = ButtonElement(
|
|
399
|
-
text=text,
|
|
400
|
-
action_id=f"incident_open_set_res_type_{response_type}",
|
|
401
|
-
value=json.dumps(open_incident_context, cls=SlackFormJSONEncoder),
|
|
402
|
-
style=style,
|
|
403
|
-
)
|
|
404
|
-
elements.append(button)
|
|
405
|
-
|
|
406
|
-
blocks: list[Block] = [ActionsBlock(elements=elements)]
|
|
427
|
+
blocks: list[Block] = []
|
|
428
|
+
# No buttons needed - response type is auto-determined
|
|
407
429
|
if impact_form_data := open_incident_context.get("impact_form_data"):
|
|
408
430
|
impact_form = SelectImpactForm(impact_form_data)
|
|
409
431
|
if impact_form.is_valid():
|
|
410
432
|
priority: Priority = Priority.objects.get(
|
|
411
433
|
value=impact_form.suggest_priority_from_impact()
|
|
412
434
|
)
|
|
435
|
+
process = ":slack: Slack :jira_new: Jira ticket" if open_incident_context.get("response_type") == "critical" else ":jira_new: Jira ticket"
|
|
436
|
+
|
|
437
|
+
impact_descriptions = OpenModal._get_impact_descriptions(open_incident_context)
|
|
438
|
+
|
|
413
439
|
blocks.append(
|
|
414
440
|
ContextBlock(
|
|
415
441
|
elements=[
|
|
416
442
|
MarkdownTextObject(
|
|
417
|
-
text=f"> {priority.emoji} Selected priority: {priority}"
|
|
443
|
+
text=f"> {priority.emoji} Selected priority: *{priority} - {priority.description}*\n"
|
|
444
|
+
f"> ⏱️ SLA: {priority.sla}\n"
|
|
445
|
+
f"> :gear: Process: {process}\n"
|
|
446
|
+
f"> :pushpin: Selected impacts:\n"
|
|
447
|
+
f"{impact_descriptions}"
|
|
418
448
|
+ (
|
|
419
449
|
(
|
|
420
|
-
"
|
|
450
|
+
"> :warning: Critical incidents are for *emergency* only"
|
|
421
451
|
+ (
|
|
422
|
-
f"<{SLACK_SEVERITY_HELP_GUIDE_URL}|
|
|
452
|
+
f" <{SLACK_SEVERITY_HELP_GUIDE_URL}|more info>"
|
|
423
453
|
if SLACK_SEVERITY_HELP_GUIDE_URL
|
|
424
|
-
else "
|
|
454
|
+
else "."
|
|
425
455
|
)
|
|
426
456
|
)
|
|
427
457
|
if selected_response_type == "critical"
|
|
@@ -448,6 +478,59 @@ class OpenModal(SlackModal):
|
|
|
448
478
|
|
|
449
479
|
return blocks
|
|
450
480
|
|
|
481
|
+
@staticmethod
|
|
482
|
+
def _get_impact_descriptions(open_incident_context: OpeningData) -> str:
|
|
483
|
+
impact_form_data = open_incident_context.get("impact_form_data", {})
|
|
484
|
+
if not impact_form_data:
|
|
485
|
+
return ""
|
|
486
|
+
|
|
487
|
+
impact_descriptions = ""
|
|
488
|
+
for field_name, original_value in impact_form_data.items():
|
|
489
|
+
value = original_value
|
|
490
|
+
# Handle case where value might be an ID instead of an object
|
|
491
|
+
if isinstance(value, int | str) and not hasattr(value, "name"):
|
|
492
|
+
# Try to get the object from the database
|
|
493
|
+
form = SelectImpactForm()
|
|
494
|
+
if field_name in form.fields:
|
|
495
|
+
field = form.fields[field_name]
|
|
496
|
+
if hasattr(field, "queryset") and field.queryset is not None:
|
|
497
|
+
try:
|
|
498
|
+
value = field.queryset.get(pk=value)
|
|
499
|
+
except field.queryset.model.DoesNotExist:
|
|
500
|
+
logger.warning(f"Could not find impact object with pk={value} for field {field_name}")
|
|
501
|
+
continue
|
|
502
|
+
|
|
503
|
+
description = OpenModal._format_single_impact_description(value)
|
|
504
|
+
if description:
|
|
505
|
+
impact_descriptions += description
|
|
506
|
+
return impact_descriptions
|
|
507
|
+
|
|
508
|
+
@staticmethod
|
|
509
|
+
def _format_single_impact_description(value: Any) -> str:
|
|
510
|
+
"""Format a single impact value into description text."""
|
|
511
|
+
# Handle object with name and description attributes (impact levels)
|
|
512
|
+
if hasattr(value, "name") and hasattr(value, "description"):
|
|
513
|
+
if value.name == "NO" or not value.description:
|
|
514
|
+
return ""
|
|
515
|
+
|
|
516
|
+
description = ""
|
|
517
|
+
# Add impact type header if available
|
|
518
|
+
if hasattr(value, "impact_type_id") and value.impact_type_id:
|
|
519
|
+
try:
|
|
520
|
+
impact_type = ImpactType.objects.get(pk=value.impact_type_id)
|
|
521
|
+
# Use value.name instead of value to avoid showing IDs
|
|
522
|
+
description += f"> \u00A0\u00A0 :exclamation: {impact_type} - {value.name}\n"
|
|
523
|
+
except ImpactType.DoesNotExist:
|
|
524
|
+
description += f"> \u00A0\u00A0 :exclamation: {value.name}\n"
|
|
525
|
+
|
|
526
|
+
# Add description lines
|
|
527
|
+
for line in str(value.description).splitlines():
|
|
528
|
+
description += f"> \u00A0\u00A0\u00A0\u00A0\u00A0\u00A0 • {line}\n"
|
|
529
|
+
return description
|
|
530
|
+
|
|
531
|
+
# Skip string values - incident_type is handled separately, not in impact descriptions
|
|
532
|
+
return ""
|
|
533
|
+
|
|
451
534
|
@staticmethod
|
|
452
535
|
def get_details_modal_form_class(
|
|
453
536
|
open_incident_context: OpeningData,
|
|
@@ -508,21 +591,7 @@ class OpenModal(SlackModal):
|
|
|
508
591
|
logger.exception("Error triggering incident workflow")
|
|
509
592
|
# XXX warn the user via DM!
|
|
510
593
|
|
|
511
|
-
|
|
512
|
-
@app.action("incident_open_set_res_type_critical")
|
|
513
|
-
@staticmethod
|
|
514
|
-
def handle_set_incident_response_type_action(
|
|
515
|
-
ack: Ack, body: dict[str, Any]
|
|
516
|
-
) -> None:
|
|
517
|
-
action_name: str = body.get("actions", [{}])[0].get("action_id", "")
|
|
518
|
-
action_name = action_name.replace("incident_open_set_res_type_", "")
|
|
519
|
-
opening_data = cast(
|
|
520
|
-
"OpeningData", json.loads(body.get("actions", [{}])[0].get("value", {})) or {}
|
|
521
|
-
)
|
|
522
|
-
|
|
523
|
-
OpenModal._update_incident_modal(
|
|
524
|
-
action_name, "response_type", ack, body, opening_data
|
|
525
|
-
)
|
|
594
|
+
# Response type buttons removed - now auto-determined based on priority
|
|
526
595
|
|
|
527
596
|
@app.action("set_type")
|
|
528
597
|
@staticmethod
|
|
@@ -544,7 +613,11 @@ class OpenModal(SlackModal):
|
|
|
544
613
|
body: dict[str, Any],
|
|
545
614
|
opening_data: OpeningData,
|
|
546
615
|
) -> None:
|
|
547
|
-
|
|
616
|
+
# Ensure we preserve all existing data, especially impact_form_data
|
|
617
|
+
data: OpeningData = OpeningData()
|
|
618
|
+
data.update(opening_data)
|
|
619
|
+
data[metadata_key] = action_value
|
|
620
|
+
|
|
548
621
|
user = get_user_from_context(body)
|
|
549
622
|
view = cls().build_modal_fn(open_incident_context=data, user=user)
|
|
550
623
|
|
|
@@ -205,7 +205,16 @@ class SelectImpactModal(
|
|
|
205
205
|
def _calculate_proposed_incident_type(
|
|
206
206
|
suggested_priority_value: int,
|
|
207
207
|
) -> ResponseType:
|
|
208
|
-
|
|
208
|
+
try:
|
|
209
|
+
priority = Priority.objects.get(value=suggested_priority_value)
|
|
210
|
+
# Use priority recommendation if available
|
|
211
|
+
if priority.recommended_response_type:
|
|
212
|
+
return cast("ResponseType", priority.recommended_response_type)
|
|
213
|
+
except Priority.DoesNotExist:
|
|
214
|
+
logger.warning(f"Priority with value {suggested_priority_value} does not exist")
|
|
215
|
+
|
|
216
|
+
# Fallback logic: P1/P2/P3 = critical, P4/P5 = normal
|
|
217
|
+
return cast("ResponseType", "critical" if suggested_priority_value < 4 else "normal")
|
|
209
218
|
|
|
210
219
|
@staticmethod
|
|
211
220
|
def _update_private_metadata(
|
|
@@ -230,12 +239,36 @@ class SelectImpactModal(
|
|
|
230
239
|
)
|
|
231
240
|
except queryset.model.DoesNotExist:
|
|
232
241
|
form.form.data[field_name] = None # type: ignore
|
|
242
|
+
suggested_priority_value = form.form.suggest_priority_from_impact()
|
|
243
|
+
|
|
244
|
+
# If no impacts are selected (all set to "NO"), don't set priority/response_type
|
|
245
|
+
if suggested_priority_value == 6: # LevelChoices.NONE.priority
|
|
246
|
+
return OpeningData(
|
|
247
|
+
priority=None,
|
|
248
|
+
response_type=None,
|
|
249
|
+
impact_form_data=cast("dict[str, Any]", form.form.data),
|
|
250
|
+
details_form_data=private_metadata_raw.get("details_form_data", {}),
|
|
251
|
+
incident_type=private_metadata_raw.get("incident_type"),
|
|
252
|
+
)
|
|
253
|
+
|
|
254
|
+
try:
|
|
255
|
+
priority = Priority.objects.get(value=suggested_priority_value)
|
|
256
|
+
except Priority.DoesNotExist as err:
|
|
257
|
+
logger.exception(
|
|
258
|
+
f"Priority with value {suggested_priority_value} does not exist"
|
|
259
|
+
)
|
|
260
|
+
# Fallback to default priority (assuming P3 exists)
|
|
261
|
+
fallback_priority = Priority.objects.filter(value__gte=3).first()
|
|
262
|
+
if not fallback_priority:
|
|
263
|
+
# If no priority exists, create a minimal fallback
|
|
264
|
+
logger.exception("No priority found in database")
|
|
265
|
+
raise ValueError("No priority configuration found in database") from err
|
|
266
|
+
priority = fallback_priority
|
|
267
|
+
|
|
233
268
|
return OpeningData(
|
|
234
|
-
priority=
|
|
235
|
-
value=form.form.suggest_priority_from_impact()
|
|
236
|
-
),
|
|
269
|
+
priority=priority,
|
|
237
270
|
response_type=SelectImpactModal._calculate_proposed_incident_type(
|
|
238
|
-
|
|
271
|
+
suggested_priority_value
|
|
239
272
|
),
|
|
240
273
|
impact_form_data=cast("dict[str, Any]", form.form.data),
|
|
241
274
|
details_form_data=private_metadata_raw.get("details_form_data", {}),
|
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
3
|
from typing import Any
|
|
4
|
-
from unittest.mock import MagicMock
|
|
4
|
+
from unittest.mock import MagicMock, Mock, patch
|
|
5
5
|
|
|
6
6
|
import pytest
|
|
7
|
-
from slack_sdk.models.blocks.block_elements import ButtonElement
|
|
8
7
|
from slack_sdk.models.blocks.blocks import (
|
|
9
|
-
|
|
8
|
+
ContextBlock,
|
|
10
9
|
)
|
|
11
10
|
|
|
12
11
|
from firefighter.incidents.forms.create_incident import CreateIncidentFormBase
|
|
@@ -102,14 +101,32 @@ def test_validate_details_form_invalid() -> None:
|
|
|
102
101
|
|
|
103
102
|
|
|
104
103
|
def test_build_response_type_blocks_bis(open_incident_context: OpeningData) -> None:
|
|
104
|
+
# With no impact_form_data, should return empty list
|
|
105
105
|
open_incident_context["response_type"] = "critical"
|
|
106
106
|
blocks = OpenModal._build_response_type_blocks(open_incident_context)
|
|
107
|
+
assert len(blocks) == 0
|
|
107
108
|
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
109
|
+
# With valid impact_form_data, should return context blocks
|
|
110
|
+
mock_impact_form = Mock()
|
|
111
|
+
mock_impact_form.is_valid.return_value = True
|
|
112
|
+
mock_impact_form.suggest_priority_from_impact.return_value = 1
|
|
113
|
+
|
|
114
|
+
# Mock Priority object
|
|
115
|
+
mock_priority = Mock()
|
|
116
|
+
mock_priority.emoji = "🔴"
|
|
117
|
+
mock_priority.description = "Critical"
|
|
118
|
+
mock_priority.sla = "15 min"
|
|
119
|
+
mock_priority.recommended_response_type = None
|
|
120
|
+
|
|
121
|
+
open_incident_context["impact_form_data"] = {"test_field": "test_value"}
|
|
122
|
+
|
|
123
|
+
with patch("firefighter.slack.views.modals.open.SelectImpactForm", return_value=mock_impact_form), \
|
|
124
|
+
patch("firefighter.slack.views.modals.open.Priority.objects.get", return_value=mock_priority), \
|
|
125
|
+
patch.object(OpenModal, "_get_impact_descriptions", return_value="Test impact"):
|
|
126
|
+
blocks = OpenModal._build_response_type_blocks(open_incident_context)
|
|
127
|
+
assert len(blocks) == 1
|
|
128
|
+
first_block = blocks[0]
|
|
129
|
+
assert isinstance(first_block, ContextBlock)
|
|
113
130
|
|
|
114
131
|
|
|
115
132
|
@pytest.mark.django_db
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/authentication.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/migrations/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/components.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/environments.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/incident_costs.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/incidents.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/api/views/severities.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/__init__.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/avatar/__init__.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/avatar/avatar.html
RENAMED
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/card/__init__.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/card/card.html
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/form/__init__.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.9 → firefighter_incident-0.0.11}/firefighter/components/form/form.html
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|