mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-10 05:03:43 +01:00
Finally extract the log library and make it build.
This patch: - introduces an fdio module for low-level fd functions that don't need to log. - moves the responsibility for opening files outside of torlog.c, so it won't need to call tor_open_cloexec.
This commit is contained in:
parent
90a09df5ba
commit
79f73ab330
@ -42,6 +42,7 @@ TOR_UTIL_LIBS = \
|
|||||||
src/common/libor.a \
|
src/common/libor.a \
|
||||||
src/lib/libtor-log.a \
|
src/lib/libtor-log.a \
|
||||||
src/lib/libtor-lock.a \
|
src/lib/libtor-lock.a \
|
||||||
|
src/lib/libtor-fdio.a \
|
||||||
src/lib/libtor-container.a \
|
src/lib/libtor-container.a \
|
||||||
src/lib/libtor-string.a \
|
src/lib/libtor-string.a \
|
||||||
src/lib/libtor-malloc.a \
|
src/lib/libtor-malloc.a \
|
||||||
@ -56,6 +57,7 @@ TOR_UTIL_TESTING_LIBS = \
|
|||||||
src/common/libor-testing.a \
|
src/common/libor-testing.a \
|
||||||
src/lib/libtor-log-testing.a \
|
src/lib/libtor-log-testing.a \
|
||||||
src/lib/libtor-lock-testing.a \
|
src/lib/libtor-lock-testing.a \
|
||||||
|
src/lib/libtor-fdio-testing.a \
|
||||||
src/lib/libtor-container-testing.a \
|
src/lib/libtor-container-testing.a \
|
||||||
src/lib/libtor-string-testing.a \
|
src/lib/libtor-string-testing.a \
|
||||||
src/lib/libtor-malloc-testing.a \
|
src/lib/libtor-malloc-testing.a \
|
||||||
|
@ -733,80 +733,6 @@ tor_lockfile_unlock(tor_lockfile_t *lockfile)
|
|||||||
tor_free(lockfile);
|
tor_free(lockfile);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @{ */
|
|
||||||
/** Some old versions of Unix didn't define constants for these values,
|
|
||||||
* and instead expect you to say 0, 1, or 2. */
|
|
||||||
#ifndef SEEK_SET
|
|
||||||
#define SEEK_SET 0
|
|
||||||
#endif
|
|
||||||
#ifndef SEEK_CUR
|
|
||||||
#define SEEK_CUR 1
|
|
||||||
#endif
|
|
||||||
#ifndef SEEK_END
|
|
||||||
#define SEEK_END 2
|
|
||||||
#endif
|
|
||||||
/** @} */
|
|
||||||
|
|
||||||
/** Return the position of <b>fd</b> with respect to the start of the file. */
|
|
||||||
off_t
|
|
||||||
tor_fd_getpos(int fd)
|
|
||||||
{
|
|
||||||
#ifdef _WIN32
|
|
||||||
return (off_t) _lseek(fd, 0, SEEK_CUR);
|
|
||||||
#else
|
|
||||||
return (off_t) lseek(fd, 0, SEEK_CUR);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Move <b>fd</b> to the end of the file. Return -1 on error, 0 on success.
|
|
||||||
* If the file is a pipe, do nothing and succeed.
|
|
||||||
**/
|
|
||||||
int
|
|
||||||
tor_fd_seekend(int fd)
|
|
||||||
{
|
|
||||||
#ifdef _WIN32
|
|
||||||
return _lseek(fd, 0, SEEK_END) < 0 ? -1 : 0;
|
|
||||||
#else
|
|
||||||
off_t rc = lseek(fd, 0, SEEK_END) < 0 ? -1 : 0;
|
|
||||||
#ifdef ESPIPE
|
|
||||||
/* If we get an error and ESPIPE, then it's a pipe or a socket of a fifo:
|
|
||||||
* no need to worry. */
|
|
||||||
if (rc < 0 && errno == ESPIPE)
|
|
||||||
rc = 0;
|
|
||||||
#endif /* defined(ESPIPE) */
|
|
||||||
return (rc < 0) ? -1 : 0;
|
|
||||||
#endif /* defined(_WIN32) */
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Move <b>fd</b> to position <b>pos</b> in the file. Return -1 on error, 0
|
|
||||||
* on success. */
|
|
||||||
int
|
|
||||||
tor_fd_setpos(int fd, off_t pos)
|
|
||||||
{
|
|
||||||
#ifdef _WIN32
|
|
||||||
return _lseek(fd, pos, SEEK_SET) < 0 ? -1 : 0;
|
|
||||||
#else
|
|
||||||
return lseek(fd, pos, SEEK_SET) < 0 ? -1 : 0;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Replacement for ftruncate(fd, 0): move to the front of the file and remove
|
|
||||||
* all the rest of the file. Return -1 on error, 0 on success. */
|
|
||||||
int
|
|
||||||
tor_ftruncate(int fd)
|
|
||||||
{
|
|
||||||
/* Rumor has it that some versions of ftruncate do not move the file pointer.
|
|
||||||
*/
|
|
||||||
if (tor_fd_setpos(fd, 0) < 0)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
|
||||||
return _chsize(fd, 0);
|
|
||||||
#else
|
|
||||||
return ftruncate(fd, 0);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
#undef DEBUG_SOCKET_COUNTING
|
#undef DEBUG_SOCKET_COUNTING
|
||||||
#ifdef DEBUG_SOCKET_COUNTING
|
#ifdef DEBUG_SOCKET_COUNTING
|
||||||
/** A bitarray of all fds that should be passed to tor_socket_close(). Only
|
/** A bitarray of all fds that should be passed to tor_socket_close(). Only
|
||||||
@ -2641,7 +2567,6 @@ compute_num_cpus(void)
|
|||||||
return num_cpus;
|
return num_cpus;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/** As localtime_r, but defined for platforms that don't have it:
|
/** As localtime_r, but defined for platforms that don't have it:
|
||||||
*
|
*
|
||||||
* Convert *<b>timep</b> to a struct tm in local time, and store the value in
|
* Convert *<b>timep</b> to a struct tm in local time, and store the value in
|
||||||
|
@ -160,11 +160,6 @@ tor_lockfile_t *tor_lockfile_lock(const char *filename, int blocking,
|
|||||||
int *locked_out);
|
int *locked_out);
|
||||||
void tor_lockfile_unlock(tor_lockfile_t *lockfile);
|
void tor_lockfile_unlock(tor_lockfile_t *lockfile);
|
||||||
|
|
||||||
off_t tor_fd_getpos(int fd);
|
|
||||||
int tor_fd_setpos(int fd, off_t pos);
|
|
||||||
int tor_fd_seekend(int fd);
|
|
||||||
int tor_ftruncate(int fd);
|
|
||||||
|
|
||||||
int64_t tor_get_avail_disk_space(const char *path);
|
int64_t tor_get_avail_disk_space(const char *path);
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
#include "lib/crypt_ops/crypto_digest.h"
|
#include "lib/crypt_ops/crypto_digest.h"
|
||||||
#include "lib/cc/torint.h"
|
#include "lib/cc/torint.h"
|
||||||
#include "lib/container/smartlist.h"
|
#include "lib/container/smartlist.h"
|
||||||
|
#include "lib/fdio/fdio.h"
|
||||||
#include "common/address.h"
|
#include "common/address.h"
|
||||||
#include "common/sandbox.h"
|
#include "common/sandbox.h"
|
||||||
#include "lib/err/backtrace.h"
|
#include "lib/err/backtrace.h"
|
||||||
|
@ -6,6 +6,7 @@ include src/lib/compress/include.am
|
|||||||
include src/lib/container/include.am
|
include src/lib/container/include.am
|
||||||
include src/lib/crypt_ops/include.am
|
include src/lib/crypt_ops/include.am
|
||||||
include src/lib/defs/include.am
|
include src/lib/defs/include.am
|
||||||
|
include src/lib/fdio/include.am
|
||||||
include src/lib/include.libdonna.am
|
include src/lib/include.libdonna.am
|
||||||
include src/lib/intmath/include.am
|
include src/lib/intmath/include.am
|
||||||
include src/lib/lock/include.am
|
include src/lib/lock/include.am
|
||||||
|
4
src/lib/fdio/.may_include
Normal file
4
src/lib/fdio/.may_include
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
orconfig.h
|
||||||
|
lib/cc/*.h
|
||||||
|
lib/err/*.h
|
||||||
|
lib/fdio/*.h
|
109
src/lib/fdio/fdio.c
Normal file
109
src/lib/fdio/fdio.c
Normal file
@ -0,0 +1,109 @@
|
|||||||
|
/* Copyright (c) 2003-2004, Roger Dingledine
|
||||||
|
* Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
|
||||||
|
* Copyright (c) 2007-2018, The Tor Project, Inc. */
|
||||||
|
/* See LICENSE for licensing information */
|
||||||
|
|
||||||
|
#include "orconfig.h"
|
||||||
|
|
||||||
|
#ifdef HAVE_UNISTD_H
|
||||||
|
#include <unistd.h>
|
||||||
|
#endif
|
||||||
|
#ifdef _WIN32
|
||||||
|
#include <windows.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "lib/fdio/fdio.h"
|
||||||
|
#include "lib/cc/torint.h"
|
||||||
|
#include "lib/err/torerr.h"
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
/** @{ */
|
||||||
|
/** Some old versions of Unix didn't define constants for these values,
|
||||||
|
* and instead expect you to say 0, 1, or 2. */
|
||||||
|
#ifndef SEEK_SET
|
||||||
|
#define SEEK_SET 0
|
||||||
|
#endif
|
||||||
|
#ifndef SEEK_CUR
|
||||||
|
#define SEEK_CUR 1
|
||||||
|
#endif
|
||||||
|
#ifndef SEEK_END
|
||||||
|
#define SEEK_END 2
|
||||||
|
#endif
|
||||||
|
/** @} */
|
||||||
|
|
||||||
|
/** Return the position of <b>fd</b> with respect to the start of the file. */
|
||||||
|
off_t
|
||||||
|
tor_fd_getpos(int fd)
|
||||||
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
|
return (off_t) _lseek(fd, 0, SEEK_CUR);
|
||||||
|
#else
|
||||||
|
return (off_t) lseek(fd, 0, SEEK_CUR);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Move <b>fd</b> to the end of the file. Return -1 on error, 0 on success.
|
||||||
|
* If the file is a pipe, do nothing and succeed.
|
||||||
|
**/
|
||||||
|
int
|
||||||
|
tor_fd_seekend(int fd)
|
||||||
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
|
return _lseek(fd, 0, SEEK_END) < 0 ? -1 : 0;
|
||||||
|
#else
|
||||||
|
off_t rc = lseek(fd, 0, SEEK_END) < 0 ? -1 : 0;
|
||||||
|
#ifdef ESPIPE
|
||||||
|
/* If we get an error and ESPIPE, then it's a pipe or a socket of a fifo:
|
||||||
|
* no need to worry. */
|
||||||
|
if (rc < 0 && errno == ESPIPE)
|
||||||
|
rc = 0;
|
||||||
|
#endif /* defined(ESPIPE) */
|
||||||
|
return (rc < 0) ? -1 : 0;
|
||||||
|
#endif /* defined(_WIN32) */
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Move <b>fd</b> to position <b>pos</b> in the file. Return -1 on error, 0
|
||||||
|
* on success. */
|
||||||
|
int
|
||||||
|
tor_fd_setpos(int fd, off_t pos)
|
||||||
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
|
return _lseek(fd, pos, SEEK_SET) < 0 ? -1 : 0;
|
||||||
|
#else
|
||||||
|
return lseek(fd, pos, SEEK_SET) < 0 ? -1 : 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Replacement for ftruncate(fd, 0): move to the front of the file and remove
|
||||||
|
* all the rest of the file. Return -1 on error, 0 on success. */
|
||||||
|
int
|
||||||
|
tor_ftruncate(int fd)
|
||||||
|
{
|
||||||
|
/* Rumor has it that some versions of ftruncate do not move the file pointer.
|
||||||
|
*/
|
||||||
|
if (tor_fd_setpos(fd, 0) < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
return _chsize(fd, 0);
|
||||||
|
#else
|
||||||
|
return ftruncate(fd, 0);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Minimal version of write_all, for use by logging. */
|
||||||
|
int
|
||||||
|
write_all_to_fd(int fd, const char *buf, size_t count)
|
||||||
|
{
|
||||||
|
size_t written = 0;
|
||||||
|
raw_assert(count < SSIZE_MAX);
|
||||||
|
|
||||||
|
while (written < count) {
|
||||||
|
ssize_t result = write(fd, buf+written, count-written);
|
||||||
|
if (result<0)
|
||||||
|
return -1;
|
||||||
|
written += result;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
17
src/lib/fdio/fdio.h
Normal file
17
src/lib/fdio/fdio.h
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
/* Copyright (c) 2003-2004, Roger Dingledine
|
||||||
|
* Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
|
||||||
|
* Copyright (c) 2007-2018, The Tor Project, Inc. */
|
||||||
|
/* See LICENSE for licensing information */
|
||||||
|
|
||||||
|
#ifndef TOR_FDIO_H
|
||||||
|
#define TOR_FDIO_H
|
||||||
|
|
||||||
|
#include <stddef.h>
|
||||||
|
|
||||||
|
off_t tor_fd_getpos(int fd);
|
||||||
|
int tor_fd_setpos(int fd, off_t pos);
|
||||||
|
int tor_fd_seekend(int fd);
|
||||||
|
int tor_ftruncate(int fd);
|
||||||
|
int write_all_to_fd(int fd, const char *buf, size_t count);
|
||||||
|
|
||||||
|
#endif /* !defined(TOR_FDIO_H) */
|
17
src/lib/fdio/include.am
Normal file
17
src/lib/fdio/include.am
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
|
||||||
|
noinst_LIBRARIES += src/lib/libtor-fdio.a
|
||||||
|
|
||||||
|
if UNITTESTS_ENABLED
|
||||||
|
noinst_LIBRARIES += src/lib/libtor-fdio-testing.a
|
||||||
|
endif
|
||||||
|
|
||||||
|
src_lib_libtor_fdio_a_SOURCES = \
|
||||||
|
src/lib/fdio/fdio.c
|
||||||
|
|
||||||
|
src_lib_libtor_fdio_testing_a_SOURCES = \
|
||||||
|
$(src_lib_libtor_fdio_a_SOURCES)
|
||||||
|
src_lib_libtor_fdio_testing_a_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_CPPFLAGS)
|
||||||
|
src_lib_libtor_fdio_testing_a_CFLAGS = $(AM_CFLAGS) $(TEST_CFLAGS)
|
||||||
|
|
||||||
|
noinst_HEADERS += \
|
||||||
|
src/lib/fdio/fdio.h
|
@ -37,11 +37,14 @@
|
|||||||
#include "lib/container/smartlist.h"
|
#include "lib/container/smartlist.h"
|
||||||
#include "lib/err/torerr.h"
|
#include "lib/err/torerr.h"
|
||||||
#include "lib/intmath/bits.h"
|
#include "lib/intmath/bits.h"
|
||||||
|
#include "lib/string/compat_string.h"
|
||||||
|
#include "lib/string/printf.h"
|
||||||
#include "lib/malloc/util_malloc.h"
|
#include "lib/malloc/util_malloc.h"
|
||||||
#include "lib/string/util_string.h"
|
#include "lib/string/util_string.h"
|
||||||
#include "lib/wallclock/tor_gettimeofday.h"
|
#include "lib/wallclock/tor_gettimeofday.h"
|
||||||
#include "lib/wallclock/approx_time.h"
|
#include "lib/wallclock/approx_time.h"
|
||||||
#include "lib/wallclock/tm_cvt.h"
|
#include "lib/wallclock/tm_cvt.h"
|
||||||
|
#include "lib/fdio/fdio.h"
|
||||||
|
|
||||||
#ifdef HAVE_ANDROID_LOG_H
|
#ifdef HAVE_ANDROID_LOG_H
|
||||||
#include <android/log.h>
|
#include <android/log.h>
|
||||||
@ -201,12 +204,12 @@ static int pretty_fn_has_parens = 0;
|
|||||||
|
|
||||||
/** Lock the log_mutex to prevent others from changing the logfile_t list */
|
/** Lock the log_mutex to prevent others from changing the logfile_t list */
|
||||||
#define LOCK_LOGS() STMT_BEGIN \
|
#define LOCK_LOGS() STMT_BEGIN \
|
||||||
tor_assert(log_mutex_initialized); \
|
raw_assert(log_mutex_initialized); \
|
||||||
tor_mutex_acquire(&log_mutex); \
|
tor_mutex_acquire(&log_mutex); \
|
||||||
STMT_END
|
STMT_END
|
||||||
/** Unlock the log_mutex */
|
/** Unlock the log_mutex */
|
||||||
#define UNLOCK_LOGS() STMT_BEGIN \
|
#define UNLOCK_LOGS() STMT_BEGIN \
|
||||||
tor_assert(log_mutex_initialized); \
|
raw_assert(log_mutex_initialized); \
|
||||||
tor_mutex_release(&log_mutex); \
|
tor_mutex_release(&log_mutex); \
|
||||||
STMT_END
|
STMT_END
|
||||||
|
|
||||||
@ -310,22 +313,6 @@ log_prefix_(char *buf, size_t buf_len, int severity)
|
|||||||
return n+r;
|
return n+r;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Minimal version of write_all, for use by logging. */
|
|
||||||
static int
|
|
||||||
write_all_to_fd(int fd, const char *buf, size_t count)
|
|
||||||
{
|
|
||||||
size_t written = 0;
|
|
||||||
raw_assert(count < SSIZE_MAX);
|
|
||||||
|
|
||||||
while (written < count) {
|
|
||||||
ssize_t result = write(fd, buf+written, count-written);
|
|
||||||
if (result<0)
|
|
||||||
return -1;
|
|
||||||
written += result;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** If lf refers to an actual file that we have just opened, and the file
|
/** If lf refers to an actual file that we have just opened, and the file
|
||||||
* contains no data, log an "opening new logfile" message at the top.
|
* contains no data, log an "opening new logfile" message at the top.
|
||||||
*
|
*
|
||||||
@ -596,7 +583,7 @@ logv,(int severity, log_domain_mask_t domain, const char *funcname,
|
|||||||
char *end_of_prefix=NULL;
|
char *end_of_prefix=NULL;
|
||||||
int callbacks_deferred = 0;
|
int callbacks_deferred = 0;
|
||||||
|
|
||||||
/* Call assert, not tor_assert, since tor_assert calls log on failure. */
|
/* Call assert, not raw_assert, since raw_assert calls log on failure. */
|
||||||
raw_assert(format);
|
raw_assert(format);
|
||||||
/* check that severity is sane. Overrunning the masks array leads to
|
/* check that severity is sane. Overrunning the masks array leads to
|
||||||
* interesting and hard to diagnose effects */
|
* interesting and hard to diagnose effects */
|
||||||
@ -711,7 +698,7 @@ tor_log_update_sigsafe_err_fds(void)
|
|||||||
if (!found_real_stderr &&
|
if (!found_real_stderr &&
|
||||||
int_array_contains(fds, n_fds, STDOUT_FILENO)) {
|
int_array_contains(fds, n_fds, STDOUT_FILENO)) {
|
||||||
/* Don't use a virtual stderr when we're also logging to stdout. */
|
/* Don't use a virtual stderr when we're also logging to stdout. */
|
||||||
raw_assert(n_fds >= 2); /* Don't tor_assert inside log fns */
|
raw_assert(n_fds >= 2); /* Don't raw_assert inside log fns */
|
||||||
fds[0] = fds[--n_fds];
|
fds[0] = fds[--n_fds];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -726,7 +713,7 @@ void
|
|||||||
tor_log_get_logfile_names(smartlist_t *out)
|
tor_log_get_logfile_names(smartlist_t *out)
|
||||||
{
|
{
|
||||||
logfile_t *lf;
|
logfile_t *lf;
|
||||||
tor_assert(out);
|
raw_assert(out);
|
||||||
|
|
||||||
LOCK_LOGS();
|
LOCK_LOGS();
|
||||||
|
|
||||||
@ -839,8 +826,8 @@ delete_log(logfile_t *victim)
|
|||||||
logfiles = victim->next;
|
logfiles = victim->next;
|
||||||
else {
|
else {
|
||||||
for (tmpl = logfiles; tmpl && tmpl->next != victim; tmpl=tmpl->next) ;
|
for (tmpl = logfiles; tmpl && tmpl->next != victim; tmpl=tmpl->next) ;
|
||||||
// tor_assert(tmpl);
|
// raw_assert(tmpl);
|
||||||
// tor_assert(tmpl->next == victim);
|
// raw_assert(tmpl->next == victim);
|
||||||
if (!tmpl)
|
if (!tmpl)
|
||||||
return;
|
return;
|
||||||
tmpl->next = victim->next;
|
tmpl->next = victim->next;
|
||||||
@ -874,9 +861,9 @@ set_log_severity_config(int loglevelMin, int loglevelMax,
|
|||||||
log_severity_list_t *severity_out)
|
log_severity_list_t *severity_out)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
tor_assert(loglevelMin >= loglevelMax);
|
raw_assert(loglevelMin >= loglevelMax);
|
||||||
tor_assert(loglevelMin >= LOG_ERR && loglevelMin <= LOG_DEBUG);
|
raw_assert(loglevelMin >= LOG_ERR && loglevelMin <= LOG_DEBUG);
|
||||||
tor_assert(loglevelMax >= LOG_ERR && loglevelMax <= LOG_DEBUG);
|
raw_assert(loglevelMax >= LOG_ERR && loglevelMax <= LOG_DEBUG);
|
||||||
memset(severity_out, 0, sizeof(log_severity_list_t));
|
memset(severity_out, 0, sizeof(log_severity_list_t));
|
||||||
for (i = loglevelMin; i >= loglevelMax; --i) {
|
for (i = loglevelMin; i >= loglevelMax; --i) {
|
||||||
severity_out->masks[SEVERITY_MASK_IDX(i)] = ~0u;
|
severity_out->masks[SEVERITY_MASK_IDX(i)] = ~0u;
|
||||||
@ -1146,20 +1133,17 @@ mark_logs_temp(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add a log handler to send messages to <b>filename</b>. If opening the
|
* Add a log handler to send messages to <b>filename</b> via <b>fd</b>. If
|
||||||
* logfile fails, -1 is returned and errno is set appropriately (by open(2)).
|
* opening the logfile failed, -1 is returned and errno is set appropriately
|
||||||
|
* (by open(2)). Takes ownership of fd.
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
add_file_log(const log_severity_list_t *severity, const char *filename,
|
add_file_log(const log_severity_list_t *severity,
|
||||||
const int truncate_log)
|
const char *filename,
|
||||||
|
int fd)
|
||||||
{
|
{
|
||||||
int fd;
|
|
||||||
logfile_t *lf;
|
logfile_t *lf;
|
||||||
|
|
||||||
int open_flags = O_WRONLY|O_CREAT;
|
|
||||||
open_flags |= truncate_log ? O_TRUNC : O_APPEND;
|
|
||||||
|
|
||||||
fd = tor_open_cloexec(filename, open_flags, 0640);
|
|
||||||
if (fd<0)
|
if (fd<0)
|
||||||
return -1;
|
return -1;
|
||||||
if (tor_fd_seekend(fd)<0) {
|
if (tor_fd_seekend(fd)<0) {
|
||||||
|
@ -145,8 +145,10 @@ void set_log_severity_config(int minSeverity, int maxSeverity,
|
|||||||
log_severity_list_t *severity_out);
|
log_severity_list_t *severity_out);
|
||||||
void add_stream_log(const log_severity_list_t *severity, const char *name,
|
void add_stream_log(const log_severity_list_t *severity, const char *name,
|
||||||
int fd);
|
int fd);
|
||||||
int add_file_log(const log_severity_list_t *severity, const char *filename,
|
int add_file_log(const log_severity_list_t *severity,
|
||||||
const int truncate);
|
const char *filename,
|
||||||
|
int fd);
|
||||||
|
|
||||||
#ifdef HAVE_SYSLOG_H
|
#ifdef HAVE_SYSLOG_H
|
||||||
int add_syslog_log(const log_severity_list_t *severity,
|
int add_syslog_log(const log_severity_list_t *severity,
|
||||||
const char* syslog_identity_tag);
|
const char* syslog_identity_tag);
|
||||||
|
@ -5637,6 +5637,23 @@ addressmap_register_auto(const char *from, const char *to,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* As add_file_log, but open the file as appropriate.
|
||||||
|
*/
|
||||||
|
STATIC int
|
||||||
|
open_and_add_file_log(const log_severity_list_t *severity,
|
||||||
|
const char *filename, int truncate_log)
|
||||||
|
{
|
||||||
|
int open_flags = O_WRONLY|O_CREAT;
|
||||||
|
open_flags |= truncate_log ? O_TRUNC : O_APPEND;
|
||||||
|
|
||||||
|
int fd = tor_open_cloexec(filename, open_flags, 0640);
|
||||||
|
if (fd < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
return add_file_log(severity, filename, fd);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initialize the logs based on the configuration file.
|
* Initialize the logs based on the configuration file.
|
||||||
*/
|
*/
|
||||||
@ -5762,7 +5779,7 @@ options_init_logs(const or_options_t *old_options, or_options_t *options,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (add_file_log(severity, fname, truncate_log) < 0) {
|
if (open_and_add_file_log(severity, fname, truncate_log) < 0) {
|
||||||
log_warn(LD_CONFIG, "Couldn't open file for 'Log %s': %s",
|
log_warn(LD_CONFIG, "Couldn't open file for 'Log %s': %s",
|
||||||
opt->value, strerror(errno));
|
opt->value, strerror(errno));
|
||||||
ok = 0;
|
ok = 0;
|
||||||
@ -8452,4 +8469,3 @@ options_any_client_port_set(const or_options_t *options)
|
|||||||
options->DNSPort_set ||
|
options->DNSPort_set ||
|
||||||
options->HTTPTunnelPort_set);
|
options->HTTPTunnelPort_set);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -271,8 +271,10 @@ STATIC int check_bridge_distribution_setting(const char *bd);
|
|||||||
|
|
||||||
STATIC uint64_t compute_real_max_mem_in_queues(const uint64_t val,
|
STATIC uint64_t compute_real_max_mem_in_queues(const uint64_t val,
|
||||||
int log_guess);
|
int log_guess);
|
||||||
|
STATIC int open_and_add_file_log(const log_severity_list_t *severity,
|
||||||
|
const char *fname,
|
||||||
|
int truncate_log);
|
||||||
|
|
||||||
#endif /* defined(CONFIG_PRIVATE) */
|
#endif /* defined(CONFIG_PRIVATE) */
|
||||||
|
|
||||||
#endif /* !defined(TOR_CONFIG_H) */
|
#endif /* !defined(TOR_CONFIG_H) */
|
||||||
|
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
#include "siphash.h"
|
#include "siphash.h"
|
||||||
#include "lib/cc/torint.h"
|
#include "lib/cc/torint.h"
|
||||||
#include "lib/log/torlog.h"
|
#include "lib/log/torlog.h"
|
||||||
|
#include "lib/fdio/fdio.h"
|
||||||
#include "common/util.h"
|
#include "common/util.h"
|
||||||
#include "common/util_format.h"
|
#include "common/util_format.h"
|
||||||
|
|
||||||
@ -498,4 +499,3 @@ keypin_clear(void)
|
|||||||
bad_entries);
|
bad_entries);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,6 +9,9 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "or/or.h"
|
#include "or/or.h"
|
||||||
|
|
||||||
|
#include "lib/fdio/fdio.h"
|
||||||
|
|
||||||
#include "or/circuitbuild.h"
|
#include "or/circuitbuild.h"
|
||||||
#include "or/config.h"
|
#include "or/config.h"
|
||||||
#include "or/directory.h"
|
#include "or/directory.h"
|
||||||
@ -1047,4 +1050,3 @@ usable_consensus_flavor,(void))
|
|||||||
return FLAV_NS;
|
return FLAV_NS;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,8 +1,11 @@
|
|||||||
/* Copyright (c) 2013-2018, The Tor Project, Inc. */
|
/* Copyright (c) 2013-2018, The Tor Project, Inc. */
|
||||||
/* See LICENSE for licensing information */
|
/* See LICENSE for licensing information */
|
||||||
|
|
||||||
|
#define CONFIG_PRIVATE
|
||||||
|
|
||||||
#include "orconfig.h"
|
#include "orconfig.h"
|
||||||
#include "or/or.h"
|
#include "or/or.h"
|
||||||
|
#include "or/config.h"
|
||||||
#include "lib/err/torerr.h"
|
#include "lib/err/torerr.h"
|
||||||
#include "lib/log/torlog.h"
|
#include "lib/log/torlog.h"
|
||||||
#include "test/test.h"
|
#include "test/test.h"
|
||||||
@ -90,7 +93,7 @@ test_sigsafe_err(void *arg)
|
|||||||
|
|
||||||
init_logging(1);
|
init_logging(1);
|
||||||
mark_logs_temp();
|
mark_logs_temp();
|
||||||
add_file_log(&include_bug, fn, 0);
|
open_and_add_file_log(&include_bug, fn, 0);
|
||||||
tor_log_update_sigsafe_err_fds();
|
tor_log_update_sigsafe_err_fds();
|
||||||
close_temp_logs();
|
close_temp_logs();
|
||||||
|
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
#include "common/util_process.h"
|
#include "common/util_process.h"
|
||||||
#include "test/log_test_helpers.h"
|
#include "test/log_test_helpers.h"
|
||||||
#include "lib/compress/compress_zstd.h"
|
#include "lib/compress/compress_zstd.h"
|
||||||
|
#include "lib/fdio/fdio.h"
|
||||||
|
|
||||||
#ifdef HAVE_PWD_H
|
#ifdef HAVE_PWD_H
|
||||||
#include <pwd.h>
|
#include <pwd.h>
|
||||||
|
Loading…
Reference in New Issue
Block a user