Lines
100 %
Functions
#pragma once
#include <vector>
#include "envoy/extensions/access_loggers/grpc/v3/als.pb.h"
#include "envoy/grpc/async_client.h"
#include "envoy/grpc/async_client_manager.h"
#include "envoy/local_info/local_info.h"
#include "envoy/singleton/instance.h"
#include "envoy/thread_local/thread_local.h"
#include "source/common/grpc/typed_async_client.h"
#include "source/extensions/access_loggers/common/access_log_base.h"
#include "source/extensions/access_loggers/grpc/grpc_access_log_impl.h"
#include "source/extensions/access_loggers/grpc/grpc_access_log_utils.h"
namespace Envoy {
namespace Extensions {
namespace AccessLoggers {
namespace TcpGrpc {
// TODO(mattklein123): Stats
using envoy::extensions::access_loggers::grpc::v3::TcpGrpcAccessLogConfig;
using TcpGrpcAccessLogConfigConstSharedPtr = std::shared_ptr<const TcpGrpcAccessLogConfig>;
/**
* Access log Instance that streams TCP logs over gRPC.
*/
class TcpGrpcAccessLog : public Common::ImplBase {
public:
TcpGrpcAccessLog(AccessLog::FilterPtr&& filter, const TcpGrpcAccessLogConfig config,
ThreadLocal::SlotAllocator& tls,
GrpcCommon::GrpcAccessLoggerCacheSharedPtr access_logger_cache,
const Formatter::CommandParserPtrVector& command_parsers = {});
private:
* Per-thread cached logger.
struct ThreadLocalLogger : public ThreadLocal::ThreadLocalObject {
ThreadLocalLogger(GrpcCommon::GrpcAccessLoggerSharedPtr logger);
const GrpcCommon::GrpcAccessLoggerSharedPtr logger_;
};
// Common::ImplBase
void emitLog(const Formatter::Context& context, const StreamInfo::StreamInfo& info) override;
const TcpGrpcAccessLogConfigConstSharedPtr config_;
const ThreadLocal::SlotPtr tls_slot_;
const GrpcCommon::GrpcAccessLoggerCacheSharedPtr access_logger_cache_;
const GrpcCommon::CommonPropertiesConfig common_properties_config_;
} // namespace TcpGrpc
} // namespace AccessLoggers
} // namespace Extensions
} // namespace Envoy