Skip to content

Commit

Permalink
[#2762] update settings: log outgoing requests
Browse files Browse the repository at this point in the history
  • Loading branch information
pi-sigma authored and sergei-maertens committed Jun 8, 2023
1 parent 3681101 commit 2ba2b72
Show file tree
Hide file tree
Showing 11 changed files with 125 additions and 1 deletion.
1 change: 1 addition & 0 deletions requirements/base.in
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ django-cors-headers
django-decorator-include
django-digid-eherkenning
django-hijack
django-log-outgoing-requests
django-modeltranslation
django-ordered-model
django-privates
Expand Down
6 changes: 6 additions & 0 deletions requirements/base.txt
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,7 @@ django==3.2.19
# django-filter
# django-formtools
# django-hijack
# django-log-outgoing-requests
# django-modeltranslation
# django-otp
# django-phonenumber-field
Expand Down Expand Up @@ -131,6 +132,7 @@ django-admin-index==2.0.0
django-appconf==1.0.4
# via
# django-cookie-consent
# django-log-outgoing-requests
# django-timeline-logger
django-autoslug==1.9.8
# via -r requirements/base.in
Expand Down Expand Up @@ -166,6 +168,8 @@ django-hijack==3.1.6
# via -r requirements/base.in
django-ipware==3.0.1
# via django-axes
django-log-outgoing-requests==0.3.0
# via -r requirements/base.in
django-modeltranslation==0.18.5
# via -r requirements/base.in
django-ordered-model==3.6
Expand Down Expand Up @@ -197,6 +201,7 @@ django-solo==2.0.0
# -r requirements/base.in
# django-camunda
# django-digid-eherkenning
# django-log-outgoing-requests
# mozilla-django-oidc-db
# zgw-consumers
django-timeline-logger==2.1.0
Expand Down Expand Up @@ -376,6 +381,7 @@ redis==4.5.4
requests==2.31.0
# via
# django-camunda
# django-log-outgoing-requests
# gemma-zds-client
# maykin-python3-saml
# mozilla-django-oidc
Expand Down
8 changes: 8 additions & 0 deletions requirements/ci.txt
Original file line number Diff line number Diff line change
Expand Up @@ -178,6 +178,7 @@ django==3.2.19
# django-formtools
# django-hijack
# django-jenkins
# django-log-outgoing-requests
# django-modeltranslation
# django-otp
# django-phonenumber-field
Expand Down Expand Up @@ -210,6 +211,7 @@ django-appconf==1.0.4
# -c requirements/base.txt
# -r requirements/base.txt
# django-cookie-consent
# django-log-outgoing-requests
# django-timeline-logger
django-autoslug==1.9.8
# via
Expand Down Expand Up @@ -280,6 +282,10 @@ django-ipware==3.0.1
# django-axes
django-jenkins==0.110.0
# via -r requirements/test-tools.in
django-log-outgoing-requests==0.3.0
# via
# -c requirements/base.txt
# -r requirements/base.txt
django-modeltranslation==0.18.5
# via
# -c requirements/base.txt
Expand Down Expand Up @@ -335,6 +341,7 @@ django-solo==2.0.0
# -r requirements/base.txt
# django-camunda
# django-digid-eherkenning
# django-log-outgoing-requests
# mozilla-django-oidc-db
# zgw-consumers
django-timeline-logger==2.1.0
Expand Down Expand Up @@ -725,6 +732,7 @@ requests==2.31.0
# -c requirements/base.txt
# -r requirements/base.txt
# django-camunda
# django-log-outgoing-requests
# gemma-zds-client
# maykin-python3-saml
# mozilla-django-oidc
Expand Down
8 changes: 8 additions & 0 deletions requirements/dev.txt
Original file line number Diff line number Diff line change
Expand Up @@ -205,6 +205,7 @@ django==3.2.19
# django-formtools
# django-hijack
# django-jenkins
# django-log-outgoing-requests
# django-modeltranslation
# django-otp
# django-phonenumber-field
Expand Down Expand Up @@ -239,6 +240,7 @@ django-appconf==1.0.4
# -c requirements/ci.txt
# -r requirements/ci.txt
# django-cookie-consent
# django-log-outgoing-requests
# django-timeline-logger
django-autoslug==1.9.8
# via
Expand Down Expand Up @@ -315,6 +317,10 @@ django-jenkins==0.110.0
# via
# -c requirements/ci.txt
# -r requirements/ci.txt
django-log-outgoing-requests==0.3.0
# via
# -c requirements/ci.txt
# -r requirements/ci.txt
django-modeltranslation==0.18.5
# via
# -c requirements/ci.txt
Expand Down Expand Up @@ -374,6 +380,7 @@ django-solo==2.0.0
# -r requirements/ci.txt
# django-camunda
# django-digid-eherkenning
# django-log-outgoing-requests
# mozilla-django-oidc-db
# zgw-consumers
django-timeline-logger==2.1.0
Expand Down Expand Up @@ -858,6 +865,7 @@ requests==2.31.0
# -r requirements/ci.txt
# ddt-api-calls
# django-camunda
# django-log-outgoing-requests
# django-rosetta
# django-silk
# gemma-zds-client
Expand Down
8 changes: 8 additions & 0 deletions requirements/extensions.txt
Original file line number Diff line number Diff line change
Expand Up @@ -142,6 +142,7 @@ django==3.2.19
# django-filter
# django-formtools
# django-hijack
# django-log-outgoing-requests
# django-modeltranslation
# django-otp
# django-phonenumber-field
Expand Down Expand Up @@ -174,6 +175,7 @@ django-appconf==1.0.4
# via
# -r requirements/base.txt
# django-cookie-consent
# django-log-outgoing-requests
# django-timeline-logger
django-autoslug==1.9.8
# via
Expand Down Expand Up @@ -240,6 +242,10 @@ django-ipware==3.0.1
# via
# -r requirements/base.txt
# django-axes
django-log-outgoing-requests==0.3.0
# via
# -c requirements/base.in
# -r requirements/base.txt
django-modeltranslation==0.18.5
# via
# -c requirements/base.in
Expand Down Expand Up @@ -289,6 +295,7 @@ django-solo==2.0.0
# -r requirements/base.txt
# django-camunda
# django-digid-eherkenning
# django-log-outgoing-requests
# mozilla-django-oidc-db
# zgw-consumers
django-timeline-logger==2.1.0
Expand Down Expand Up @@ -579,6 +586,7 @@ requests==2.31.0
# via
# -r requirements/base.txt
# django-camunda
# django-log-outgoing-requests
# gemma-zds-client
# maykin-python3-saml
# mozilla-django-oidc
Expand Down
6 changes: 6 additions & 0 deletions src/log_outgoing_requests_ext/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
"""
Extensions on top of django-log-outgoing-requests
TODO: move this (or parts) into the library itself, see
https://github.com/maykinmedia/django-log-outgoing-requests/issues/7
"""
21 changes: 21 additions & 0 deletions src/log_outgoing_requests_ext/tasks.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
import logging
from datetime import timedelta

from django.conf import settings
from django.utils import timezone

from celery import shared_task
from log_outgoing_requests.models import OutgoingRequestsLog

logger = logging.getLogger(__name__)


@shared_task
def cleanup_request_logs() -> int:
delta = timedelta(hours=settings.LOG_OUTGOING_REQUESTS_MAX_AGE)
past_timestamp = timezone.now() - delta
num_deleted, _ = OutgoingRequestsLog.objects.filter(
timestamp__lte=past_timestamp
).delete()
logger.info("Deleted %d outgoing request log(s)", num_deleted)
return num_deleted
Empty file.
25 changes: 25 additions & 0 deletions src/log_outgoing_requests_ext/tests/test_tasks.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
from django.test import TestCase, override_settings
from django.utils import timezone

from freezegun import freeze_time
from log_outgoing_requests.models import OutgoingRequestsLog

from ..tasks import cleanup_request_logs


class TestLogTask(TestCase):
@override_settings(LOG_OUTGOING_REQUESTS_MAX_AGE=1) # delete if >= one hour old
def test_cleanup_request_logs(self):
"""Assert that logs are cleaned if and only if created before specified time"""
with freeze_time("2023-06-08T22:00:00Z") as frozen_time:
OutgoingRequestsLog.objects.create(timestamp=timezone.now())
frozen_time.move_to("2023-06-08T23:15:00Z")
to_keep = OutgoingRequestsLog.objects.create(timestamp=timezone.now())

cleanup_request_logs()

self.assertQuerysetEqual(
OutgoingRequestsLog.objects.all(),
[to_keep.pk],
transform=lambda record: record.pk,
)
41 changes: 41 additions & 0 deletions src/openforms/conf/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@
import sentry_sdk
from celery.schedules import crontab
from corsheaders.defaults import default_headers as default_cors_headers
from log_outgoing_requests.datastructures import ContentType
from log_outgoing_requests.formatters import HttpFormatter

from csp_post_processor.constants import NONCE_HTTP_HEADER

Expand Down Expand Up @@ -185,6 +187,8 @@
"cspreports",
"csp_post_processor",
"django_camunda",
"log_outgoing_requests",
"log_outgoing_requests_ext",
# Project applications.
"openforms.accounts",
"openforms.analytics_tools",
Expand Down Expand Up @@ -376,6 +380,7 @@
"performance": {
"format": "%(asctime)s %(process)d | %(thread)d | %(message)s",
},
"outgoing_requests": {"()": HttpFormatter},
},
"filters": {
"require_debug_false": {"()": "django.utils.log.RequireDebugFalse"},
Expand Down Expand Up @@ -419,6 +424,15 @@
"maxBytes": 1024 * 1024 * 10, # 10 MB
"backupCount": 10,
},
"log_outgoing_requests": {
"level": "DEBUG",
"formatter": "outgoing_requests",
"class": "logging.StreamHandler",
},
"save_outgoing_requests": {
"level": "DEBUG",
"class": "log_outgoing_requests.handlers.DatabaseOutgoingRequestsHandler",
},
},
"loggers": {
"openforms": {
Expand All @@ -445,6 +459,11 @@
"handlers": ["project"] if not LOG_STDOUT else ["console"],
"level": "DEBUG",
},
"requests": {
"handlers": ["log_outgoing_requests", "save_outgoing_requests"],
"level": "DEBUG",
"propagate": True,
},
},
}

Expand Down Expand Up @@ -679,6 +698,10 @@
"task": "openforms.forms.admin.tasks.clear_forms_export",
"schedule": crontab(hour=0, minute=0, day_of_week="sunday"),
},
"cleanup-outgoing-request-logs": {
"task": "log_outgoing_requests_ext.tasks.cleanup_request_logs",
"schedule": crontab(hour=0, minute=0, day_of_week="*"),
},
}

RETRY_SUBMISSIONS_TIME_LIMIT = config(
Expand Down Expand Up @@ -1141,6 +1164,24 @@
#
MODELTRANSLATION_DEFAULT_LANGUAGE = "nl"

#
# Django-log-outgoing-requests
#
LOG_OUTGOING_REQUESTS_CONTENT_TYPES = [
ContentType(pattern="application/json", default_encoding="utf-8"),
ContentType(pattern="application/soap+xml", default_encoding="utf-8"),
ContentType(pattern="application/xml", default_encoding="utf-8"),
ContentType(pattern="text/xml", default_encoding="iso-8859-1"),
ContentType(pattern="text/*", default_encoding="utf-8"),
]
LOG_OUTGOING_REQUESTS_EMIT_BODY = True
LOG_OUTGOING_REQUESTS_MAX_CONTENT_LENGTH = 524_288 # 0.5MB

# Custom settings
LOG_OUTGOING_REQUESTS_MAX_AGE = config(
"LOG_OUTGOING_REQUESTS_MAX_AGE", default=7 * 24
) # number of hours

#
# Open Forms extensions
#
Expand Down
2 changes: 1 addition & 1 deletion src/openforms/fixtures/admin_index_unlisted.json
Original file line number Diff line number Diff line change
Expand Up @@ -19,5 +19,5 @@
"forms.FormLogic",
"of_authentication.AuthInfo",
"of_authentication.RegistratorInfo",
"upgrades.VersionInfo"
"upgrades.VersionInfo",
]

0 comments on commit 2ba2b72

Please sign in to comment.