From 2fb026b0fe7e35dfabcb90b79fae3e60f9f95340 Mon Sep 17 00:00:00 2001 From: Mark Reynolds Date: Wed, 7 Aug 2019 16:57:17 -0400 Subject: [PATCH] Issue 50536 - Audit log heading written to log after every update Bug Description: Once the audit log is rotated the log "title" is incorrectly written to the log after every single update. This happened becuase when we udpated the state of the log it was applied to a local variable, and not the log info structure itself. Fix Description: After writting the "title", update the state of the log using a pointer to the log info structure. relates: https://pagure.io/389-ds-base/issue/50536 Reviewed by: lkrispenz(Thanks!) --- ldap/servers/slapd/log.c | 14 +++++++------- ldap/servers/slapd/proto-slap.h | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/ldap/servers/slapd/log.c b/ldap/servers/slapd/log.c index 2456abf1e..f308a4813 100644 --- a/ldap/servers/slapd/log.c +++ b/ldap/servers/slapd/log.c @@ -2073,11 +2073,11 @@ slapd_log_audit( int retval = LDAP_SUCCESS; int lbackend = loginfo.log_backend; /* We copy this to make these next checks atomic */ - int state = 0; + int *state; if (sourcelog == SLAPD_AUDIT_LOG) { - state = loginfo.log_audit_state; + state = &loginfo.log_audit_state; } else if (sourcelog == SLAPD_AUDITFAIL_LOG) { - state = loginfo.log_auditfail_state; + state = &loginfo.log_auditfail_state; } else { /* How did we even get here! */ return 1; @@ -2106,9 +2106,9 @@ int slapd_log_audit_internal( char *buffer, int buf_len, - int state) + int *state) { - if ((state & LOGGING_ENABLED) && (loginfo.log_audit_file != NULL)) { + if ((*state & LOGGING_ENABLED) && (loginfo.log_audit_file != NULL)) { LOG_AUDIT_LOCK_WRITE(); if (log__needrotation(loginfo.log_audit_fdes, SLAPD_AUDIT_LOG) == LOG_ROTATE) { @@ -2122,9 +2122,9 @@ slapd_log_audit_internal( loginfo.log_audit_rotationsyncclock += PR_ABS(loginfo.log_audit_rotationtime_secs); } } - if (state & LOGGING_NEED_TITLE) { + if (*state & LOGGING_NEED_TITLE) { log_write_title(loginfo.log_audit_fdes); - state &= ~LOGGING_NEED_TITLE; + *state &= ~LOGGING_NEED_TITLE; } LOG_WRITE_NOW_NO_ERR(loginfo.log_audit_fdes, buffer, buf_len, 0); LOG_AUDIT_UNLOCK_WRITE(); diff --git a/ldap/servers/slapd/proto-slap.h b/ldap/servers/slapd/proto-slap.h index a0648ca3c..e37f702ea 100644 --- a/ldap/servers/slapd/proto-slap.h +++ b/ldap/servers/slapd/proto-slap.h @@ -777,7 +777,7 @@ int slapi_log_access(int level, char *fmt, ...) ; #endif int slapd_log_audit(char *buffer, int buf_len, int sourcelog); -int slapd_log_audit_internal(char *buffer, int buf_len, int state); +int slapd_log_audit_internal(char *buffer, int buf_len, int *state); int slapd_log_auditfail(char *buffer, int buf_len); int slapd_log_auditfail_internal(char *buffer, int buf_len); void log_access_flush(void); -- 2.21.0