firefighter-incident 0.0.19__tar.gz → 0.0.21__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.19 → firefighter_incident-0.0.21}/PKG-INFO +1 -1
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/_version.py +2 -2
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/forms/select_impact.py +1 -1
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/jira_app/client.py +17 -7
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/serializers.py +2 -4
- firefighter_incident-0.0.21/firefighter_tests/test_jira_app/__init__.py +1 -0
- firefighter_incident-0.0.21/firefighter_tests/test_jira_app/conftest.py +24 -0
- firefighter_incident-0.0.21/firefighter_tests/test_jira_app/test_jira_client_watchers.py +135 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_raid/test_raid_forms.py +55 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/.gitignore +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/LICENSE +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/README.md +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/admin.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/apps.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/authentication.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/migrations/0001_initial.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/migrations/0002_alter_apitokenproxy_options.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/migrations/0003_alter_apitokenproxy_options.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/models.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/permissions.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/renderer.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/serializers.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/urls.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/_base.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/components.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/environments.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/groups.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/incident_cost_types.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/incident_costs.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/incidents.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/severities.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/avatar/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/avatar/avatar.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/avatar/avatar.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/card/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/card/card.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/card/card.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/export_button/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/export_button/export_button.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/export_button/export_button.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/form/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/form/form.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/form/form.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/form_field/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/form_field/form_field.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/form_field/form_field.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/messages/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/messages/messages.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/messages/messages.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/modal/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/modal/modal.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/modal/modal.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/admin.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/apps.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/client.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/management/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/management/commands/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/management/commands/sort_postmortems.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/management/commands/sort_runbooks.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/management/commands/sync_postmortems.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/management/commands/sync_runbooks.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/migrations/0001_initial_oss.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/models.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/serializers.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/service.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/signals/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/signals/incident_updated.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/tables.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/tasks/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/tasks/archive_postmortems.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/tasks/sort_runbooks.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/tasks/sync_pages_content.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/tasks/sync_postmortems.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/tasks/sync_runbooks.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/templates/oncall_team.xml +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/templates/pages/runbook_list.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/urls.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/views/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/views/api.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/views/postmortem/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/views/postmortem/postmortem_detail.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/views/runbook/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/views/runbook/runbook_list.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/admin.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/apps.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/asgi.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/celery_client.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/fields_forms_widgets.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/filters.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/formats/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/formats/en/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/formats/en/formats.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/http_client.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/management/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/management/commands/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/management/commands/task.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/middleware.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/components/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/components/api.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/components/caches.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/components/celery.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/components/common.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/components/confluence.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/components/jira_app.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/components/logging.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/components/pagerduty.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/components/raid.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/components/slack.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/environments/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/environments/dev.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/environments/prod.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/settings_builder.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/settings/settings_utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/sso.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/tables_utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/templates/admin/base.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/templates/admin/login.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/templates/admin/send_message_conversation.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/templates/robots.txt +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/urls.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/views.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/wsgi.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/admin.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/apps.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/enums.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/factories.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/forms/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/forms/close_incident.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/forms/closure_reason.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/forms/create_incident.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/forms/edit.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/forms/unified_incident.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/forms/update_key_events.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/forms/update_roles.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/forms/update_status.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/forms/utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/menus.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0001_initial_oss.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0002_alter_severity_name_alter_user_password_featureteam.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0003_delete_featureteam.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0004_incidentupdate_environment.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0005_enable_from_p1_to_p5_priority.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0006_update_group_names.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0007_update_component_name.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0008_impact_level.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0009_update_sla.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0010_update_components.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0011_update_incidents.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0012_alter_impactlevel.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0013_add_missing_component.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0014_update_components_slack_groups.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0015_update_impact_level.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0016_update_business_incidents_and_level.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0017_reorder_impact_types.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0018_update_impactlevel_names.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0019_set_security_components_private.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0020_create_incident_category_model.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0021_copy_component_data_to_incident_category.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0022_add_incident_category_fields.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0023_populate_incident_category_references.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0024_remove_component_fields_and_model.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0025_make_incident_category_required.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0026_alter_incidentcategory_options_and_more.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0027_add_closure_fields.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0028_add_closure_reason_constraint.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/0029_add_custom_fields_to_incident.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/environment.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/group.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/impact.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/incident.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/incident_category.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/incident_cost.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/incident_cost_type.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/incident_membership.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/incident_role_type.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/incident_update.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/metric_type.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/milestone_type.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/priority.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/severity.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/models/user.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/signals.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/css/incident.css +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/css/main.css +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/css/main.min.css +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/css/tailwind.css +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/favicon/android-chrome-192x192.png +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/favicon/android-chrome-512x512.png +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/favicon/apple-touch-icon.png +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/favicon/favicon-16x16.png +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/favicon/favicon-32x32.png +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/favicon/favicon.ico +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/favicon/site.webmanifest +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/gameday.png +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/logo-firefighter.png +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/p1.png +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/p2.png +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/p3.png +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/p4.png +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/img/p5.png +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/js/main.js +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/static/js/main.min.js +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/tables.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/tasks/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/tasks/updateoncall.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/incidents/errors/base.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/incidents/filter.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/incidents/table/priority_column.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/incidents/table/status_column.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/incidents/table.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/incidents/widgets/form_container.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/incidents/widgets/grouped_checkbox_nested.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/incidents/widgets/input_option.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/index.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/created_at_help.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/environment_pill.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/footer.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/header.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/incident_card.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/incident_metrics.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/incident_timeline.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/incident_update_key_events_view.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/incident_update_key_events_view_modal.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/partial_table_list_paginated.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/priority_icon.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/priority_pill.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/status_pill.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/table.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/user_card.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/partials/user_tooltip.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/layouts/view_filters.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/pages/dashboard.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/pages/docs_metrics.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/pages/incident_category_detail.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/pages/incident_category_list.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/pages/incident_create.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/pages/incident_detail.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/pages/incident_list.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/pages/incident_role_types_detail.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/pages/incident_role_types_list.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/pages/incident_statistics.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/pages/incident_statistics_partial.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/pages/incident_update_key_events_form.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/templates/pages/user_detail.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/urls.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/components/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/components/details.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/components/list.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/date_filter.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/date_utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/docs/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/docs/metrics.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/docs/role_types.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/errors.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/reports.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/users/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/users/details.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/incidents/views/views.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/jira_app/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/jira_app/admin.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/jira_app/apps.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/jira_app/migrations/0001_initial_oss.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/jira_app/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/jira_app/models.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/jira_app/tasks/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/jira_app/tasks/sync_users_jira.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/jira_app/types.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/jira_app/utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/logging/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/logging/custom_json_formatter.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/logging/pretty_formatter.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/admin.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/apps.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/client.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/forms/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/forms/create_pagerduty_incident.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/migrations/0001_initial_oss.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/models.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/service.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/signals/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/signals/get_invites_from_pagerduty.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/signals/incident_channel_done_oncall.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/tasks/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/tasks/fetch_oncall.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/tasks/fetch_services.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/tasks/fetch_users.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/tasks/trigger_oncall.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/templates/pages/oncall_list.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/templates/pages/oncall_trigger.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/templates/partials/trigger_oncall_form_view.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/templates/partials/trigger_oncall_form_view_modal.html +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/urls.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/views/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/views/oncall_list.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/pagerduty/views/oncall_trigger.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/admin.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/apps.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/client.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/forms.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/messages.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/migrations/0001_initial_oss.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/migrations/0002_featureteam_remove_qualifierrotation_jira_user_and_more.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/migrations/0003_delete_raidarea.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/models.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/resources.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/service.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/signals/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/signals/incident_updated.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/tasks/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/types.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/urls.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/raid/views/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/admin.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/apps.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/factories.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/forms/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/forms/sos_form.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/management/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/management/commands/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/management/commands/generate_manifest.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/management/commands/switch_test_users.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/messages/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/messages/base.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/messages/slack_messages.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/migrations/0001_initial_oss.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/migrations/0002_usergroup_tag.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/migrations/0003_alter_usergroup_tag.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/migrations/0004_alter_usergroup_components.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/migrations/0005_add_incident_categories_fields.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/migrations/0006_copy_components_to_incident_categories.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/migrations/0007_remove_components_fields.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/migrations/0008_alter_conversation_incident_categories_and_more.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/migrations/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/models/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/models/conversation.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/models/incident_channel.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/models/message.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/models/sos.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/models/user.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/models/user_group.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/rules.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/signals/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/signals/create_incident_conversation.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/signals/get_users.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/signals/handle_incident_channel_done.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/signals/incident_closed.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/signals/incident_updated.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/signals/postmortem_created.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/signals/roles_reminders.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/slack_app.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/slack_incident_context.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/slack_templating.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/tasks/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/tasks/fetch_conversations_members.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/tasks/reminder_postmortem.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/tasks/send_message.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/tasks/send_reminders.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/tasks/sync_users.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/tasks/update_usergroups_members.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/tasks/update_users.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/urls.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/actions_and_shortcuts.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/channel_archive.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/channel_id_changed.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/channel_rename.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/channel_shared.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/channel_unarchive.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/channel_unshared.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/commands.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/home.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/member_joined_channel.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/member_left_channel.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/message.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/message_deleted.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/events/reaction_added.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/base_modal/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/base_modal/base.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/base_modal/base_mixins.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/base_modal/form_utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/base_modal/mixins.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/base_modal/modal_utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/close.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/closure_reason.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/downgrade_workflow.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/edit.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/key_event_message.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/open.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/opening/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/opening/check_current_incidents.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/opening/details/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/opening/details/unified.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/opening/select_impact.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/opening/set_details.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/opening/types.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/postmortem.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/select.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/send_sos.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/status.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/trigger_oncall.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/update.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/update_roles.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/update_status.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/modals/utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/slack/views/views.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_fixtures/incidents/environments.json +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_fixtures/incidents/groups.json +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_fixtures/incidents/impact_level.json +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_fixtures/incidents/impact_type.json +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_fixtures/incidents/incident_categories.json +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_fixtures/incidents/incident_role_type.json +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_fixtures/incidents/metric_type.json +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_fixtures/incidents/milestone_type.json +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_fixtures/incidents/priorities.json +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_fixtures/incidents/severities.json +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/conftest.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_api/test_api_landbot.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_api/test_api_urls.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_confluence/test_confluence_utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_firefighter/test_firefighter_utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_firefighter/test_logging.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_firefighter/test_sso.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_firefighter/test_urls.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_enums.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_forms/conftest.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_forms/test_closure_reason.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_forms/test_form_select_impact.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_forms/test_form_utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_forms/test_unified_incident_form.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_forms/test_unified_incident_form_integration.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_forms/test_unified_incident_form_p4_p5.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_forms/test_update_key_events.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_forms/test_update_status_workflow.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_forms/test_workflow_transitions.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_incident_urls.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_models/test_incident_category.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_models/test_incident_model.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_models/test_migrations/test_incident_migrations.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_utils/test_date_utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_views/test_incident_detail_view.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_incidents/test_views/test_index_view.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_raid/conftest.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_raid/test_raid_alert_p4_p5.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_raid/test_raid_client.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_raid/test_raid_client_users.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_raid/test_raid_models.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_raid/test_raid_serializers.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_raid/test_raid_service.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_raid/test_raid_signals.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_raid/test_raid_transitions.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_raid/test_raid_utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_raid/test_raid_views.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_raid/test_zendesk_integration.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/conftest.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/messages/__init__.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/messages/test_slack_messages.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/test_conversation_tags.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/test_models/test_conversations.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/test_models/test_incident_channel.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/test_models/test_slack_user.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/test_signals_downgrade.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/test_slack_utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/views/modals/conftest.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/views/modals/test_close.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/views/modals/test_closure_reason_modal.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/views/modals/test_edit.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/views/modals/test_form_utils_multiple_choice.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/views/modals/test_open.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/views/modals/test_opening_unified.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/views/modals/test_send_sos.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/views/modals/test_status.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/views/modals/test_update_status.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter_tests/test_slack/views/modals/test_utils.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/gunicorn.conf.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/main.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/manage.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/package-lock.json +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/package.json +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/pyproject.toml +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/scripts/gen_credits.py +0 -0
- {firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/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.21
|
|
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/
|
|
@@ -28,7 +28,7 @@ version_tuple: VERSION_TUPLE
|
|
|
28
28
|
commit_id: COMMIT_ID
|
|
29
29
|
__commit_id__: COMMIT_ID
|
|
30
30
|
|
|
31
|
-
__version__ = version = '0.0.
|
|
32
|
-
__version_tuple__ = version_tuple = (0, 0,
|
|
31
|
+
__version__ = version = '0.0.21'
|
|
32
|
+
__version_tuple__ = version_tuple = (0, 0, 21)
|
|
33
33
|
|
|
34
34
|
__commit_id__ = commit_id = None
|
|
@@ -71,7 +71,7 @@ class SelectImpactForm(forms.Form):
|
|
|
71
71
|
if impact_name.impact_type.name == "Business Impact":
|
|
72
72
|
impact_value = impact_name.value
|
|
73
73
|
|
|
74
|
-
return LevelChoices(impact_value).label if impact_value else None
|
|
74
|
+
return str(LevelChoices(impact_value).label) if impact_value else None
|
|
75
75
|
|
|
76
76
|
def save(self, incident: HasImpactProtocol) -> None:
|
|
77
77
|
"""Save the impact choices to the incident."""
|
|
@@ -254,14 +254,24 @@ class JiraClient:
|
|
|
254
254
|
ValueError: Empty issue id
|
|
255
255
|
|
|
256
256
|
Returns:
|
|
257
|
-
list(JiraAPIUser): List of Jira users object
|
|
257
|
+
list(JiraAPIUser): List of Jira users object, or empty list if ticket doesn't exist
|
|
258
258
|
"""
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
259
|
+
try:
|
|
260
|
+
watchers = self.jira.watchers(jira_issue_id).raw.get("watchers")
|
|
261
|
+
except exceptions.JIRAError as e:
|
|
262
|
+
if e.status_code == 404:
|
|
263
|
+
logger.warning(
|
|
264
|
+
"Jira ticket %s not found or no permission to access it. Cannot fetch watchers.",
|
|
265
|
+
jira_issue_id,
|
|
266
|
+
)
|
|
267
|
+
return []
|
|
268
|
+
raise
|
|
269
|
+
else:
|
|
270
|
+
if len(watchers) == 0:
|
|
271
|
+
logger.debug(
|
|
272
|
+
"No watchers found for jira_issue_id '%s'.", jira_issue_id
|
|
273
|
+
)
|
|
274
|
+
return watchers
|
|
265
275
|
|
|
266
276
|
@staticmethod
|
|
267
277
|
def _create_user_from_jira_info(
|
|
@@ -130,14 +130,12 @@ class LandbotIssueRequestSerializer(serializers.ModelSerializer[JiraTicket]):
|
|
|
130
130
|
allow_blank=True,
|
|
131
131
|
)
|
|
132
132
|
suggested_team_routing = serializers.CharField(max_length=10, write_only=True)
|
|
133
|
-
project = serializers.
|
|
133
|
+
project = serializers.CharField(
|
|
134
|
+
max_length=128,
|
|
134
135
|
required=False,
|
|
135
136
|
allow_blank=True,
|
|
136
137
|
allow_null=True,
|
|
137
138
|
default="SBI",
|
|
138
|
-
choices=[
|
|
139
|
-
"SBI",
|
|
140
|
-
],
|
|
141
139
|
)
|
|
142
140
|
priority = serializers.IntegerField(
|
|
143
141
|
min_value=1, max_value=5, write_only=True, allow_null=True,
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"""Tests for jira_app module."""
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"""Fixtures for jira_app tests."""
|
|
2
|
+
|
|
3
|
+
from __future__ import annotations
|
|
4
|
+
|
|
5
|
+
from unittest.mock import Mock, patch
|
|
6
|
+
|
|
7
|
+
import pytest
|
|
8
|
+
|
|
9
|
+
from firefighter.jira_app.client import JiraClient
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
@pytest.fixture
|
|
13
|
+
def mock_jira_api():
|
|
14
|
+
"""Create a mock JIRA API object."""
|
|
15
|
+
return Mock()
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
@pytest.fixture
|
|
19
|
+
def jira_client(mock_jira_api):
|
|
20
|
+
"""Create a JiraClient with mocked JIRA API."""
|
|
21
|
+
with patch("firefighter.jira_app.client.JIRA", return_value=mock_jira_api):
|
|
22
|
+
client = JiraClient()
|
|
23
|
+
client.jira = mock_jira_api
|
|
24
|
+
return client
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
"""Tests for JiraClient.get_watchers_from_jira_ticket method."""
|
|
2
|
+
|
|
3
|
+
from __future__ import annotations
|
|
4
|
+
|
|
5
|
+
from unittest.mock import Mock
|
|
6
|
+
|
|
7
|
+
import pytest
|
|
8
|
+
from jira.exceptions import JIRAError
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
@pytest.mark.django_db
|
|
12
|
+
class TestGetWatchersFromJiraTicket:
|
|
13
|
+
"""Test get_watchers_from_jira_ticket method."""
|
|
14
|
+
|
|
15
|
+
def test_get_watchers_success_with_watchers(self, jira_client, mock_jira_api):
|
|
16
|
+
"""Test successful retrieval of watchers when watchers exist."""
|
|
17
|
+
# Given
|
|
18
|
+
mock_watchers_response = Mock()
|
|
19
|
+
mock_watchers_response.raw = {
|
|
20
|
+
"watchers": [
|
|
21
|
+
{"accountId": "user1", "displayName": "User One"},
|
|
22
|
+
{"accountId": "user2", "displayName": "User Two"},
|
|
23
|
+
]
|
|
24
|
+
}
|
|
25
|
+
mock_jira_api.watchers.return_value = mock_watchers_response
|
|
26
|
+
|
|
27
|
+
# When
|
|
28
|
+
result = jira_client.get_watchers_from_jira_ticket(12345)
|
|
29
|
+
|
|
30
|
+
# Then
|
|
31
|
+
mock_jira_api.watchers.assert_called_once_with(12345)
|
|
32
|
+
assert len(result) == 2
|
|
33
|
+
assert result[0]["accountId"] == "user1"
|
|
34
|
+
assert result[1]["accountId"] == "user2"
|
|
35
|
+
|
|
36
|
+
def test_get_watchers_success_empty_list(
|
|
37
|
+
self, jira_client, mock_jira_api, caplog
|
|
38
|
+
):
|
|
39
|
+
"""Test successful retrieval when no watchers exist."""
|
|
40
|
+
# Given
|
|
41
|
+
mock_watchers_response = Mock()
|
|
42
|
+
mock_watchers_response.raw = {"watchers": []}
|
|
43
|
+
mock_jira_api.watchers.return_value = mock_watchers_response
|
|
44
|
+
|
|
45
|
+
# When
|
|
46
|
+
result = jira_client.get_watchers_from_jira_ticket(12345)
|
|
47
|
+
|
|
48
|
+
# Then
|
|
49
|
+
mock_jira_api.watchers.assert_called_once_with(12345)
|
|
50
|
+
assert result == []
|
|
51
|
+
# Should log debug message
|
|
52
|
+
assert "No watchers found for jira_issue_id '12345'" in caplog.text
|
|
53
|
+
|
|
54
|
+
def test_get_watchers_404_ticket_not_found(
|
|
55
|
+
self, jira_client, mock_jira_api, caplog
|
|
56
|
+
):
|
|
57
|
+
"""Test handling of 404 error when ticket doesn't exist."""
|
|
58
|
+
# Given
|
|
59
|
+
jira_error = JIRAError(
|
|
60
|
+
status_code=404,
|
|
61
|
+
text="Issue does not exist or you do not have permission to see it.",
|
|
62
|
+
url="https://jira.example.com/rest/api/2/issue/404295/watchers",
|
|
63
|
+
)
|
|
64
|
+
mock_jira_api.watchers.side_effect = jira_error
|
|
65
|
+
|
|
66
|
+
# When
|
|
67
|
+
result = jira_client.get_watchers_from_jira_ticket(404295)
|
|
68
|
+
|
|
69
|
+
# Then
|
|
70
|
+
mock_jira_api.watchers.assert_called_once_with(404295)
|
|
71
|
+
assert result == []
|
|
72
|
+
# Should log warning
|
|
73
|
+
assert (
|
|
74
|
+
"Jira ticket 404295 not found or no permission to access it"
|
|
75
|
+
in caplog.text
|
|
76
|
+
)
|
|
77
|
+
|
|
78
|
+
def test_get_watchers_404_no_permission(self, jira_client, mock_jira_api, caplog):
|
|
79
|
+
"""Test handling of 404 error when bot has no permission."""
|
|
80
|
+
# Given
|
|
81
|
+
jira_error = JIRAError(
|
|
82
|
+
status_code=404,
|
|
83
|
+
text="Issue does not exist or you do not have permission to see it.",
|
|
84
|
+
url="https://jira.example.com/rest/api/2/issue/999999/watchers",
|
|
85
|
+
)
|
|
86
|
+
mock_jira_api.watchers.side_effect = jira_error
|
|
87
|
+
|
|
88
|
+
# When
|
|
89
|
+
result = jira_client.get_watchers_from_jira_ticket("999999")
|
|
90
|
+
|
|
91
|
+
# Then
|
|
92
|
+
assert result == []
|
|
93
|
+
assert "not found or no permission" in caplog.text
|
|
94
|
+
|
|
95
|
+
def test_get_watchers_other_jira_error_raised(self, jira_client, mock_jira_api):
|
|
96
|
+
"""Test that non-404 JIRA errors are re-raised."""
|
|
97
|
+
# Given
|
|
98
|
+
jira_error = JIRAError(
|
|
99
|
+
status_code=500, text="Internal Server Error", url="https://jira.example.com"
|
|
100
|
+
)
|
|
101
|
+
mock_jira_api.watchers.side_effect = jira_error
|
|
102
|
+
|
|
103
|
+
# When / Then
|
|
104
|
+
with pytest.raises(JIRAError) as exc_info:
|
|
105
|
+
jira_client.get_watchers_from_jira_ticket(12345)
|
|
106
|
+
|
|
107
|
+
assert exc_info.value.status_code == 500
|
|
108
|
+
|
|
109
|
+
def test_get_watchers_403_error_raised(self, jira_client, mock_jira_api):
|
|
110
|
+
"""Test that 403 (Forbidden) errors are re-raised."""
|
|
111
|
+
# Given
|
|
112
|
+
jira_error = JIRAError(
|
|
113
|
+
status_code=403, text="Forbidden", url="https://jira.example.com"
|
|
114
|
+
)
|
|
115
|
+
mock_jira_api.watchers.side_effect = jira_error
|
|
116
|
+
|
|
117
|
+
# When / Then
|
|
118
|
+
with pytest.raises(JIRAError) as exc_info:
|
|
119
|
+
jira_client.get_watchers_from_jira_ticket(12345)
|
|
120
|
+
|
|
121
|
+
assert exc_info.value.status_code == 403
|
|
122
|
+
|
|
123
|
+
def test_get_watchers_with_string_id(self, jira_client, mock_jira_api):
|
|
124
|
+
"""Test get_watchers with string issue ID."""
|
|
125
|
+
# Given
|
|
126
|
+
mock_watchers_response = Mock()
|
|
127
|
+
mock_watchers_response.raw = {"watchers": [{"accountId": "user1"}]}
|
|
128
|
+
mock_jira_api.watchers.return_value = mock_watchers_response
|
|
129
|
+
|
|
130
|
+
# When
|
|
131
|
+
result = jira_client.get_watchers_from_jira_ticket("INCIDENT-123")
|
|
132
|
+
|
|
133
|
+
# Then
|
|
134
|
+
mock_jira_api.watchers.assert_called_once_with("INCIDENT-123")
|
|
135
|
+
assert len(result) == 1
|
|
@@ -553,3 +553,58 @@ class TestGetInternalAlertConversations:
|
|
|
553
553
|
|
|
554
554
|
# Then
|
|
555
555
|
assert conversation in result
|
|
556
|
+
|
|
557
|
+
|
|
558
|
+
@pytest.mark.django_db
|
|
559
|
+
class TestAlertSlackNewJiraTicketSlackApiError:
|
|
560
|
+
"""Test SlackApiError handling in alert_slack_new_jira_ticket."""
|
|
561
|
+
|
|
562
|
+
@pytest.fixture(autouse=True)
|
|
563
|
+
def setup(self):
|
|
564
|
+
"""Set up test fixtures."""
|
|
565
|
+
self.user = UserFactory()
|
|
566
|
+
self.jira_user = JiraUser.objects.create(id="jira-slack-error", user=self.user)
|
|
567
|
+
self.jira_ticket = JiraTicket.objects.create(
|
|
568
|
+
id=88888,
|
|
569
|
+
key="SLACK-888",
|
|
570
|
+
summary="Slack error ticket",
|
|
571
|
+
reporter=self.jira_user,
|
|
572
|
+
)
|
|
573
|
+
|
|
574
|
+
@patch("firefighter.raid.forms.get_partner_alert_conversations")
|
|
575
|
+
@patch("firefighter.raid.forms.get_internal_alert_conversations")
|
|
576
|
+
@patch("firefighter.raid.forms.SlackMessageRaidCreatedIssue")
|
|
577
|
+
def test_alert_slack_new_jira_ticket_slack_api_error_on_channel_send(
|
|
578
|
+
self, mock_message_class, mock_get_internal, mock_get_partner, caplog
|
|
579
|
+
):
|
|
580
|
+
"""Test SlackApiError when sending to channel - should log exception and continue."""
|
|
581
|
+
# Given: Create a conversation that will fail to send
|
|
582
|
+
channel = Conversation.objects.create(
|
|
583
|
+
channel_id="C_FAIL_TEST",
|
|
584
|
+
name="fail-channel-test",
|
|
585
|
+
tag="raid_alert__test_fail",
|
|
586
|
+
)
|
|
587
|
+
mock_get_internal.return_value = Conversation.objects.filter(id=channel.id)
|
|
588
|
+
mock_get_partner.return_value = Conversation.objects.none()
|
|
589
|
+
|
|
590
|
+
# Mock message
|
|
591
|
+
mock_message = Mock()
|
|
592
|
+
mock_message_class.return_value = mock_message
|
|
593
|
+
|
|
594
|
+
# Mock channel.send_message_and_save to raise SlackApiError
|
|
595
|
+
with patch.object(
|
|
596
|
+
Conversation,
|
|
597
|
+
"send_message_and_save",
|
|
598
|
+
side_effect=SlackApiError(
|
|
599
|
+
message="channel_not_found",
|
|
600
|
+
response={"error": "channel_not_found"}
|
|
601
|
+
)
|
|
602
|
+
):
|
|
603
|
+
# When
|
|
604
|
+
alert_slack_new_jira_ticket(self.jira_ticket)
|
|
605
|
+
|
|
606
|
+
# Then
|
|
607
|
+
# Should log exception about not being able to send
|
|
608
|
+
assert "Couldn't send message to channel" in caplog.text
|
|
609
|
+
assert str(self.jira_ticket.id) in caplog.text
|
|
610
|
+
# Function should continue and not raise
|
|
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.19 → firefighter_incident-0.0.21}/firefighter/api/authentication.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/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.19 → firefighter_incident-0.0.21}/firefighter/api/views/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/components.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/environments.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/incident_costs.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/incidents.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/api/views/severities.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/avatar/avatar.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/card/__init__.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/card/card.html
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/card/card.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/form/__init__.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/form/form.html
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/form/form.py
RENAMED
|
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.19 → firefighter_incident-0.0.21}/firefighter/components/modal/__init__.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/modal/modal.html
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/components/modal/modal.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/client.py
RENAMED
|
File without changes
|
|
File without changes
|
|
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.19 → firefighter_incident-0.0.21}/firefighter/confluence/models.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/serializers.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/service.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/tables.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/tasks/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
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.19 → firefighter_incident-0.0.21}/firefighter/confluence/views/__init__.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/confluence/views/api.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/__init__.py
RENAMED
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/admin.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/celery_client.py
RENAMED
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/filters.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/http_client.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{firefighter_incident-0.0.19 → firefighter_incident-0.0.21}/firefighter/firefighter/middleware.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
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.19 → firefighter_incident-0.0.21}/firefighter/firefighter/tables_utils.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|