Automatic audit logging using SQLA events

This commit is contained in:
richard-dds
2018-09-19 11:41:27 -04:00
parent b7a33de29d
commit ddc2e2fad7
27 changed files with 346 additions and 26 deletions

53
atst/domain/audit_log.py Normal file
View File

@@ -0,0 +1,53 @@
from atst.database import db
from atst.domain.common import Query
from atst.domain.authz import Authorization, Permissions
from atst.models.audit_event import AuditEvent
class AuditEventQuery(Query):
model = AuditEvent
@classmethod
def get_all(cls):
return db.session.query(cls.model).order_by(cls.model.time_created.desc()).all()
class AuditLog(object):
@classmethod
def log_event(cls, user, resource, action):
return cls._log(user=user, resource=resource, action=action)
@classmethod
def log_workspace_event(cls, user, workspace, resource, action):
return cls._log(
user=user, workspace_id=workspace.id, resource=resource, action=action
)
@classmethod
def log_system_event(cls, resource, action):
return cls._log(resource=resource, action=action)
@classmethod
def get_all_events(cls, user):
Authorization.check_atat_permission(
user, Permissions.VIEW_AUDIT_LOG, "view audit log"
)
return AuditEventQuery.get_all()
@classmethod
def _resource_name(cls, resource):
return type(resource).__name__.lower()
@classmethod
def _log(cls, user=None, workspace_id=None, resource=None, action=None):
resource_id = resource.id if resource else None
resource_name = cls._resource_name(resource) if resource else None
audit_event = AuditEventQuery.create(
user=user,
workspace_id=workspace_id,
resource_id=resource_id,
resource_name=resource_name,
action=action,
)
return AuditEventQuery.add_and_commit(audit_event)

View File

@@ -34,6 +34,10 @@ def get_current_user():
else:
return False
def logout():
if session.get("user_id"):
del (session["user_id"])
def _unprotected_route(request):
if request.endpoint in UNPROTECTED_ROUTES:

View File

@@ -43,3 +43,12 @@ class Authorization(object):
def check_workspace_permission(cls, user, workspace, permission, message):
if not Authorization.has_workspace_permission(user, workspace, permission):
raise UnauthorizedError(user, message)
@classmethod
def check_atat_permission(cls, user, permission, message):
if not Authorization.has_atat_permission(user, permission):
raise UnauthorizedError(user, message)
@classmethod
def can_view_audit_log(cls, user):
return Authorization.has_atat_permission(user, Permissions.VIEW_AUDIT_LOG)