Coverage Report

Created: 2026-03-08 06:22

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/pdns/pdns/dnsdistdist/dolog.cc
Line
Count
Source
1
/*
2
 * This file is part of PowerDNS or dnsdist.
3
 * Copyright -- PowerDNS.COM B.V. and its contributors
4
 *
5
 * This program is free software; you can redistribute it and/or modify
6
 * it under the terms of version 2 of the GNU General Public License as
7
 * published by the Free Software Foundation.
8
 *
9
 * In addition, for the avoidance of any doubt, permission is granted to
10
 * link this program with OpenSSL and to (re)distribute the binaries
11
 * produced as the result of such linking.
12
 *
13
 * This program is distributed in the hope that it will be useful,
14
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16
 * GNU General Public License for more details.
17
 *
18
 * You should have received a copy of the GNU General Public License
19
 * along with this program; if not, write to the Free Software
20
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
21
 */
22
23
#include <mutex>
24
#include <sys/time.h>
25
26
#include "dolog.hh"
27
28
namespace dnsdist::logging
29
{
30
std::optional<std::ofstream> LoggingConfiguration::s_verboseStream{std::nullopt};
31
bool LoggingConfiguration::s_logTimestamps{false};
32
bool LoggingConfiguration::s_syslog{true};
33
34
void logTime(std::ostream& stream)
35
0
{
36
0
  std::array<char, 50> buffer{""};
37
38
0
  time_t now{};
39
0
  time(&now);
40
0
  struct tm localNow{};
41
0
  localtime_r(&now, &localNow);
42
43
0
  {
44
    // strftime is not thread safe, it can access locale information
45
0
    static std::mutex mutex;
46
0
    auto lock = std::scoped_lock(mutex);
47
48
0
    if (strftime(buffer.data(), buffer.size(), "%b %d %H:%M:%S ", &localNow) == 0) {
49
0
      buffer[0] = '\0';
50
0
    }
51
0
  }
52
53
0
  stream << buffer.data();
54
0
}
55
56
}