This file documents all changes to Argus. This file is primarily meant to be read by developers.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
This project uses towncrier and the changes for the upcoming release can be found in https://github.com/Uninett/Argus/tree/master/changelog.d/.
Mostly changes to the alpha frontend
- Added docs for how to vendor a repo (copy one repo into another, preserving history).
- Add HTMX version of the destinations page (#1001)
- Show user an error message in case a htmx partial request fails (#1023)
- Allow extending preferences page (#1070)
- Keep django messages in queue on htmx redirects or refreshes (#1071)
- Replaced the placeholder notification profile page with a very ugly but functional one.
- Replaced the placeholder time-slots page with a very ugly but functional one.
- Added loading indicator to bulk action buttons
- Performance: Reduced the number of queries to preferences db table (#1082)
- Declared argus-theme as one with the light color scheme in order to always have reasonable fallbacks. (#1088)
- Generalized the multiselect dropdown widget used for the source field in the filterbox so that we can use it for other dropdowns on other pages.
- Renamed some directories and templates to give them better, more consistent names.
- Fixed background color in input fields for argus-theme globally. (#1088)
Mostly changes to the alpha frontend
- Add support for multple API tokens per user via django-rest-knox. For that reason, the old API endpoints for dealing with token authentication has been deprecated, and new endpoints have been added to v2 of the API.
- We've copied the linting rules from argus-htmx, so anything that have not been merged yet might have to be updated to keep the linters happy.
- All v1 API endpoints for dealing with phone numbers have been deprecated. Please see the v2 endpoints dealing with destinations instead.
ARGUS_HTMX_FILTER_FUNCTION
can take a callable or a dotted function path (#1029)- Support incident filtering from incident list table columns
- Return user to login page on unauthenticated HTMx request
- Automatically close certain notification toasts
- Keep column filters when autoreloading incident list (#1033)
- Fix incorrect width specifier in column filter input (#1065)
This version marks the inclusion of our new, alpha web frontend. It does not do everything the existing standalone frontend does yet, hence alpha. See docs for how to test.
- We are now linting html with djLint
- Add new (unfinished) app: argus.htmx. Thiis is a new frontend written quite old-style, with HTML enhanced with HTMx. This used to live in its own app (PyPI: argus-htmx-frontend) and repo (https://github.com/Uninett/argus-htmx-frontend/) and is in the process of being completely merged with argus-server. All new issues and PR's should be made towards the argus-server repo. Unfinished branches and issues should be moved over here. PR's merged after the move will be moved by us.
- Added a short howto on how to try to fix a broken migration. Remember, it is always less stress to restore a backup!
- We're switching from black to ruff, and will both lint and format code going forward.
- Use tox version 4 to run test suite
- Added a database model to store user preferences. Remember to migrate!
- Added a new testenv to tox to easily regenerate the ER model. It needs regenerating thanks to the new model.
- Allow deletion in admin of "dormant" users, that is: users that have never created an event or incident. These frequently occur when testing new login methods.
- Logout via the React SPA frontend works again, the url has been corrected.
This release is mainly to wrangle dependencies to the in-progress new frontend.
- There's more detail on how to set up federated logins in the docs.
- Make
AUTHENTICATION_BACKENDS
setting mutable by making it a list, not a tuple.
- Do not run processes as
root
in Docker production container (#921)
- Make it easier to use the new HTMx-based frontend, with docs. The new frontend cannot be run simultaneously with the REACT SPA frontend as some settings conflict.
- There's a new courtesy method on the User-model:
is_member_of_group()
.
-
Switched to running docker image on python 3.10 and postgres v14. (#908)
-
Make it possible to change any setting via the (EXTRA|OVERRIDING)_APPS-machinery.
-
Split out all the hard coded support for the REACT SPA frontend into a library.
In the process, the following renames were done:
ARGUS_COOKIE_DOMAIN
->ARGUS_SPA_COOKIE_DOMAIN
(environment variable)COOKIE_DOMAIN
->SPA_COOKIE_DOMAIN
(setting)ARGUS_TOKEN_COOKIE_NAME
->ARGUS_SPA_TOKEN_COOKIE_NAME
(hidden setting)
How to deploy with support for this frontend has also changed, see the new documentation section "REACT Frontend". In short, it is necessary to change which settings-file to base the deployment on.
This is the first version of Argus to be able to run on Django 5.1.
Support for Python 3.8 has been dropped.
The most visible changes are in the documentation.
- As part of refactoring some authentication utility functions the function
get_psa_authentication_names()
has been removed as it wasn't used anywhere in Argus proper.
- Added a new section "Customization" to the docs, for customizations that go beyond integrations.
- Documented how to use (EXTRA|OVERRIDING)_APPS to add app-specific middleware.
- There's a new howto, for how to regenerate the ER diagram in the docs.
- So. Many. Refactors.
- There should be fewer warnings/log messages when visiting the autogenerated OpenAPI. There is one commit per change to help with future wrangling. There are still some warnings left; getting rid of those is left as an exercise to the reader.
- The favicon and template for the simple page generated on "/" are now replacable by adding an app at the start of INSTALLED_APPS that has the new files.
- Plenty of dependencies and sub-dependencies were upgraded
- Django ValidationErrors are converted to DRF ValidationErrors. This makes it possible to move some validation from API model serializers to the actual model, which means validating only once and the API and future Django frontend seeing the same errors.
- Moved reference docs into their own section (as per Diátaxis), improved the looks and contents of the explanation and terms, and added a very brief explanation of each model.
- Moved site TEMPLATES and STATIC to a mini-app to make them replaceable via an app added before it in INSTALLED_APPS.
- Removed
FilterSerializer
andvalidate_jsonfilter
from the filter plugin mechanism since they just wrapFilterBlobSerializer
. (This also meansFilterBlobSerializer
can no longer be in the same file asFilterSerializer
.)
- Fix OpenAPI parameters for
incidents/
andincidents/mine/
- Add method to get associated names of Incident levels (#875)
- Refactored ticket creation code so the actual changing of the incident happens only in one place. Also moved the actual autocreation magic to utility functions (sans error-handling since that is response-type dependent). Made bulk changes of tickets actually create the ChangeEvents so that it behaves like other bulk actions and make it possible to get notified of changed ticket urls.
- Replace the setting
STATICFILES_STORAGE
withSTORAGES
to prepare for running on newer Djangos. See NOTES for details.
- Hopefully there will be fewer spurious test-failures thanks to explicitly creating the user connected to a sourcesystem. UniqueError, you won't be missd.
- Fixed broken link to dataporten authentication docs in README (#broken-dataporten-link)
- Renamed 'docker-compose' to 'Docker Compose' in README (#update-readme-command-naming)
- Make description editable (#811)
INCIDENT_LEVEL_CHOICES
was behaving oddly when debugging so it has been made a proper immutable constant.
- Added method to check whether incident is acknowledged by a specific user group. (#838)
- Made it possible to replace how Argus does filtering (for sending notifications and showing a list of incidents). See the howto "How to customize filtering".
OVERRIDING_APPS
andEXTRA_APPS
now supports changing the MIDDLEWARE-setting. The key is "middleware" and the value is a dictionary of the dotted path of the middleware as the key, and an action as the value. Currently only the actions "start" and "end" is supported, putting the middleware at either the start of the list or the end, depending.
BIG filter refactor/cleanup. All filter-stuff except the Filter-model has been moved to a new app, argus.filter
- Move
Filter.filtered_incidents
toargus.filter.queryset_filters.QuerySetFilter
- Change the signature so that it works on a filterblob, not a Filter model instance
- Ensure that the fallback filter, which is only relevant when sending notifications, is ignored everywhere else. First step in getting rid of this misfeature of a setting.
- Get rid of
NotificationProfile.filtered_incidents
, instead useargus.filter.queryset_filters.QuerySetFilter.incidents_by_notificationprofile
- Move Filter-dependent methods out of incident/models.py
- Move filter settings check to argus.filter
- Keep OpenAPI queryparam descriptions with their filters in argus.filter.filters
- Update and improve tests
- Move Filter
*_fits
methods to argus.filter.filterwrapper.FilterWrapper - Move NotificationProfile
*_fits
methods to ComplexFilterWrapper - Add docstring to argus.filter.filter
- Simplify/DRY existing filterwrapper methods, including tristate
- Removed one cause for spurious failures of tests
- Show infinite
end_time
as 'Still open' instead of datetime representation in email (#793) - Temporarily hide DestinationConfig from User admin in order to allow updating Users again. Undo if Django starts allowing JSONFields in UniqueConstraints. (#822)
- Improve
/incident
endpoint response time by roughly 36% by pre-fetching incident tag data (#837)
- There is now a commented line in
argus.site.urls.urlpatterns
that if uncommented will allow logging into the API with username/password. This allows the use of the DRF HTML api to change records. This partially works with django-debug-toolbar and should ease some debugging sessions.
- Optimized PUT/PATCH of incidents in API v2. Mainly by no longer replacing
Incident.search_text
on every Incident save, thereby avoiding looking up all events for that incident. The old behavior was fine when there was only a handful of events per incident but we can no longer assume that.
- Fixed bug preventing naive printing of TimeRecurrences, triggering a traceback
Backwards-incompatible change: Because it is now possible to filter on multiple event types instead of just one, both API V1 and API V2 has changed its schema for Filter.filter. See NOTES.md for details.
- Removed
"event_type"
from the V1 Filter API, it should only have been available in V2 (since it was new) and it has never been in use by the frontend. (#699)
- Add filtering of events by a list of event types (#699)
- Add howto about how to set up and test federated login, using GitHub as an example. (#803)
- Extend the usefulness of
OVERRIDE_APPS
andEXTRA_APPS
by adding support for Django template engine context processors. Any context processors are added to the end of the list. (#810)
- Change how the description of a change event is formatted so that it is always consistent (not to mention DRY). (#809)
- New in the API: Allow sources to delete their own incidents, as well as allow superusers to delete any incident. (#804)
- Allow replacing Incident.metadata with another json blob via API, no questions asked, nothing to see here. (#807)
- Add a possibility to filter incidents by start time in incident admin list (#739)
- Added an optional JSONField "metadata" to incident. This can be used for any additional info the glue-service would like to store on the incident that needs more structure than tags. The field has been added to the V2 IncidentSerializer but we do not plan to expose it in the frontend.
- Added documentation on how to safely test notifications.
- Added simple support for pluggable django-apps. The setting
OVERRIDING_APPS
is loaded first inINSTALLED_APPS
andurls.py
, and can override templates and views. The settingEXTRA_APPS
is safer, it is loaded last inINSTALLED_APPS
andurls.py
and can therefore only add additional templates and views.
- When editing a notification profile in the admin UI, only the profile owner's own filters are now listed as available for selection. (#735)
- Linked up the second column in the admin incident list to the details view in addition to the default first column because the first column is currently an optional field. If the field has no value there can also not be a link.
- Update the release checklist in
docs/
to current practices and turn it into a howto.
- Show fully qualified details URL in emails (#744)
- Fix internal server error in timeslot admin due to removed method (#797)
- Added development dependency on django-debug-toolbar to make it easy to use.
- Adds more capability to the stresstest command, including incident creation verification, bulk ACKing and timeout configuration. (#641)
- Add possibility to set fields when creating fake incidents in Django admin (#669)
- Show user and filter by user in notification profile admin (#734)
- Add cli command to toggle notification profile activation (#747)
- Add admin action to change activation of profiles (#748)
- Add API documentation for GET responses (#752)
- Added an informational page on /, with favicon, in order to cut down on some common 404 log messages and set up the static files system properly.
- Switched official Docker image to serve using gunicorn+uvicorn (#766)
- Changed how tristates (open, acked, stateful) are logged in order to improve debuggability.
- Return False and log if sms-to-email has trouble with the email server.
- To improve debugability: Change how sending notifications are logged so that there's a log both when sending succeds and when it fails.
- Changed references to docs for Django 4.2 (#746)
- Do not allow used destinations to be deleted (#753)
- Fix typo in admin that prevented sorting on incident id
Due to the removal of the django-multiselectfield dependency it is vitally important to upgrade to this version after correctly having upgraded to 1.14.3 (the previous version).
Be sure to migrate the database:
$ python manage.py migrate
This version supports Django 4.2 and newer.
- Drop all support for Django 3.2. No version-specific requirements for 3.2 are included anymore, and we no longer test on 3.2.
- Remove django-multiselectfield dependency (#707)
This release changes the database in order to get rid of a dead dependency, make sure to run migrations.
This version can run on Django 5.0 if necessary. Install the dependencies in
requirements-django50.txt
if so.
This is the last version that supports Django 3.2.
-
Add filtering of incident list by notificationprofile
This returns all incidents that are included in filters that are connected to that notificationprofile
-
Added support for running and testing on Django 5.0
- Change TimeRecurrence.days from MultiSelectField to ArrayField (#707)
- Updated lots of depenendcies in order to run on Django 5.0
This version can run on Django 4.2. In production, ensure that the list of
entries in CSRF_TRUSTED_ORIGINS
are absolute urls, all starting with
https://
.
-
Add filtering of incident list by filter
This returns all incidents that are included in the filter (#244)
-
Allow running and testing on Python 3.12
-
Added towncrier to automatically produce changelog
-
Add two development dependencies
While
tox
doesn't need to be in the venv, it DOES currently need to be less than version 4.build
is useful for debugging pip errors and pip-compile trouble. Whenever pip-compile (viatox -e upgrade-deps
for instance) fails withBackend subprocess exited when trying to invoke get_requires_for_build_wheel Failed to parse /PATH/pyproject.toml
run
python -m build -w
to see whatbuild
is actually complaining about.See also pypa/build#553
-
Add the "admin_url" field to the user serializer. This is so that the frontend can show a link to the Django admin.
-
Added the possibility to filter incident by a given list of ids
- Fixed posting/updating notification profiles without name
- Updated a lot of (sub)dependencies to allow running on newer pythons and newer Djangos, and to quiet dependency bots
- Restructured documentation about integrations
Incomplete changelog.
Due to a change in the signature of NotificationPlugin.send()
, 3rd party
plugins will need to mark better which versions of argus-server they work with
in their dependencies-list. The old-style plugins work on 1.9-1.13.
- Add the "installed" field to the media serializer. This is so that the frontend can detect media used that is no longer installed on the backend.
- Ensure the right notifications go to the right destinations when sending many of each.
- Change the signature of the notification-plugin
send
-method to avoid passing in the database - Log profile owners name when checking profiles
- Constrain subdependencies in a better way
- Send one email per email-address so as to not leak who else gets that email.
- Remove the
Filter.filter_string
-field from the database. We're not using it anymore and shouldn't ever use it by accident either.
Works with argus-frontend 1.11 and newer.
- Lint for critical problems before testing in Github CI, to speed things up
- Added config-file for building docs at readthedocs
- Add inline destinations to user edit page in admin
- Add management command for listing filters
- Add management command for bulk acting on incidents matching a given filter
- Raise validation error on posting incident with tags without tag key
-
Update Django patch versions and various dependencies
-
Drop support for Python 3.7. Github's CI/CD was sufficiently different from testing on local (different setuptools-version used maybe?) that we had a "fun" goose chase finding and upgrading the sub-dependency that broke the build.
-
Remove all remaining uses of
Filter.filter_string
, replace with Filter.filter, in preparation of removing the actualfilter_string
field from the database.The API v1 still accepts
filter_string
but it is optional. It will prefer the data infilter
. v2 ignores the presence or absence offilter_string
entirely.
- Ensure that the start event is created after the incident has its tags so that notification filters with tags trigger correctly. The signal that creates the first event is gone, but the signal that triggers on creation of the first event is not, that will have to wait until we utilize a queue.
- Change what is logged on notification sending in order to ease solving problems in production
- When sending a notification in production a typo lead to an exception that prevented sending the notification but was otherwise hidden from the end user.
- Typo in code (that could have been found by flake8) lead to acks not working when notifications are turned on
- More tests. Lots.
- Add docs for how to write a notification plugin
- Add a new command "stresstest", for stress-testing the API
- Start a process for revealing to the frontend which media plugins are actually installed
- Log a warning if a medium in the Media-table does not have a plugin installed
- Mention cookiecutter-template for tickets in the ticket docs
- Support running on Django 4.2
- Documented how to use email to send notifications to Slack
- Make the auth-method endpoint also show that username/password is supported
- In ticket-automation, show which fields were configured but not found in the generated ticket
- Lots of formatting-bugaboos in the docs
- Allow updating of a timeslot with an empty time recurrence list, which results in all time recurrences to be removed from the timeslot
- Optimize and refactor bulk api operations
- Change how media plugins are accessed in order to avoid/control some exceptions
- Start the process of getting rid of
Filter.filter_string
by ensuring the info infilter_string
is also inFilter.filter
- Correct some api examples in docs
- Only fork a new process to send notifications if there are any notifications to send
- Upgrade lots of dependencies
- Support explicit timestamp in
Incident.set_open/set_closed
- Change how parameter names to SerializerMethodFields are set up
- Improved ticket docs
- Fixed typos
- Simplify generation of frozen dependency list: trust pyproject.toml
- Coverage of the notificationprofile app was improved with several new tests
- CORS-headers do not want explicit port numbers if the ports are the default
for their type, that is: 80 for http or 443 for https. This lead to CORS not
working if there was an explicit port in the
ARGUS_FRONTEND_URL
setting, which used to generate a CORS entry for the frontend. Such port numbers are now stripped when generating the CORS header.
With this version, the API for bulk changes of incidents and sending of notifications to new and interesting destinations via destination plugins has been frozen, and should be ready for use, completing what was started in 1.10.
- Add default HTML template for autocreated tickets
- Also include frontend-url to incident in incident-serializer
- Output XML test-reports and set up github actions for it
- Show installed plugins in the metadata view
- Fix API for adding events in bulk, with tests
- Fix API for bulk acking, with tests
- Improved OpenAPI by adding some more docstrings
- Updated version of github-actions actions
- Use better exceptions for ticket plugins
- Change how/where change-events are created
- Move tests for included destinations to individual files
- Renamed the ticket creation endpoint via plugin from
/ticket/
to/automatic-ticket/
- Refactored the view tests for NotificationProfile
- Explicitly set language in sphinx conf, silencing a warning
- Added support for testing on Python 3.11 and Django 4.0, 4.1
- Plugin system for ticket system integrations, documented in the new "Ticket system settings" sections.
- Add a production-oriented Dockerfile and use Github to build and store images
- New API endpoint to create a new ticket in an external ticket system
- Add docs about notification plugins
- Added the possibility to filter notifications by event-type
- Added a management command that will create incidents if a source token is close to expiring
- Added an endpoint to set
ticket_url
of incidents in bulk - Added an endpoint to create events for incidents in bulk
- Changed when the Media-table is synced with settings
MEDIA_PLUGINS
to avoid dev/prod-settings leaking into the tests
- Flatten the json structure for posting acknowledgements.
- Improve Sonar Cloud settings, like just testing for Python 3
- Add test for updating phone number in V1
- Add test for posting tag with invalid key
- Added an endpoint to acknowledge incidents in bulk
- Added an endpoint to get a refreshed auth token.
- Add a filter to find incidents with a duration longer than a given amount of minutes.
- Added tests for previously untested incident endpoints
- A Makefile that cleans away generated files
- Validate that user doesn't have destination with same settings before creating/updating destination
- Properly catch tag validtion errors
- The FilterFactory no longer leads to random UniqueViolations on testing
- Fix typo that prevented SMS messages from being sent.
- A notification profile can now have a name.
- Docstrings and type hints to functions of media plugins.
- Added tests for the email and sms destination serializer in case of invalid input for updating.
- Added tests for the incident, event and tag serializer
- Added endpoint that returns True if another user has a destination with the same medium and settings as the destination with the given primary key
- Add tests for filtering on stateful/statelss and open/closed incients.
- Add SMSNotification plugin to MEDIA_PLUGINS in development settings.
- Fix a notification profile test to include the phone number changes.
- Broken links and formatting in documentation.
- Fix notification profile serializer test to actually change phone number when updating.
- Make code snippets visible in release checklist in documentation.
- Validate tags before adding them to an incident
- Disallow the use of
argus
as username when creating admin user via theinitial_setup
script.
- One timeslot can now be used by multiple notification profiles.
- Replaced wildcard imports with specific imports.
- Moved the notification profile Github test to parent folder and added regression tag.
- Renamed notification profile serializer tests to be more descriptive and added integration test tags.
- Improve query in notification profile signal test and add clarifying comment.
- Ran black again on whole code base.
- In media plugins rename the function
is_deletable
toraise_if_not_deletable
and make it raise an error if a destination is not deletable. - Split up and rename notification profile model tests
- Upgrade from pyjwt 2.0.1 to 2.4.0
- Upgrade from django 3.2.13 to 3.2.15
- Upgrade from black 20.8b1 to 22.3.0 in pre-commit
- Clean away database tables rendered unnecessary due to changes in 1.6.0
- Modernize packaging. Package-building is all in pyproject.toml, tools are
- Clean away database tables rendered unnecessary due to changes in 1.6.0
- Modernize packaging. Package-building is all in pyproject.toml, tools are configured either there or in tox.ini.
- Add endpoint for getting all events.
- Add support for multiple emails and phone numbers per user.
- Allow source systems to post acknowledgements.
- Added clearer directions to the Argus documentation in the README.
- Rename the
media_v1
key in the notificationprofile endpoint back tomedia
, as changing it tomedia_v1
broke the frontend. - Fix a notification profile test running duplicate asserts against one filter instead of actually testing the other defined filters.
- Use more factories for notificationprofile tests.
- Acknowledging incidents works again, thanks to a workaround.
- Github actions: Add support for SonarQube (for Géant) and prevent CodeCov on 3rd party forks
- Add feature for searching through incident and event descriptions.
- Support external authentication via REMOTE_USER environment variable.
- Replace references to Uninett with Sikt.
- Upgrade from django 3.2.12 to 3.2.13
- Add new API endpoint for listing all login endpoints.
- Add new event type "LES" for stateless events.
- Add debugging endpoint to incident API for counting results of a filter.
- Allow changing level via incident endpoint
- Make initial events for stateless incidents be of type "LES" instead of "STA".
- Update README documentation for using create_fake_incident.
- Allow any length for event type keys instead of limiting it to a lenght of 3.
- Ensure unique source for incidents in incident queryset tests.
- Remove unsupported authentication backend.
- Add support for python 3.10.
- Upgrade from django 3.2.11 to 3.2.12.
- Stop NotificationProfileViewV1 from appearing in API v2.
- Fix signatures for ListFields.
- Force djangorestframework dependency to be older than 3.13.