aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/grpc/server/actors/logger.cpp
blob: 5233c0cb9a27966a303540e5a62e5278e44c86d6 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include "logger.h"

namespace NGrpc {
namespace {

static_assert(
        ui16(TLOG_EMERG) == ui16(NActors::NLog::PRI_EMERG) &&
        ui16(TLOG_DEBUG) == ui16(NActors::NLog::PRI_DEBUG),
        "log levels in the library/log and library/cpp/actors don't match");

class TActorSystemLogger final: public TLogger {
public:
    TActorSystemLogger(NActors::TActorSystem& as, NActors::NLog::EComponent component) noexcept
        : ActorSystem_{as}
        , Component_{component}
    {
    }

protected:
    bool DoIsEnabled(ELogPriority p) const noexcept override {
        const auto* settings = static_cast<::NActors::NLog::TSettings*>(ActorSystem_.LoggerSettings());
        const auto priority = static_cast<::NActors::NLog::EPriority>(p);

        return settings && settings->Satisfies(priority, Component_, 0);
    }

    void DoWrite(ELogPriority p, const char* format, va_list args) noexcept override {
        Y_DEBUG_ABORT_UNLESS(DoIsEnabled(p));

        const auto priority = static_cast<::NActors::NLog::EPriority>(p);
        ::NActors::MemLogAdapter(ActorSystem_, priority, Component_, format, args);
    }

private:
    NActors::TActorSystem& ActorSystem_;
    NActors::NLog::EComponent Component_;
};

} // namespace

TLoggerPtr CreateActorSystemLogger(NActors::TActorSystem& as, NActors::NLog::EComponent component) {
    return MakeIntrusive<TActorSystemLogger>(as, component);
}

} // namespace NGrpc