ModSecurity/src/audit_log_writer_serial.cc
2015-09-02 10:55:29 -03:00

67 lines
1.5 KiB
C++

/*
* ModSecurity, http://www.modsecurity.org/
* Copyright (c) 2015 Trustwave Holdings, Inc. (http://www.trustwave.com/)
*
* You may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* If any of the files related to licensing are missing or if you have any
* other questions related to licensing please contact Trustwave Holdings, Inc.
* directly using the email address security@modsecurity.org.
*
*/
#include "src/audit_log_writer_serial.h"
// #include <mutex>
#include "src/audit_log.h"
namespace ModSecurity {
// static std::mutex serialLoggingMutex;
AuditLogWriterSerial::~AuditLogWriterSerial() {
m_log.close();
}
void AuditLogWriterSerial::generateBoundary(std::string *boundary) {
static const char alphanum[] =
"0123456789"
"ABCDEFGHIJKLMNOPQRSTUVWXYZ"
"abcdefghijklmnopqrstuvwxyz";
for (int i = 0; i < SERIAL_AUDIT_LOG_BOUNDARY_LENGTH; ++i) {
boundary->append(1, alphanum[rand() % (sizeof(alphanum) - 1)]);
}
}
bool AuditLogWriterSerial::init() {
m_log.open(m_audit->m_path1, std::fstream::out | std::fstream::app);
return true;
}
bool AuditLogWriterSerial::write(Assay *assay, int parts) {
std::string boundary;
generateBoundary(&boundary);
// serialLoggingMutex.lock();
m_log << assay->toOldAuditLogFormat(parts, "-" + boundary + "--");
m_log.flush();
// serialLoggingMutex.unlock();
return true;
}
} // namespace ModSecurity