mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05:00
Change: enable auditlog by default, fix import / export (#6267)
This commit is contained in:
parent
00b04c2e86
commit
0f8b2e69c9
@ -1311,11 +1311,9 @@ assigns or creates tags if a properly formatted barcode is detected.
|
|||||||
|
|
||||||
#### [`PAPERLESS_AUDIT_LOG_ENABLED=<bool>`](#PAPERLESS_AUDIT_LOG_ENABLED) {#PAPERLESS_AUDIT_LOG_ENABLED}
|
#### [`PAPERLESS_AUDIT_LOG_ENABLED=<bool>`](#PAPERLESS_AUDIT_LOG_ENABLED) {#PAPERLESS_AUDIT_LOG_ENABLED}
|
||||||
|
|
||||||
: Enables an audit trail for documents, document types, correspondents, and tags. Log entries can be viewed in the Django backend only.
|
: Enables the audit trail for documents, document types, correspondents, and tags.
|
||||||
|
|
||||||
!!! warning
|
Defaults to true.
|
||||||
|
|
||||||
Once enabled cannot be disabled
|
|
||||||
|
|
||||||
## Collate Double-Sided Documents {#collate}
|
## Collate Double-Sided Documents {#collate}
|
||||||
|
|
||||||
|
@ -9,6 +9,9 @@ from typing import Optional
|
|||||||
|
|
||||||
import tqdm
|
import tqdm
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
|
|
||||||
|
if settings.AUDIT_LOG_ENABLED:
|
||||||
|
from auditlog.models import LogEntry
|
||||||
from django.contrib.auth.models import Group
|
from django.contrib.auth.models import Group
|
||||||
from django.contrib.auth.models import Permission
|
from django.contrib.auth.models import Permission
|
||||||
from django.contrib.auth.models import User
|
from django.contrib.auth.models import User
|
||||||
@ -307,6 +310,11 @@ class Command(BaseCommand):
|
|||||||
serializers.serialize("json", ApplicationConfiguration.objects.all()),
|
serializers.serialize("json", ApplicationConfiguration.objects.all()),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if settings.AUDIT_LOG_ENABLED:
|
||||||
|
manifest += json.loads(
|
||||||
|
serializers.serialize("json", LogEntry.objects.all()),
|
||||||
|
)
|
||||||
|
|
||||||
# These are treated specially and included in the per-document manifest
|
# These are treated specially and included in the per-document manifest
|
||||||
# if that setting is enabled. Otherwise, they are just exported to the bulk
|
# if that setting is enabled. Otherwise, they are just exported to the bulk
|
||||||
# manifest
|
# manifest
|
||||||
|
@ -21,7 +21,13 @@ from django.db.models.signals import post_save
|
|||||||
from filelock import FileLock
|
from filelock import FileLock
|
||||||
|
|
||||||
from documents.file_handling import create_source_path_directory
|
from documents.file_handling import create_source_path_directory
|
||||||
|
from documents.models import Correspondent
|
||||||
|
from documents.models import CustomField
|
||||||
|
from documents.models import CustomFieldInstance
|
||||||
from documents.models import Document
|
from documents.models import Document
|
||||||
|
from documents.models import DocumentType
|
||||||
|
from documents.models import Note
|
||||||
|
from documents.models import Tag
|
||||||
from documents.parsers import run_convert
|
from documents.parsers import run_convert
|
||||||
from documents.settings import EXPORTER_ARCHIVE_NAME
|
from documents.settings import EXPORTER_ARCHIVE_NAME
|
||||||
from documents.settings import EXPORTER_FILE_NAME
|
from documents.settings import EXPORTER_FILE_NAME
|
||||||
@ -30,6 +36,9 @@ from documents.signals.handlers import update_filename_and_move_files
|
|||||||
from documents.utils import copy_file_with_basic_stats
|
from documents.utils import copy_file_with_basic_stats
|
||||||
from paperless import version
|
from paperless import version
|
||||||
|
|
||||||
|
if settings.AUDIT_LOG_ENABLED:
|
||||||
|
from auditlog.registry import auditlog
|
||||||
|
|
||||||
|
|
||||||
@contextmanager
|
@contextmanager
|
||||||
def disable_signal(sig, receiver, sender):
|
def disable_signal(sig, receiver, sender):
|
||||||
@ -151,6 +160,15 @@ class Command(BaseCommand):
|
|||||||
receiver=update_filename_and_move_files,
|
receiver=update_filename_and_move_files,
|
||||||
sender=Document.tags.through,
|
sender=Document.tags.through,
|
||||||
):
|
):
|
||||||
|
if settings.AUDIT_LOG_ENABLED:
|
||||||
|
auditlog.unregister(Document)
|
||||||
|
auditlog.unregister(Correspondent)
|
||||||
|
auditlog.unregister(Tag)
|
||||||
|
auditlog.unregister(DocumentType)
|
||||||
|
auditlog.unregister(Note)
|
||||||
|
auditlog.unregister(CustomField)
|
||||||
|
auditlog.unregister(CustomFieldInstance)
|
||||||
|
|
||||||
# Fill up the database with whatever is in the manifest
|
# Fill up the database with whatever is in the manifest
|
||||||
try:
|
try:
|
||||||
with transaction.atomic():
|
with transaction.atomic():
|
||||||
|
@ -780,3 +780,17 @@ class TestExportImport(DirectoriesMixin, FileSystemAssertsMixin, TestCase):
|
|||||||
|
|
||||||
self.assertEqual(ContentType.objects.count(), num_content_type_objects)
|
self.assertEqual(ContentType.objects.count(), num_content_type_objects)
|
||||||
self.assertEqual(Permission.objects.count(), num_permission_objects + 1)
|
self.assertEqual(Permission.objects.count(), num_permission_objects + 1)
|
||||||
|
|
||||||
|
def test_exporter_with_auditlog_disabled(self):
|
||||||
|
shutil.rmtree(os.path.join(self.dirs.media_dir, "documents"))
|
||||||
|
shutil.copytree(
|
||||||
|
os.path.join(os.path.dirname(__file__), "samples", "documents"),
|
||||||
|
os.path.join(self.dirs.media_dir, "documents"),
|
||||||
|
)
|
||||||
|
|
||||||
|
with override_settings(
|
||||||
|
AUDIT_LOG_ENABLED=False,
|
||||||
|
):
|
||||||
|
manifest = self._do_export(use_filename_format=True)
|
||||||
|
for obj in manifest:
|
||||||
|
self.assertNotEqual(obj["model"], "auditlog.logentry")
|
||||||
|
@ -5,7 +5,6 @@ import shutil
|
|||||||
import stat
|
import stat
|
||||||
|
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
from django.core.checks import Critical
|
|
||||||
from django.core.checks import Error
|
from django.core.checks import Error
|
||||||
from django.core.checks import Warning
|
from django.core.checks import Warning
|
||||||
from django.core.checks import register
|
from django.core.checks import register
|
||||||
@ -205,13 +204,10 @@ def audit_log_check(app_configs, **kwargs):
|
|||||||
all_tables = db_conn.introspection.table_names()
|
all_tables = db_conn.introspection.table_names()
|
||||||
result = []
|
result = []
|
||||||
|
|
||||||
if ("auditlog_logentry" in all_tables) and not (settings.AUDIT_LOG_ENABLED):
|
if ("auditlog_logentry" in all_tables) and not settings.AUDIT_LOG_ENABLED:
|
||||||
result.append(
|
result.append(
|
||||||
Critical(
|
Warning(
|
||||||
(
|
("auditlog table was found but audit log is disabled."),
|
||||||
"auditlog table was found but PAPERLESS_AUDIT_LOG_ENABLED"
|
|
||||||
" is not active. This setting cannot be disabled after enabling"
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -1045,7 +1045,7 @@ TIKA_GOTENBERG_ENDPOINT = os.getenv(
|
|||||||
if TIKA_ENABLED:
|
if TIKA_ENABLED:
|
||||||
INSTALLED_APPS.append("paperless_tika.apps.PaperlessTikaConfig")
|
INSTALLED_APPS.append("paperless_tika.apps.PaperlessTikaConfig")
|
||||||
|
|
||||||
AUDIT_LOG_ENABLED = __get_boolean("PAPERLESS_AUDIT_LOG_ENABLED", "NO")
|
AUDIT_LOG_ENABLED = __get_boolean("PAPERLESS_AUDIT_LOG_ENABLED", "true")
|
||||||
if AUDIT_LOG_ENABLED:
|
if AUDIT_LOG_ENABLED:
|
||||||
INSTALLED_APPS.append("auditlog")
|
INSTALLED_APPS.append("auditlog")
|
||||||
MIDDLEWARE.append("auditlog.middleware.AuditlogMiddleware")
|
MIDDLEWARE.append("auditlog.middleware.AuditlogMiddleware")
|
||||||
|
@ -259,9 +259,6 @@ class TestAuditLogChecks(TestCase):
|
|||||||
msg = msgs[0]
|
msg = msgs[0]
|
||||||
|
|
||||||
self.assertIn(
|
self.assertIn(
|
||||||
(
|
("auditlog table was found but audit log is disabled."),
|
||||||
"auditlog table was found but PAPERLESS_AUDIT_LOG_ENABLED"
|
|
||||||
" is not active."
|
|
||||||
),
|
|
||||||
msg.msg,
|
msg.msg,
|
||||||
)
|
)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user