firefighter-incident 0.0.29__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.29/.gitignore +161 -0
- firefighter_incident-0.0.29/LICENSE +21 -0
- firefighter_incident-0.0.29/PKG-INFO +111 -0
- firefighter_incident-0.0.29/README.md +29 -0
- firefighter_incident-0.0.29/firefighter/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/_version.py +34 -0
- firefighter_incident-0.0.29/firefighter/api/__init__.py +4 -0
- firefighter_incident-0.0.29/firefighter/api/admin.py +124 -0
- firefighter_incident-0.0.29/firefighter/api/apps.py +9 -0
- firefighter_incident-0.0.29/firefighter/api/authentication.py +20 -0
- firefighter_incident-0.0.29/firefighter/api/migrations/0001_initial.py +49 -0
- firefighter_incident-0.0.29/firefighter/api/migrations/0002_alter_apitokenproxy_options.py +28 -0
- firefighter_incident-0.0.29/firefighter/api/migrations/0003_alter_apitokenproxy_options.py +30 -0
- firefighter_incident-0.0.29/firefighter/api/migrations/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/api/models.py +45 -0
- firefighter_incident-0.0.29/firefighter/api/permissions.py +18 -0
- firefighter_incident-0.0.29/firefighter/api/renderer.py +115 -0
- firefighter_incident-0.0.29/firefighter/api/serializers.py +320 -0
- firefighter_incident-0.0.29/firefighter/api/urls.py +80 -0
- firefighter_incident-0.0.29/firefighter/api/views/__init__.py +13 -0
- firefighter_incident-0.0.29/firefighter/api/views/_base.py +80 -0
- firefighter_incident-0.0.29/firefighter/api/views/components.py +10 -0
- firefighter_incident-0.0.29/firefighter/api/views/environments.py +10 -0
- firefighter_incident-0.0.29/firefighter/api/views/groups.py +10 -0
- firefighter_incident-0.0.29/firefighter/api/views/incident_cost_types.py +10 -0
- firefighter_incident-0.0.29/firefighter/api/views/incident_costs.py +10 -0
- firefighter_incident-0.0.29/firefighter/api/views/incidents.py +266 -0
- firefighter_incident-0.0.29/firefighter/api/views/severities.py +10 -0
- firefighter_incident-0.0.29/firefighter/components/__init__.py +11 -0
- firefighter_incident-0.0.29/firefighter/components/avatar/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/components/avatar/avatar.html +11 -0
- firefighter_incident-0.0.29/firefighter/components/avatar/avatar.py +37 -0
- firefighter_incident-0.0.29/firefighter/components/card/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/components/card/card.html +17 -0
- firefighter_incident-0.0.29/firefighter/components/card/card.py +21 -0
- firefighter_incident-0.0.29/firefighter/components/export_button/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/components/export_button/export_button.html +33 -0
- firefighter_incident-0.0.29/firefighter/components/export_button/export_button.py +60 -0
- firefighter_incident-0.0.29/firefighter/components/form/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/components/form/form.html +18 -0
- firefighter_incident-0.0.29/firefighter/components/form/form.py +26 -0
- firefighter_incident-0.0.29/firefighter/components/form_field/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/components/form_field/form_field.html +18 -0
- firefighter_incident-0.0.29/firefighter/components/form_field/form_field.py +33 -0
- firefighter_incident-0.0.29/firefighter/components/messages/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/components/messages/messages.html +42 -0
- firefighter_incident-0.0.29/firefighter/components/messages/messages.py +21 -0
- firefighter_incident-0.0.29/firefighter/components/modal/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/components/modal/modal.html +59 -0
- firefighter_incident-0.0.29/firefighter/components/modal/modal.py +35 -0
- firefighter_incident-0.0.29/firefighter/confluence/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/confluence/admin.py +52 -0
- firefighter_incident-0.0.29/firefighter/confluence/apps.py +15 -0
- firefighter_incident-0.0.29/firefighter/confluence/client.py +192 -0
- firefighter_incident-0.0.29/firefighter/confluence/management/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/confluence/management/commands/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/confluence/management/commands/sort_postmortems.py +25 -0
- firefighter_incident-0.0.29/firefighter/confluence/management/commands/sort_runbooks.py +23 -0
- firefighter_incident-0.0.29/firefighter/confluence/management/commands/sync_postmortems.py +16 -0
- firefighter_incident-0.0.29/firefighter/confluence/management/commands/sync_runbooks.py +14 -0
- firefighter_incident-0.0.29/firefighter/confluence/migrations/0001_initial_oss.py +104 -0
- firefighter_incident-0.0.29/firefighter/confluence/migrations/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/confluence/models.py +266 -0
- firefighter_incident-0.0.29/firefighter/confluence/serializers.py +11 -0
- firefighter_incident-0.0.29/firefighter/confluence/service.py +336 -0
- firefighter_incident-0.0.29/firefighter/confluence/signals/__init__.py +3 -0
- firefighter_incident-0.0.29/firefighter/confluence/signals/incident_updated.py +36 -0
- firefighter_incident-0.0.29/firefighter/confluence/tables.py +22 -0
- firefighter_incident-0.0.29/firefighter/confluence/tasks/__init__.py +9 -0
- firefighter_incident-0.0.29/firefighter/confluence/tasks/archive_postmortems.py +228 -0
- firefighter_incident-0.0.29/firefighter/confluence/tasks/sort_runbooks.py +85 -0
- firefighter_incident-0.0.29/firefighter/confluence/tasks/sync_pages_content.py +34 -0
- firefighter_incident-0.0.29/firefighter/confluence/tasks/sync_postmortems.py +71 -0
- firefighter_incident-0.0.29/firefighter/confluence/tasks/sync_runbooks.py +88 -0
- firefighter_incident-0.0.29/firefighter/confluence/templates/oncall_team.xml +6 -0
- firefighter_incident-0.0.29/firefighter/confluence/templates/pages/runbook_list.html +19 -0
- firefighter_incident-0.0.29/firefighter/confluence/urls.py +22 -0
- firefighter_incident-0.0.29/firefighter/confluence/utils.py +106 -0
- firefighter_incident-0.0.29/firefighter/confluence/views/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/confluence/views/api.py +10 -0
- firefighter_incident-0.0.29/firefighter/confluence/views/postmortem/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/confluence/views/postmortem/postmortem_detail.py +0 -0
- firefighter_incident-0.0.29/firefighter/confluence/views/runbook/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/confluence/views/runbook/runbook_list.py +46 -0
- firefighter_incident-0.0.29/firefighter/firefighter/__init__.py +26 -0
- firefighter_incident-0.0.29/firefighter/firefighter/admin.py +12 -0
- firefighter_incident-0.0.29/firefighter/firefighter/apps.py +50 -0
- firefighter_incident-0.0.29/firefighter/firefighter/asgi.py +17 -0
- firefighter_incident-0.0.29/firefighter/firefighter/celery_client.py +40 -0
- firefighter_incident-0.0.29/firefighter/firefighter/fields_forms_widgets.py +92 -0
- firefighter_incident-0.0.29/firefighter/firefighter/filters.py +145 -0
- firefighter_incident-0.0.29/firefighter/firefighter/formats/__init__.py +1 -0
- firefighter_incident-0.0.29/firefighter/firefighter/formats/en/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/firefighter/formats/en/formats.py +5 -0
- firefighter_incident-0.0.29/firefighter/firefighter/http_client.py +54 -0
- firefighter_incident-0.0.29/firefighter/firefighter/management/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/firefighter/management/commands/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/firefighter/management/commands/task.py +35 -0
- firefighter_incident-0.0.29/firefighter/firefighter/middleware.py +35 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/__init__.py +54 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/components/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/components/api.py +173 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/components/caches.py +41 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/components/celery.py +39 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/components/common.py +313 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/components/confluence.py +43 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/components/jira_app.py +54 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/components/logging.py +105 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/components/pagerduty.py +17 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/components/raid.py +25 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/components/slack.py +53 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/environments/__init__.py +3 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/environments/dev.py +202 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/environments/prod.py +62 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/settings_builder.py +41 -0
- firefighter_incident-0.0.29/firefighter/firefighter/settings/settings_utils.py +25 -0
- firefighter_incident-0.0.29/firefighter/firefighter/sso.py +44 -0
- firefighter_incident-0.0.29/firefighter/firefighter/tables_utils.py +19 -0
- firefighter_incident-0.0.29/firefighter/firefighter/templates/admin/base.html +107 -0
- firefighter_incident-0.0.29/firefighter/firefighter/templates/admin/login.html +14 -0
- firefighter_incident-0.0.29/firefighter/firefighter/templates/admin/send_message_conversation.html +45 -0
- firefighter_incident-0.0.29/firefighter/firefighter/templates/robots.txt +2 -0
- firefighter_incident-0.0.29/firefighter/firefighter/urls.py +112 -0
- firefighter_incident-0.0.29/firefighter/firefighter/utils.py +90 -0
- firefighter_incident-0.0.29/firefighter/firefighter/views.py +71 -0
- firefighter_incident-0.0.29/firefighter/firefighter/wsgi.py +23 -0
- firefighter_incident-0.0.29/firefighter/incidents/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/admin.py +744 -0
- firefighter_incident-0.0.29/firefighter/incidents/apps.py +13 -0
- firefighter_incident-0.0.29/firefighter/incidents/enums.py +52 -0
- firefighter_incident-0.0.29/firefighter/incidents/factories.py +102 -0
- firefighter_incident-0.0.29/firefighter/incidents/forms/__init__.py +3 -0
- firefighter_incident-0.0.29/firefighter/incidents/forms/close_incident.py +38 -0
- firefighter_incident-0.0.29/firefighter/incidents/forms/closure_reason.py +45 -0
- firefighter_incident-0.0.29/firefighter/incidents/forms/create_incident.py +92 -0
- firefighter_incident-0.0.29/firefighter/incidents/forms/edit.py +35 -0
- firefighter_incident-0.0.29/firefighter/incidents/forms/select_impact.py +116 -0
- firefighter_incident-0.0.29/firefighter/incidents/forms/unified_incident.py +530 -0
- firefighter_incident-0.0.29/firefighter/incidents/forms/update_key_events.py +115 -0
- firefighter_incident-0.0.29/firefighter/incidents/forms/update_roles.py +95 -0
- firefighter_incident-0.0.29/firefighter/incidents/forms/update_status.py +158 -0
- firefighter_incident-0.0.29/firefighter/incidents/forms/utils.py +111 -0
- firefighter_incident-0.0.29/firefighter/incidents/management/__init__.py +1 -0
- firefighter_incident-0.0.29/firefighter/incidents/management/commands/__init__.py +1 -0
- firefighter_incident-0.0.29/firefighter/incidents/management/commands/backdate_incident_mitigated.py +94 -0
- firefighter_incident-0.0.29/firefighter/incidents/management/commands/test_postmortem_reminders.py +113 -0
- firefighter_incident-0.0.29/firefighter/incidents/menus.py +163 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0001_initial_oss.py +1617 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0002_alter_severity_name_alter_user_password_featureteam.py +35 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0003_delete_featureteam.py +16 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0004_incidentupdate_environment.py +27 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0005_enable_from_p1_to_p5_priority.py +32 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0006_update_group_names.py +102 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0007_update_component_name.py +148 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0008_impact_level.py +305 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0009_update_sla.py +32 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0010_update_components.py +102 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0011_update_incidents.py +87 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0012_alter_impactlevel.py +42 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0013_add_missing_component.py +61 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0014_update_components_slack_groups.py +177 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0015_update_impact_level.py +136 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0016_update_business_incidents_and_level.py +84 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0017_reorder_impact_types.py +28 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0018_update_impactlevel_names.py +48 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0019_set_security_components_private.py +67 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0020_create_incident_category_model.py +64 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0021_copy_component_data_to_incident_category.py +57 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0022_add_incident_category_fields.py +34 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0023_populate_incident_category_references.py +57 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0024_remove_component_fields_and_model.py +26 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0025_make_incident_category_required.py +24 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0026_alter_incidentcategory_options_and_more.py +39 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0027_add_closure_fields.py +40 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0028_add_closure_reason_constraint.py +33 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0029_add_custom_fields_to_incident.py +22 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/0030_add_mitigated_at_field.py +22 -0
- firefighter_incident-0.0.29/firefighter/incidents/migrations/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/__init__.py +15 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/environment.py +26 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/group.py +21 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/impact.py +157 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/incident.py +787 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/incident_category.py +224 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/incident_cost.py +48 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/incident_cost_type.py +27 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/incident_membership.py +58 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/incident_role_type.py +65 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/incident_update.py +145 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/metric_type.py +89 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/milestone_type.py +65 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/priority.py +65 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/severity.py +56 -0
- firefighter_incident-0.0.29/firefighter/incidents/models/user.py +94 -0
- firefighter_incident-0.0.29/firefighter/incidents/signals.py +73 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/css/incident.css +171 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/css/main.css +2 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/css/main.min.css +1 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/css/tailwind.css +53 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/favicon/android-chrome-192x192.png +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/favicon/android-chrome-512x512.png +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/favicon/apple-touch-icon.png +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/favicon/favicon-16x16.png +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/favicon/favicon-32x32.png +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/favicon/favicon.ico +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/favicon/site.webmanifest +1 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/gameday.png +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/logo-firefighter.png +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/p1.png +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/p2.png +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/p3.png +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/p4.png +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/img/p5.png +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/js/main.js +24 -0
- firefighter_incident-0.0.29/firefighter/incidents/static/js/main.min.js +15 -0
- firefighter_incident-0.0.29/firefighter/incidents/tables.py +104 -0
- firefighter_incident-0.0.29/firefighter/incidents/tasks/__init__.py +3 -0
- firefighter_incident-0.0.29/firefighter/incidents/tasks/updateoncall.py +113 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/incidents/errors/base.html +22 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/incidents/filter.html +80 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/incidents/table/priority_column.html +8 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/incidents/table/status_column.html +1 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/incidents/table.html +56 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/incidents/widgets/form_container.html +90 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/incidents/widgets/grouped_checkbox_nested.html +97 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/incidents/widgets/input_option.html +4 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/index.html +25 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/created_at_help.html +57 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/environment_pill.html +11 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/footer.html +31 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/header.html +99 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/incident_card.html +28 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/incident_metrics.html +25 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/incident_timeline.html +146 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/incident_update_key_events_view.html +13 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/incident_update_key_events_view_modal.html +20 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/partial_table_list_paginated.html +107 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/priority_icon.html +14 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/priority_pill.html +4 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/status_pill.html +18 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/table.html +30 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/user_card.html +13 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/partials/user_tooltip.html +13 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/layouts/view_filters.html +30 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/pages/dashboard.html +40 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/pages/docs_metrics.html +86 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/pages/incident_category_detail.html +92 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/pages/incident_category_list.html +20 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/pages/incident_create.html +52 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/pages/incident_detail.html +239 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/pages/incident_list.html +29 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/pages/incident_role_types_detail.html +86 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/pages/incident_role_types_list.html +32 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/pages/incident_statistics.html +124 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/pages/incident_statistics_partial.html +117 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/pages/incident_update_key_events_form.html +16 -0
- firefighter_incident-0.0.29/firefighter/incidents/templates/pages/user_detail.html +110 -0
- firefighter_incident-0.0.29/firefighter/incidents/urls.py +67 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/components/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/components/details.py +33 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/components/list.py +63 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/date_filter.py +166 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/date_utils.py +189 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/docs/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/docs/metrics.py +47 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/docs/role_types.py +36 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/errors.py +248 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/reports.py +564 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/users/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/users/details.py +57 -0
- firefighter_incident-0.0.29/firefighter/incidents/views/views.py +311 -0
- firefighter_incident-0.0.29/firefighter/jira_app/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/jira_app/admin.py +38 -0
- firefighter_incident-0.0.29/firefighter/jira_app/apps.py +18 -0
- firefighter_incident-0.0.29/firefighter/jira_app/client.py +613 -0
- firefighter_incident-0.0.29/firefighter/jira_app/management/__init__.py +1 -0
- firefighter_incident-0.0.29/firefighter/jira_app/management/commands/__init__.py +1 -0
- firefighter_incident-0.0.29/firefighter/jira_app/migrations/0001_initial_oss.py +84 -0
- firefighter_incident-0.0.29/firefighter/jira_app/migrations/0002_add_jira_postmortem_model.py +71 -0
- firefighter_incident-0.0.29/firefighter/jira_app/migrations/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/jira_app/models.py +111 -0
- firefighter_incident-0.0.29/firefighter/jira_app/service_postmortem.py +306 -0
- firefighter_incident-0.0.29/firefighter/jira_app/signals/__init__.py +10 -0
- firefighter_incident-0.0.29/firefighter/jira_app/signals/incident_key_events_updated.py +88 -0
- firefighter_incident-0.0.29/firefighter/jira_app/signals/postmortem_created.py +217 -0
- firefighter_incident-0.0.29/firefighter/jira_app/tasks/__init__.py +3 -0
- firefighter_incident-0.0.29/firefighter/jira_app/tasks/sync_users_jira.py +47 -0
- firefighter_incident-0.0.29/firefighter/jira_app/templates/jira/postmortem/impact.txt +17 -0
- firefighter_incident-0.0.29/firefighter/jira_app/templates/jira/postmortem/incident_summary.txt +17 -0
- firefighter_incident-0.0.29/firefighter/jira_app/templates/jira/postmortem/mitigation_actions.txt +9 -0
- firefighter_incident-0.0.29/firefighter/jira_app/templates/jira/postmortem/root_causes.txt +12 -0
- firefighter_incident-0.0.29/firefighter/jira_app/templates/jira/postmortem/timeline.txt +7 -0
- firefighter_incident-0.0.29/firefighter/jira_app/types.py +44 -0
- firefighter_incident-0.0.29/firefighter/jira_app/utils.py +112 -0
- firefighter_incident-0.0.29/firefighter/logging/__init__.py +1 -0
- firefighter_incident-0.0.29/firefighter/logging/custom_json_formatter.py +160 -0
- firefighter_incident-0.0.29/firefighter/logging/pretty_formatter.py +73 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/admin.py +139 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/apps.py +17 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/client.py +67 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/forms/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/forms/create_pagerduty_incident.py +43 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/migrations/0001_initial_oss.py +463 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/migrations/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/models.py +454 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/service.py +78 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/signals/__init__.py +12 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/signals/get_invites_from_pagerduty.py +24 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/signals/incident_channel_done_oncall.py +26 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/tasks/__init__.py +7 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/tasks/fetch_oncall.py +107 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/tasks/fetch_services.py +35 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/tasks/fetch_users.py +66 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/tasks/trigger_oncall.py +94 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/templates/pages/oncall_list.html +84 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/templates/pages/oncall_trigger.html +16 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/templates/partials/trigger_oncall_form_view.html +14 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/templates/partials/trigger_oncall_form_view_modal.html +19 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/urls.py +16 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/views/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/views/oncall_list.py +30 -0
- firefighter_incident-0.0.29/firefighter/pagerduty/views/oncall_trigger.py +64 -0
- firefighter_incident-0.0.29/firefighter/raid/__init__.py +6 -0
- firefighter_incident-0.0.29/firefighter/raid/admin.py +40 -0
- firefighter_incident-0.0.29/firefighter/raid/apps.py +37 -0
- firefighter_incident-0.0.29/firefighter/raid/client.py +220 -0
- firefighter_incident-0.0.29/firefighter/raid/forms.py +330 -0
- firefighter_incident-0.0.29/firefighter/raid/messages.py +155 -0
- firefighter_incident-0.0.29/firefighter/raid/migrations/0001_initial_oss.py +175 -0
- firefighter_incident-0.0.29/firefighter/raid/migrations/0002_featureteam_remove_qualifierrotation_jira_user_and_more.py +36 -0
- firefighter_incident-0.0.29/firefighter/raid/migrations/0003_delete_raidarea.py +16 -0
- firefighter_incident-0.0.29/firefighter/raid/migrations/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/raid/models.py +83 -0
- firefighter_incident-0.0.29/firefighter/raid/resources.py +15 -0
- firefighter_incident-0.0.29/firefighter/raid/serializers.py +339 -0
- firefighter_incident-0.0.29/firefighter/raid/service.py +268 -0
- firefighter_incident-0.0.29/firefighter/raid/signals/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/raid/signals/incident_updated.py +59 -0
- firefighter_incident-0.0.29/firefighter/raid/tasks/__init__.py +1 -0
- firefighter_incident-0.0.29/firefighter/raid/types.py +23 -0
- firefighter_incident-0.0.29/firefighter/raid/urls.py +33 -0
- firefighter_incident-0.0.29/firefighter/raid/utils.py +42 -0
- firefighter_incident-0.0.29/firefighter/raid/views/__init__.py +134 -0
- firefighter_incident-0.0.29/firefighter/slack/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/slack/admin.py +417 -0
- firefighter_incident-0.0.29/firefighter/slack/apps.py +23 -0
- firefighter_incident-0.0.29/firefighter/slack/factories.py +96 -0
- firefighter_incident-0.0.29/firefighter/slack/forms/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/slack/forms/sos_form.py +11 -0
- firefighter_incident-0.0.29/firefighter/slack/management/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/slack/management/commands/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/slack/management/commands/generate_manifest.py +201 -0
- firefighter_incident-0.0.29/firefighter/slack/management/commands/switch_test_users.py +272 -0
- firefighter_incident-0.0.29/firefighter/slack/messages/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/slack/messages/base.py +129 -0
- firefighter_incident-0.0.29/firefighter/slack/messages/slack_messages.py +1105 -0
- firefighter_incident-0.0.29/firefighter/slack/migrations/0001_initial_oss.py +348 -0
- firefighter_incident-0.0.29/firefighter/slack/migrations/0002_usergroup_tag.py +22 -0
- firefighter_incident-0.0.29/firefighter/slack/migrations/0003_alter_usergroup_tag.py +22 -0
- firefighter_incident-0.0.29/firefighter/slack/migrations/0004_alter_usergroup_components.py +24 -0
- firefighter_incident-0.0.29/firefighter/slack/migrations/0005_add_incident_categories_fields.py +33 -0
- firefighter_incident-0.0.29/firefighter/slack/migrations/0006_copy_components_to_incident_categories.py +57 -0
- firefighter_incident-0.0.29/firefighter/slack/migrations/0007_remove_components_fields.py +22 -0
- firefighter_incident-0.0.29/firefighter/slack/migrations/0008_alter_conversation_incident_categories_and_more.py +33 -0
- firefighter_incident-0.0.29/firefighter/slack/migrations/0009_add_postmortem_reminder_periodic_task.py +60 -0
- firefighter_incident-0.0.29/firefighter/slack/migrations/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/slack/models/__init__.py +7 -0
- firefighter_incident-0.0.29/firefighter/slack/models/conversation.py +461 -0
- firefighter_incident-0.0.29/firefighter/slack/models/incident_channel.py +210 -0
- firefighter_incident-0.0.29/firefighter/slack/models/message.py +138 -0
- firefighter_incident-0.0.29/firefighter/slack/models/sos.py +40 -0
- firefighter_incident-0.0.29/firefighter/slack/models/user.py +462 -0
- firefighter_incident-0.0.29/firefighter/slack/models/user_group.py +198 -0
- firefighter_incident-0.0.29/firefighter/slack/rules.py +76 -0
- firefighter_incident-0.0.29/firefighter/slack/signals/__init__.py +23 -0
- firefighter_incident-0.0.29/firefighter/slack/signals/create_incident_conversation.py +141 -0
- firefighter_incident-0.0.29/firefighter/slack/signals/get_users.py +68 -0
- firefighter_incident-0.0.29/firefighter/slack/signals/handle_incident_channel_done.py +54 -0
- firefighter_incident-0.0.29/firefighter/slack/signals/incident_closed.py +22 -0
- firefighter_incident-0.0.29/firefighter/slack/signals/incident_updated.py +290 -0
- firefighter_incident-0.0.29/firefighter/slack/signals/postmortem_created.py +84 -0
- firefighter_incident-0.0.29/firefighter/slack/signals/roles_reminders.py +111 -0
- firefighter_incident-0.0.29/firefighter/slack/slack_app.py +114 -0
- firefighter_incident-0.0.29/firefighter/slack/slack_incident_context.py +227 -0
- firefighter_incident-0.0.29/firefighter/slack/slack_templating.py +122 -0
- firefighter_incident-0.0.29/firefighter/slack/tasks/__init__.py +9 -0
- firefighter_incident-0.0.29/firefighter/slack/tasks/fetch_conversations_members.py +146 -0
- firefighter_incident-0.0.29/firefighter/slack/tasks/reminder_postmortem.py +74 -0
- firefighter_incident-0.0.29/firefighter/slack/tasks/send_message.py +28 -0
- firefighter_incident-0.0.29/firefighter/slack/tasks/send_postmortem_reminders.py +127 -0
- firefighter_incident-0.0.29/firefighter/slack/tasks/send_reminders.py +118 -0
- firefighter_incident-0.0.29/firefighter/slack/tasks/sync_users.py +67 -0
- firefighter_incident-0.0.29/firefighter/slack/tasks/update_usergroups_members.py +123 -0
- firefighter_incident-0.0.29/firefighter/slack/tasks/update_users.py +22 -0
- firefighter_incident-0.0.29/firefighter/slack/urls.py +10 -0
- firefighter_incident-0.0.29/firefighter/slack/utils.py +145 -0
- firefighter_incident-0.0.29/firefighter/slack/views/__init__.py +18 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/__init__.py +26 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/actions_and_shortcuts.py +51 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/channel_archive.py +26 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/channel_id_changed.py +25 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/channel_rename.py +25 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/channel_shared.py +23 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/channel_unarchive.py +32 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/channel_unshared.py +26 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/commands.py +145 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/home.py +177 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/member_joined_channel.py +67 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/member_left_channel.py +58 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/message.py +68 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/message_deleted.py +29 -0
- firefighter_incident-0.0.29/firefighter/slack/views/events/reaction_added.py +128 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/__init__.py +55 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/base_modal/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/base_modal/base.py +352 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/base_modal/base_mixins.py +9 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/base_modal/form_utils.py +650 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/base_modal/mixins.py +56 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/base_modal/modal_utils.py +86 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/close.py +398 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/closure_reason.py +237 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/downgrade_workflow.py +91 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/edit.py +163 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/key_event_message.py +167 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/open.py +700 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/opening/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/opening/check_current_incidents.py +82 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/opening/details/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/opening/details/unified.py +203 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/opening/select_impact.py +282 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/opening/set_details.py +190 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/opening/types.py +20 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/postmortem.py +147 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/select.py +98 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/send_sos.py +135 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/status.py +113 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/trigger_oncall.py +133 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/update.py +66 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/update_roles.py +76 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/update_status.py +160 -0
- firefighter_incident-0.0.29/firefighter/slack/views/modals/utils.py +51 -0
- firefighter_incident-0.0.29/firefighter/slack/views/views.py +21 -0
- firefighter_incident-0.0.29/firefighter_fixtures/incidents/environments.json +41 -0
- firefighter_incident-0.0.29/firefighter_fixtures/incidents/groups.json +101 -0
- firefighter_incident-0.0.29/firefighter_fixtures/incidents/impact_level.json +255 -0
- firefighter_incident-0.0.29/firefighter_fixtures/incidents/impact_type.json +46 -0
- firefighter_incident-0.0.29/firefighter_fixtures/incidents/incident_categories.json +730 -0
- firefighter_incident-0.0.29/firefighter_fixtures/incidents/incident_role_type.json +32 -0
- firefighter_incident-0.0.29/firefighter_fixtures/incidents/metric_type.json +86 -0
- firefighter_incident-0.0.29/firefighter_fixtures/incidents/milestone_type.json +80 -0
- firefighter_incident-0.0.29/firefighter_fixtures/incidents/priorities.json +116 -0
- firefighter_incident-0.0.29/firefighter_fixtures/incidents/severities.json +92 -0
- firefighter_incident-0.0.29/firefighter_tests/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter_tests/conftest.py +88 -0
- firefighter_incident-0.0.29/firefighter_tests/test_api/test_api_landbot.py +163 -0
- firefighter_incident-0.0.29/firefighter_tests/test_api/test_api_urls.py +60 -0
- firefighter_incident-0.0.29/firefighter_tests/test_api/test_renderer.py +41 -0
- firefighter_incident-0.0.29/firefighter_tests/test_confluence/test_confluence_utils.py +60 -0
- firefighter_incident-0.0.29/firefighter_tests/test_firefighter/test_firefighter_utils.py +117 -0
- firefighter_incident-0.0.29/firefighter_tests/test_firefighter/test_logging.py +29 -0
- firefighter_incident-0.0.29/firefighter_tests/test_firefighter/test_sso.py +146 -0
- firefighter_incident-0.0.29/firefighter_tests/test_firefighter/test_urls.py +150 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_enums.py +100 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_forms/conftest.py +179 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_forms/test_closure_reason.py +91 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_forms/test_form_select_impact.py +104 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_forms/test_form_utils.py +73 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_forms/test_unified_incident_form.py +570 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_forms/test_unified_incident_form_integration.py +718 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_forms/test_unified_incident_form_p4_p5.py +388 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_forms/test_update_key_events.py +53 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_forms/test_update_status_workflow.py +358 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_forms/test_workflow_transitions.py +169 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_incident_urls.py +120 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_models/test_incident_category.py +165 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_models/test_incident_model.py +235 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_models/test_migrations/test_incident_migrations.py +0 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_utils/test_date_utils.py +208 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_views/test_incident_detail_view.py +28 -0
- firefighter_incident-0.0.29/firefighter_tests/test_incidents/test_views/test_index_view.py +27 -0
- firefighter_incident-0.0.29/firefighter_tests/test_jira_app/__init__.py +1 -0
- firefighter_incident-0.0.29/firefighter_tests/test_jira_app/conftest.py +24 -0
- firefighter_incident-0.0.29/firefighter_tests/test_jira_app/test_incident_key_events_sync.py +112 -0
- firefighter_incident-0.0.29/firefighter_tests/test_jira_app/test_jira_client_watchers.py +135 -0
- firefighter_incident-0.0.29/firefighter_tests/test_jira_app/test_models.py +138 -0
- firefighter_incident-0.0.29/firefighter_tests/test_jira_app/test_postmortem_issue_link.py +201 -0
- firefighter_incident-0.0.29/firefighter_tests/test_jira_app/test_postmortem_service.py +416 -0
- firefighter_incident-0.0.29/firefighter_tests/test_jira_app/test_timeline_template.py +135 -0
- firefighter_incident-0.0.29/firefighter_tests/test_raid/conftest.py +154 -0
- firefighter_incident-0.0.29/firefighter_tests/test_raid/test_raid_alert_p4_p5.py +255 -0
- firefighter_incident-0.0.29/firefighter_tests/test_raid/test_raid_client.py +612 -0
- firefighter_incident-0.0.29/firefighter_tests/test_raid/test_raid_client_users.py +120 -0
- firefighter_incident-0.0.29/firefighter_tests/test_raid/test_raid_forms.py +610 -0
- firefighter_incident-0.0.29/firefighter_tests/test_raid/test_raid_models.py +185 -0
- firefighter_incident-0.0.29/firefighter_tests/test_raid/test_raid_serializers.py +554 -0
- firefighter_incident-0.0.29/firefighter_tests/test_raid/test_raid_service.py +442 -0
- firefighter_incident-0.0.29/firefighter_tests/test_raid/test_raid_signals.py +229 -0
- firefighter_incident-0.0.29/firefighter_tests/test_raid/test_raid_transitions.py +145 -0
- firefighter_incident-0.0.29/firefighter_tests/test_raid/test_raid_utils.py +26 -0
- firefighter_incident-0.0.29/firefighter_tests/test_raid/test_raid_views.py +196 -0
- firefighter_incident-0.0.29/firefighter_tests/test_raid/test_zendesk_integration.py +198 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/conftest.py +66 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/messages/__init__.py +0 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/messages/test_slack_messages.py +460 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/test_conversation_tags.py +344 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/test_models/test_conversations.py +26 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/test_models/test_incident_channel.py +496 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/test_models/test_slack_user.py +194 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/test_signals_downgrade.py +147 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/test_slack_utils.py +126 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/views/modals/conftest.py +140 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/views/modals/test_close.py +1044 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/views/modals/test_closure_reason_modal.py +237 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/views/modals/test_edit.py +324 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/views/modals/test_form_utils_multiple_choice.py +249 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/views/modals/test_key_event_message.py +30 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/views/modals/test_open.py +285 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/views/modals/test_opening_unified.py +463 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/views/modals/test_postmortem_modal.py +72 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/views/modals/test_send_sos.py +42 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/views/modals/test_status.py +72 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/views/modals/test_update_status.py +1292 -0
- firefighter_incident-0.0.29/firefighter_tests/test_slack/views/modals/test_utils.py +135 -0
- firefighter_incident-0.0.29/gunicorn.conf.py +15 -0
- firefighter_incident-0.0.29/main.py +53 -0
- firefighter_incident-0.0.29/manage.py +24 -0
- firefighter_incident-0.0.29/package-lock.json +6442 -0
- firefighter_incident-0.0.29/package.json +49 -0
- firefighter_incident-0.0.29/pyproject.toml +598 -0
- firefighter_incident-0.0.29/scripts/gen_credits.py +165 -0
- firefighter_incident-0.0.29/scripts/hatch_build.py +15 -0
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
|
|
2
|
+
# Created by https://www.gitignore.io/api/python
|
|
3
|
+
# Edit at https://www.gitignore.io/?templates=python
|
|
4
|
+
|
|
5
|
+
# Add .git for tools that respect .gitignore
|
|
6
|
+
.git
|
|
7
|
+
|
|
8
|
+
### Python ###
|
|
9
|
+
# Byte-compiled / optimized / DLL files
|
|
10
|
+
__pycache__/
|
|
11
|
+
*.py[cod]
|
|
12
|
+
*$py.class
|
|
13
|
+
|
|
14
|
+
# C extensions
|
|
15
|
+
*.so
|
|
16
|
+
|
|
17
|
+
# Distribution / packaging
|
|
18
|
+
.Python
|
|
19
|
+
build/
|
|
20
|
+
builds/
|
|
21
|
+
develop-eggs/
|
|
22
|
+
dist/
|
|
23
|
+
downloads/
|
|
24
|
+
eggs/
|
|
25
|
+
.eggs/
|
|
26
|
+
lib/
|
|
27
|
+
lib64/
|
|
28
|
+
parts/
|
|
29
|
+
sdist/
|
|
30
|
+
var/
|
|
31
|
+
wheels/
|
|
32
|
+
pip-wheel-metadata/
|
|
33
|
+
share/python-wheels/
|
|
34
|
+
*.egg-info/
|
|
35
|
+
.installed.cfg
|
|
36
|
+
*.egg
|
|
37
|
+
MANIFEST
|
|
38
|
+
|
|
39
|
+
# PyInstaller
|
|
40
|
+
# Usually these files are written by a python script from a template
|
|
41
|
+
# before PyInstaller builds the exe, so as to inject date/other infos into it.
|
|
42
|
+
*.manifest
|
|
43
|
+
*.spec
|
|
44
|
+
|
|
45
|
+
# Installer logs
|
|
46
|
+
pip-log.txt
|
|
47
|
+
pip-delete-this-directory.txt
|
|
48
|
+
|
|
49
|
+
# Unit test / coverage reports
|
|
50
|
+
htmlcov/
|
|
51
|
+
.tox/
|
|
52
|
+
.nox/
|
|
53
|
+
.coverage
|
|
54
|
+
.coverage.*
|
|
55
|
+
.cache
|
|
56
|
+
nosetests.xml
|
|
57
|
+
coverage.xml
|
|
58
|
+
cov.xml
|
|
59
|
+
*.cover
|
|
60
|
+
.hypothesis/
|
|
61
|
+
.pytest_cache/
|
|
62
|
+
|
|
63
|
+
# Translations
|
|
64
|
+
*.mo
|
|
65
|
+
*.pot
|
|
66
|
+
|
|
67
|
+
# Scrapy stuff:
|
|
68
|
+
.scrapy
|
|
69
|
+
|
|
70
|
+
# Sphinx documentation
|
|
71
|
+
docs/_build/
|
|
72
|
+
|
|
73
|
+
# PyBuilder
|
|
74
|
+
target/
|
|
75
|
+
|
|
76
|
+
# pyenv
|
|
77
|
+
.python-version
|
|
78
|
+
|
|
79
|
+
# pipenv
|
|
80
|
+
# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control.
|
|
81
|
+
# However, in case of collaboration, if having platform-specific dependencies or dependencies
|
|
82
|
+
# having no cross-platform support, pipenv may install dependencies that don't work, or not
|
|
83
|
+
# install all needed dependencies.
|
|
84
|
+
#Pipfile.lock
|
|
85
|
+
|
|
86
|
+
# celery beat schedule file
|
|
87
|
+
celerybeat-schedule
|
|
88
|
+
|
|
89
|
+
# SageMath parsed files
|
|
90
|
+
*.sage.py
|
|
91
|
+
|
|
92
|
+
# Spyder project settings
|
|
93
|
+
.spyderproject
|
|
94
|
+
.spyproject
|
|
95
|
+
|
|
96
|
+
# Rope project settings
|
|
97
|
+
.ropeproject
|
|
98
|
+
|
|
99
|
+
# Mr Developer
|
|
100
|
+
.mr.developer.cfg
|
|
101
|
+
.project
|
|
102
|
+
.pydevproject
|
|
103
|
+
|
|
104
|
+
# mkdocs documentation
|
|
105
|
+
/site
|
|
106
|
+
|
|
107
|
+
# mypy
|
|
108
|
+
.mypy_cache/
|
|
109
|
+
.dmypy.json
|
|
110
|
+
dmypy.json
|
|
111
|
+
|
|
112
|
+
# Ruff
|
|
113
|
+
.ruff_cache
|
|
114
|
+
|
|
115
|
+
# Pyre type checker
|
|
116
|
+
.pyre/
|
|
117
|
+
|
|
118
|
+
# End of https://www.gitignore.io/api/python
|
|
119
|
+
|
|
120
|
+
# Secrets
|
|
121
|
+
.env
|
|
122
|
+
|
|
123
|
+
# Sonarscanner local config / cache
|
|
124
|
+
.scannerwork
|
|
125
|
+
sonar-project.properties
|
|
126
|
+
|
|
127
|
+
# IDEs
|
|
128
|
+
# Create your own workspace in VS Code!
|
|
129
|
+
*.code-workspace
|
|
130
|
+
.idea
|
|
131
|
+
|
|
132
|
+
# Poetry / PDM local configs (contains local paths)
|
|
133
|
+
poetry.toml
|
|
134
|
+
.pdm-python
|
|
135
|
+
.pdm.toml
|
|
136
|
+
|
|
137
|
+
# Virtual envs
|
|
138
|
+
venv
|
|
139
|
+
.venv
|
|
140
|
+
|
|
141
|
+
# Pytest artifacts
|
|
142
|
+
pytest-report.xml
|
|
143
|
+
pytest-coverage.xml
|
|
144
|
+
|
|
145
|
+
# Misc
|
|
146
|
+
*.log
|
|
147
|
+
.DS_Store
|
|
148
|
+
*.sqlite3
|
|
149
|
+
**/node_modules
|
|
150
|
+
!/**/.gitkeep
|
|
151
|
+
|
|
152
|
+
# FireFighter / Django specific
|
|
153
|
+
/static/*
|
|
154
|
+
.static
|
|
155
|
+
|
|
156
|
+
**/_version.py
|
|
157
|
+
|
|
158
|
+
|
|
159
|
+
# Minified files
|
|
160
|
+
*.min.js
|
|
161
|
+
*.min.css
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2021-2023 - Colibri SAS, "ManoMano"
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
Metadata-Version: 2.4
|
|
2
|
+
Name: firefighter-incident
|
|
3
|
+
Version: 0.0.29
|
|
4
|
+
Summary: Incident Management tool made for Slack using Django
|
|
5
|
+
Project-URL: Repository, https://github.com/ManoManoTech/firefighter-incident
|
|
6
|
+
Project-URL: Documentation, https://manomanotech.github.io/firefighter-incident/latest/
|
|
7
|
+
Project-URL: Changelog, https://github.com/ManoManoTech/firefighter-incident/releases
|
|
8
|
+
Author-email: Gabriel Dugny <gabriel.dugny@manomano.com>, SRE <teamsre@manomano.com>
|
|
9
|
+
License: MIT License
|
|
10
|
+
|
|
11
|
+
Copyright (c) 2021-2023 - Colibri SAS, "ManoMano"
|
|
12
|
+
|
|
13
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
14
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
15
|
+
in the Software without restriction, including without limitation the rights
|
|
16
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
17
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
18
|
+
furnished to do so, subject to the following conditions:
|
|
19
|
+
|
|
20
|
+
The above copyright notice and this permission notice shall be included in all
|
|
21
|
+
copies or substantial portions of the Software.
|
|
22
|
+
|
|
23
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
24
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
25
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
26
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
27
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
28
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
29
|
+
SOFTWARE.
|
|
30
|
+
License-File: LICENSE
|
|
31
|
+
Classifier: Development Status :: 4 - Beta
|
|
32
|
+
Classifier: Environment :: Web Environment
|
|
33
|
+
Classifier: Framework :: Django
|
|
34
|
+
Classifier: Framework :: Django :: 4.2
|
|
35
|
+
Classifier: Intended Audience :: Developers
|
|
36
|
+
Classifier: Intended Audience :: Information Technology
|
|
37
|
+
Classifier: License :: OSI Approved :: MIT License
|
|
38
|
+
Classifier: Programming Language :: Python :: 3
|
|
39
|
+
Classifier: Programming Language :: Python :: 3 :: Only
|
|
40
|
+
Classifier: Programming Language :: Python :: 3.11
|
|
41
|
+
Classifier: Programming Language :: Python :: 3.12
|
|
42
|
+
Classifier: Typing :: Typed
|
|
43
|
+
Requires-Python: <4.0,>=3.11
|
|
44
|
+
Requires-Dist: aiohttp>=3.9.1
|
|
45
|
+
Requires-Dist: celery[gevent,redis]>=5.3.6
|
|
46
|
+
Requires-Dist: dateparser>=1.2.0
|
|
47
|
+
Requires-Dist: ddtrace<2.4.0,>=2.3.3
|
|
48
|
+
Requires-Dist: django-celery-beat>=2.5.0
|
|
49
|
+
Requires-Dist: django-components>=0.101
|
|
50
|
+
Requires-Dist: django-filter>=23.4
|
|
51
|
+
Requires-Dist: django-htmx>=1.17.2
|
|
52
|
+
Requires-Dist: django-import-export>=4.0.0
|
|
53
|
+
Requires-Dist: django-oauth2-authcodeflow>=1.0.1
|
|
54
|
+
Requires-Dist: django-redis>=5.4.0
|
|
55
|
+
Requires-Dist: django-simple-menu>=2.1.3
|
|
56
|
+
Requires-Dist: django-stubs-ext~=5.1.1
|
|
57
|
+
Requires-Dist: django-tables2>=2.6.0
|
|
58
|
+
Requires-Dist: django-taggit>=5.0.1
|
|
59
|
+
Requires-Dist: django-widget-tweaks>=1.5.0
|
|
60
|
+
Requires-Dist: django[argon2]<5.0.0,>=4.2.8
|
|
61
|
+
Requires-Dist: djangorestframework-csv>=3.0.1
|
|
62
|
+
Requires-Dist: djangorestframework>=3.14.0
|
|
63
|
+
Requires-Dist: docutils>=0.20.1
|
|
64
|
+
Requires-Dist: drf-spectacular>=0.26.5
|
|
65
|
+
Requires-Dist: drf-standardized-errors>=0.12.6
|
|
66
|
+
Requires-Dist: gunicorn>=21.2.0
|
|
67
|
+
Requires-Dist: httpx>=0.25.2
|
|
68
|
+
Requires-Dist: jira<3.6.0,>=3.5.2
|
|
69
|
+
Requires-Dist: markdown>=3.5.1
|
|
70
|
+
Requires-Dist: nh3>=0.2.15
|
|
71
|
+
Requires-Dist: pdpyras>=5.1.3
|
|
72
|
+
Requires-Dist: psycopg[binary]>=3.1.14
|
|
73
|
+
Requires-Dist: python-dateutil>=2.8.2
|
|
74
|
+
Requires-Dist: python-decouple>=3.8
|
|
75
|
+
Requires-Dist: python-json-logger>=2.0.7
|
|
76
|
+
Requires-Dist: slack-bolt>=1.18.1
|
|
77
|
+
Requires-Dist: slack-sdk>=3.26.1
|
|
78
|
+
Requires-Dist: uritemplate>=4.1.1
|
|
79
|
+
Requires-Dist: whitenoise>=6.6.0
|
|
80
|
+
Requires-Dist: wrapt>=1.17.0
|
|
81
|
+
Description-Content-Type: text/markdown
|
|
82
|
+
|
|
83
|
+
# FireFighter
|
|
84
|
+
|
|
85
|
+
[](https://pypi.org/project/firefighter-incident/) [](https://pypi.org/project/firefighter-incident/) [](https://manomanotech.github.io/firefighter-incident/latest/license/) [](https://www.bestpractices.dev/projects/8170) [](https://github.com/pre-commit/pre-commit) [](https://github.com/astral-sh/ruff)
|
|
86
|
+
|
|
87
|
+
FireFighter is ManoMano's in-house Incident Management Tool.
|
|
88
|
+
|
|
89
|
+
It helps manage incidents, by automatically creating a Slack channel for communication, integrating with Jira (with P1-P5 priority mapping), and much more.
|
|
90
|
+
|
|
91
|
+

|
|
92
|
+
|
|
93
|
+
__What's Incident Management?__
|
|
94
|
+
|
|
95
|
+
Incident Management is a set of processes and tools to help teams detect, respond to, and resolve incidents quickly and effectively.
|
|
96
|
+
|
|
97
|
+
Incidents are unplanned interruptions or reductions in quality of services, like a service outage or a security breach.
|
|
98
|
+
|
|
99
|
+
<!--intro-end-->
|
|
100
|
+
|
|
101
|
+
## Learn more
|
|
102
|
+
|
|
103
|
+
Check out our [documentation](https://manomanotech.github.io/firefighter-incident/latest/) for more details.
|
|
104
|
+
|
|
105
|
+
## Contributing
|
|
106
|
+
|
|
107
|
+
See [our Contribution Guide](https://manomanotech.github.io/firefighter-incident/latest/contributing/) for details on submitting patches, the contribution workflow and developer's guide.
|
|
108
|
+
|
|
109
|
+
## License
|
|
110
|
+
|
|
111
|
+
FireFighter is under the MIT license. See the [LICENSE](LICENSE) file for details.
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
# FireFighter
|
|
2
|
+
|
|
3
|
+
[](https://pypi.org/project/firefighter-incident/) [](https://pypi.org/project/firefighter-incident/) [](https://manomanotech.github.io/firefighter-incident/latest/license/) [](https://www.bestpractices.dev/projects/8170) [](https://github.com/pre-commit/pre-commit) [](https://github.com/astral-sh/ruff)
|
|
4
|
+
|
|
5
|
+
FireFighter is ManoMano's in-house Incident Management Tool.
|
|
6
|
+
|
|
7
|
+
It helps manage incidents, by automatically creating a Slack channel for communication, integrating with Jira (with P1-P5 priority mapping), and much more.
|
|
8
|
+
|
|
9
|
+

|
|
10
|
+
|
|
11
|
+
__What's Incident Management?__
|
|
12
|
+
|
|
13
|
+
Incident Management is a set of processes and tools to help teams detect, respond to, and resolve incidents quickly and effectively.
|
|
14
|
+
|
|
15
|
+
Incidents are unplanned interruptions or reductions in quality of services, like a service outage or a security breach.
|
|
16
|
+
|
|
17
|
+
<!--intro-end-->
|
|
18
|
+
|
|
19
|
+
## Learn more
|
|
20
|
+
|
|
21
|
+
Check out our [documentation](https://manomanotech.github.io/firefighter-incident/latest/) for more details.
|
|
22
|
+
|
|
23
|
+
## Contributing
|
|
24
|
+
|
|
25
|
+
See [our Contribution Guide](https://manomanotech.github.io/firefighter-incident/latest/contributing/) for details on submitting patches, the contribution workflow and developer's guide.
|
|
26
|
+
|
|
27
|
+
## License
|
|
28
|
+
|
|
29
|
+
FireFighter is under the MIT license. See the [LICENSE](LICENSE) file for details.
|
|
File without changes
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
# file generated by setuptools-scm
|
|
2
|
+
# don't change, don't track in version control
|
|
3
|
+
|
|
4
|
+
__all__ = [
|
|
5
|
+
"__version__",
|
|
6
|
+
"__version_tuple__",
|
|
7
|
+
"version",
|
|
8
|
+
"version_tuple",
|
|
9
|
+
"__commit_id__",
|
|
10
|
+
"commit_id",
|
|
11
|
+
]
|
|
12
|
+
|
|
13
|
+
TYPE_CHECKING = False
|
|
14
|
+
if TYPE_CHECKING:
|
|
15
|
+
from typing import Tuple
|
|
16
|
+
from typing import Union
|
|
17
|
+
|
|
18
|
+
VERSION_TUPLE = Tuple[Union[int, str], ...]
|
|
19
|
+
COMMIT_ID = Union[str, None]
|
|
20
|
+
else:
|
|
21
|
+
VERSION_TUPLE = object
|
|
22
|
+
COMMIT_ID = object
|
|
23
|
+
|
|
24
|
+
version: str
|
|
25
|
+
__version__: str
|
|
26
|
+
__version_tuple__: VERSION_TUPLE
|
|
27
|
+
version_tuple: VERSION_TUPLE
|
|
28
|
+
commit_id: COMMIT_ID
|
|
29
|
+
__commit_id__: COMMIT_ID
|
|
30
|
+
|
|
31
|
+
__version__ = version = '0.0.29'
|
|
32
|
+
__version_tuple__ = version_tuple = (0, 0, 29)
|
|
33
|
+
|
|
34
|
+
__commit_id__ = commit_id = None
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
import logging
|
|
4
|
+
from typing import TYPE_CHECKING, Any
|
|
5
|
+
|
|
6
|
+
from django.contrib import messages
|
|
7
|
+
from rest_framework.authtoken.admin import TokenAdmin
|
|
8
|
+
from rest_framework.authtoken.models import TokenProxy
|
|
9
|
+
|
|
10
|
+
from firefighter.api.models import APITokenProxy
|
|
11
|
+
from firefighter.firefighter.admin import admin_custom as admin
|
|
12
|
+
from firefighter.incidents.models.user import User
|
|
13
|
+
|
|
14
|
+
logger = logging.getLogger(__name__)
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
if TYPE_CHECKING:
|
|
18
|
+
from django.db.models import ForeignKey
|
|
19
|
+
from django.db.models.query import QuerySet
|
|
20
|
+
from django.forms import ModelChoiceField, ModelForm
|
|
21
|
+
from django.http.request import HttpRequest as BaseHttpRequest
|
|
22
|
+
|
|
23
|
+
class HttpRequest(BaseHttpRequest):
|
|
24
|
+
user: User
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
class APITokenAdmin(TokenAdmin):
|
|
28
|
+
"""Custom Admin for DRF Token.
|
|
29
|
+
Add supports for custom permissions.
|
|
30
|
+
"""
|
|
31
|
+
|
|
32
|
+
def formfield_for_foreignkey(
|
|
33
|
+
self,
|
|
34
|
+
db_field: ForeignKey[Any, Any],
|
|
35
|
+
request: HttpRequest, # type: ignore[override]
|
|
36
|
+
**kwargs: Any,
|
|
37
|
+
) -> ModelChoiceField: # type: ignore[type-arg]
|
|
38
|
+
"""Show all or only current user depending on permissions."""
|
|
39
|
+
if db_field.name == "user":
|
|
40
|
+
if request.user.has_perm("api.can_add_any") or request.user.has_perm(
|
|
41
|
+
"api.can_edit_any"
|
|
42
|
+
):
|
|
43
|
+
kwargs["queryset"] = User.objects.all()
|
|
44
|
+
elif request.user.has_perm("api.can_add_own"):
|
|
45
|
+
kwargs["queryset"] = User.objects.filter(id=request.user.id)
|
|
46
|
+
return super().formfield_for_foreignkey(db_field, request, **kwargs) # type: ignore[return-value]
|
|
47
|
+
|
|
48
|
+
def get_form(
|
|
49
|
+
self,
|
|
50
|
+
request: HttpRequest, # type: ignore[override]
|
|
51
|
+
obj: APITokenProxy | None = None,
|
|
52
|
+
change: bool = False, # noqa: FBT001, FBT002
|
|
53
|
+
**kwargs: Any,
|
|
54
|
+
) -> type[ModelForm[APITokenProxy]]:
|
|
55
|
+
"""Prefill the form with the current user."""
|
|
56
|
+
form: type[ModelForm[APITokenProxy]] = super().get_form(
|
|
57
|
+
request, obj, change, **kwargs
|
|
58
|
+
)
|
|
59
|
+
form.base_fields["user"].initial = request.user
|
|
60
|
+
return form
|
|
61
|
+
|
|
62
|
+
def get_queryset(self, request: HttpRequest) -> QuerySet[APITokenProxy]: # type: ignore[override]
|
|
63
|
+
"""Show all or only own tokens depending on permissions."""
|
|
64
|
+
qs = super().get_queryset(request)
|
|
65
|
+
if request.user.has_perm("api.can_view_any"):
|
|
66
|
+
return qs
|
|
67
|
+
return qs.filter(user=request.user)
|
|
68
|
+
|
|
69
|
+
def get_sortable_by(self, request: HttpRequest): # type: ignore[no-untyped-def,override]
|
|
70
|
+
"""Hack to send a message depending on the status of the user."""
|
|
71
|
+
if request.user.has_perm("api.can_view_any"):
|
|
72
|
+
self.message_user(request, "You are seeing all tokens.", messages.WARNING)
|
|
73
|
+
elif request.user.has_perm("api.can_view_own"):
|
|
74
|
+
self.message_user(
|
|
75
|
+
request, "You are only seeing your tokens.", messages.WARNING
|
|
76
|
+
)
|
|
77
|
+
return super().get_sortable_by(request)
|
|
78
|
+
|
|
79
|
+
def has_view_permission(
|
|
80
|
+
self,
|
|
81
|
+
request: HttpRequest, # type: ignore[override]
|
|
82
|
+
obj: APITokenProxy | None = None,
|
|
83
|
+
) -> bool:
|
|
84
|
+
if obj is None:
|
|
85
|
+
return request.user.has_perm("api.can_view_any") or request.user.has_perm(
|
|
86
|
+
"api.can_view_own"
|
|
87
|
+
)
|
|
88
|
+
if request.user.has_perm("api.can_view_any"):
|
|
89
|
+
return True
|
|
90
|
+
if request.user.has_perm("api.can_view_own"):
|
|
91
|
+
return bool(obj.user == request.user)
|
|
92
|
+
return False
|
|
93
|
+
|
|
94
|
+
def has_add_permission(self, request: HttpRequest) -> bool: # type: ignore[override]
|
|
95
|
+
return request.user.has_perm("api.can_add_any") or request.user.has_perm(
|
|
96
|
+
"api.can_add_own"
|
|
97
|
+
)
|
|
98
|
+
|
|
99
|
+
def has_delete_permission(
|
|
100
|
+
self,
|
|
101
|
+
request: HttpRequest, # type: ignore[override]
|
|
102
|
+
obj: APITokenProxy | None = None,
|
|
103
|
+
) -> bool:
|
|
104
|
+
if obj is None:
|
|
105
|
+
return request.user.has_perm("api.can_delete_any") or request.user.has_perm(
|
|
106
|
+
"api.can_delete_own"
|
|
107
|
+
)
|
|
108
|
+
if request.user.has_perm("api.can_delete_any"):
|
|
109
|
+
return True
|
|
110
|
+
if request.user.has_perm("api.can_delete_own"):
|
|
111
|
+
return bool(obj.user == request.user)
|
|
112
|
+
return False
|
|
113
|
+
|
|
114
|
+
def has_change_permission(
|
|
115
|
+
self,
|
|
116
|
+
request: HttpRequest, # type: ignore[override]
|
|
117
|
+
_obj: APITokenProxy | None = None,
|
|
118
|
+
) -> bool:
|
|
119
|
+
return request.user.has_perm("api.can_edit_any")
|
|
120
|
+
|
|
121
|
+
|
|
122
|
+
# Remove the default TokenAdmin created by DRF and replace it with our custom one.
|
|
123
|
+
admin.site.unregister(TokenProxy)
|
|
124
|
+
admin.site.register(APITokenProxy, APITokenAdmin)
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
from typing import TYPE_CHECKING
|
|
4
|
+
|
|
5
|
+
from rest_framework.authentication import TokenAuthentication
|
|
6
|
+
|
|
7
|
+
if TYPE_CHECKING:
|
|
8
|
+
from django.db.models import Model
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
class BearerTokenAuthentication(TokenAuthentication):
|
|
12
|
+
"""To use `Authorization: Bearer <token>` instead of `Authorization: Token <token>`."""
|
|
13
|
+
|
|
14
|
+
keyword = "Bearer"
|
|
15
|
+
|
|
16
|
+
def get_model(self) -> type[Model]:
|
|
17
|
+
# ruff: noqa: PLC0415
|
|
18
|
+
from firefighter.api.models import APIToken
|
|
19
|
+
|
|
20
|
+
return APIToken
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
# Generated by Django 3.2.8 on 2021-11-07 16:58
|
|
2
|
+
|
|
3
|
+
from __future__ import annotations
|
|
4
|
+
|
|
5
|
+
from django.db import migrations
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
class Migration(migrations.Migration):
|
|
9
|
+
initial = True
|
|
10
|
+
|
|
11
|
+
dependencies = [
|
|
12
|
+
("authtoken", "0003_tokenproxy"),
|
|
13
|
+
]
|
|
14
|
+
|
|
15
|
+
operations = [
|
|
16
|
+
migrations.CreateModel(
|
|
17
|
+
name="APIToken",
|
|
18
|
+
fields=[],
|
|
19
|
+
options={
|
|
20
|
+
"proxy": True,
|
|
21
|
+
"default_permissions": [],
|
|
22
|
+
"indexes": [],
|
|
23
|
+
"constraints": [],
|
|
24
|
+
},
|
|
25
|
+
bases=("authtoken.token",),
|
|
26
|
+
),
|
|
27
|
+
migrations.CreateModel(
|
|
28
|
+
name="APITokenProxy",
|
|
29
|
+
fields=[],
|
|
30
|
+
options={
|
|
31
|
+
"verbose_name": "API Token",
|
|
32
|
+
"permissions": (
|
|
33
|
+
("can_edit_any", "Can reassign token to any user"),
|
|
34
|
+
("can_add_any", "Can add token to any user"),
|
|
35
|
+
("can_view_any", "Can view token of all users"),
|
|
36
|
+
("can_delete_any", "Can delete token of any user"),
|
|
37
|
+
("can_add_own", "Can add own tokens"),
|
|
38
|
+
("can_view_own", "Can view own tokens"),
|
|
39
|
+
("can_delete_own", "Can delete own tokens"),
|
|
40
|
+
),
|
|
41
|
+
"abstract": False,
|
|
42
|
+
"proxy": True,
|
|
43
|
+
"default_permissions": [],
|
|
44
|
+
"indexes": [],
|
|
45
|
+
"constraints": [],
|
|
46
|
+
},
|
|
47
|
+
bases=("api.apitoken",),
|
|
48
|
+
),
|
|
49
|
+
]
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
# Generated by Django 4.2.3 on 2023-07-04 09:06
|
|
2
|
+
|
|
3
|
+
from django.db import migrations
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
class Migration(migrations.Migration):
|
|
7
|
+
dependencies = [
|
|
8
|
+
("api", "0001_initial"),
|
|
9
|
+
]
|
|
10
|
+
|
|
11
|
+
operations = [
|
|
12
|
+
migrations.AlterModelOptions(
|
|
13
|
+
name="apitokenproxy",
|
|
14
|
+
options={
|
|
15
|
+
"default_permissions": [],
|
|
16
|
+
"permissions": [
|
|
17
|
+
("can_edit_any", "Can reassign token to any user"),
|
|
18
|
+
("can_add_any", "Can add token to any user"),
|
|
19
|
+
("can_view_any", "Can view token of all users"),
|
|
20
|
+
("can_delete_any", "Can delete token of any user"),
|
|
21
|
+
("can_add_own", "Can add own tokens"),
|
|
22
|
+
("can_view_own", "Can view own tokens"),
|
|
23
|
+
("can_delete_own", "Can delete own tokens"),
|
|
24
|
+
],
|
|
25
|
+
"verbose_name": "API Token",
|
|
26
|
+
},
|
|
27
|
+
),
|
|
28
|
+
]
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
# Generated by Django 4.2.11 on 2024-04-30 15:39
|
|
2
|
+
|
|
3
|
+
from django.db import migrations
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
class Migration(migrations.Migration):
|
|
7
|
+
|
|
8
|
+
dependencies = [
|
|
9
|
+
("api", "0002_alter_apitokenproxy_options"),
|
|
10
|
+
]
|
|
11
|
+
|
|
12
|
+
operations = [
|
|
13
|
+
migrations.AlterModelOptions(
|
|
14
|
+
name="apitokenproxy",
|
|
15
|
+
options={
|
|
16
|
+
"default_permissions": [],
|
|
17
|
+
"permissions": [
|
|
18
|
+
("can_edit_any", "Can reassign token to any user"),
|
|
19
|
+
("can_add_any", "Can add token to any user"),
|
|
20
|
+
("can_view_any", "Can view token of all users"),
|
|
21
|
+
("can_delete_any", "Can delete token of any user"),
|
|
22
|
+
("can_add_own", "Can add own tokens"),
|
|
23
|
+
("can_view_own", "Can view own tokens"),
|
|
24
|
+
("can_delete_own", "Can delete own tokens"),
|
|
25
|
+
],
|
|
26
|
+
"verbose_name": "API Token",
|
|
27
|
+
"verbose_name_plural": "API Tokens",
|
|
28
|
+
},
|
|
29
|
+
),
|
|
30
|
+
]
|
|
File without changes
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
from typing import TYPE_CHECKING, ClassVar, Self, cast
|
|
4
|
+
|
|
5
|
+
from django.conf import settings
|
|
6
|
+
from django.utils.translation import gettext_lazy as _
|
|
7
|
+
from django_stubs_ext.db.models import TypedModelMeta
|
|
8
|
+
from rest_framework.authtoken.models import Token
|
|
9
|
+
|
|
10
|
+
if TYPE_CHECKING:
|
|
11
|
+
import uuid
|
|
12
|
+
from collections.abc import Sequence
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
class APIToken(Token):
|
|
16
|
+
class Meta(TypedModelMeta):
|
|
17
|
+
default_permissions: ClassVar[Sequence[str]] = []
|
|
18
|
+
proxy = True
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
class APITokenProxy(APIToken):
|
|
22
|
+
"""Proxy mapping pk to user pk for use in admin.
|
|
23
|
+
|
|
24
|
+
Overrides default permissions.
|
|
25
|
+
"""
|
|
26
|
+
|
|
27
|
+
@property
|
|
28
|
+
def pk(self: Self) -> uuid.UUID:
|
|
29
|
+
return cast("uuid.UUID", self.user_id) # pyright: ignore[reportGeneralTypeIssues]
|
|
30
|
+
|
|
31
|
+
class Meta(TypedModelMeta):
|
|
32
|
+
permissions = [
|
|
33
|
+
("can_edit_any", "Can reassign token to any user"),
|
|
34
|
+
("can_add_any", "Can add token to any user"),
|
|
35
|
+
("can_view_any", "Can view token of all users"),
|
|
36
|
+
("can_delete_any", "Can delete token of any user"),
|
|
37
|
+
("can_add_own", "Can add own tokens"),
|
|
38
|
+
("can_view_own", "Can view own tokens"),
|
|
39
|
+
("can_delete_own", "Can delete own tokens"),
|
|
40
|
+
]
|
|
41
|
+
default_permissions: ClassVar[Sequence[str]] = []
|
|
42
|
+
proxy = "rest_framework.authtoken" in settings.INSTALLED_APPS
|
|
43
|
+
abstract = "rest_framework.authtoken" not in settings.INSTALLED_APPS
|
|
44
|
+
verbose_name = _("API Token")
|
|
45
|
+
verbose_name_plural = _("API Tokens")
|