2018-12-31 22:04:05 +03:00
|
|
|
//
|
2021-01-01 15:57:46 +03:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2021
|
2018-12-31 22:04:05 +03:00
|
|
|
//
|
|
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "td/utils/common.h"
|
|
|
|
#include "td/utils/logging.h"
|
|
|
|
#include "td/utils/port/FileFd.h"
|
|
|
|
#include "td/utils/Slice.h"
|
2018-10-24 18:42:40 +03:00
|
|
|
#include "td/utils/Status.h"
|
2018-12-31 22:04:05 +03:00
|
|
|
|
2020-06-26 02:24:13 +03:00
|
|
|
#include <atomic>
|
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
namespace td {
|
|
|
|
|
|
|
|
class FileLog : public LogInterface {
|
2018-01-28 17:33:14 +03:00
|
|
|
static constexpr int64 DEFAULT_ROTATE_THRESHOLD = 10 * (1 << 20);
|
2018-12-31 22:04:05 +03:00
|
|
|
|
|
|
|
public:
|
2020-06-26 02:24:13 +03:00
|
|
|
static Result<unique_ptr<LogInterface>> create(string path, int64 rotate_threshold = DEFAULT_ROTATE_THRESHOLD,
|
|
|
|
bool redirect_stderr = true);
|
2019-08-12 14:45:57 +03:00
|
|
|
Status init(string path, int64 rotate_threshold = DEFAULT_ROTATE_THRESHOLD, bool redirect_stderr = true);
|
2018-10-24 18:42:40 +03:00
|
|
|
|
|
|
|
Slice get_path() const;
|
2018-12-31 22:04:05 +03:00
|
|
|
|
2021-05-17 16:18:19 +03:00
|
|
|
vector<string> get_file_paths() final;
|
2019-01-18 01:17:20 +03:00
|
|
|
|
2018-01-28 17:33:14 +03:00
|
|
|
void set_rotate_threshold(int64 rotate_threshold);
|
2018-12-31 22:04:05 +03:00
|
|
|
|
2018-10-24 18:42:40 +03:00
|
|
|
int64 get_rotate_threshold() const;
|
|
|
|
|
2020-09-27 14:37:35 +03:00
|
|
|
bool get_redirect_stderr() const;
|
|
|
|
|
2021-05-17 17:58:33 +03:00
|
|
|
void after_rotation() final;
|
2018-01-09 12:40:56 +03:00
|
|
|
|
2020-06-24 14:47:36 +03:00
|
|
|
void lazy_rotate();
|
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
private:
|
|
|
|
FileFd fd_;
|
|
|
|
string path_;
|
2018-10-26 17:11:20 +03:00
|
|
|
int64 size_ = 0;
|
|
|
|
int64 rotate_threshold_ = 0;
|
2019-08-13 23:52:54 +03:00
|
|
|
bool redirect_stderr_ = false;
|
2020-06-26 02:24:13 +03:00
|
|
|
std::atomic<bool> want_rotate_{false};
|
2018-12-31 22:04:05 +03:00
|
|
|
|
2021-05-17 16:18:19 +03:00
|
|
|
void do_append(int log_level, CSlice slice) final;
|
|
|
|
|
2021-05-17 17:58:33 +03:00
|
|
|
void do_after_rotation();
|
2018-12-31 22:04:05 +03:00
|
|
|
};
|
2018-01-28 17:33:14 +03:00
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
} // namespace td
|