userver: userver/ugrpc/server/middlewares/access_log/component.hpp Source File
Loading...
Searching...
No Matches
component.hpp
Go to the documentation of this file.
1#pragma once
2
3/// @file userver/ugrpc/server/middlewares/access_log/component.hpp
4/// @brief @copybrief ugrpc::server::middlewares::access_log::Component
5
6#include <userver/logging/component.hpp>
7
8#include <userver/ugrpc/server/middlewares/base.hpp>
9
10USERVER_NAMESPACE_BEGIN
11
12/// Server access_log middleware
13/// @see @ref scripts/docs/en/userver/grpc/server_middlewares.md
14/// @see @ref ugrpc::server::middlewares::access_log::Component
15namespace ugrpc::server::middlewares::access_log {
16
17/// @brief Storage to handle additional fields in access_log
18/// @snippet grpc/tests/logging_test.cpp grpc log extra tag
19inline const utils::AnyStorageDataTag<ugrpc::server::StorageContext, logging::LogExtra> kLogExtraTag;
20
21/// @ingroup userver_components userver_base_classes
22///
23/// @brief gRPC server access log middleware component. Writes one TSKV log line per handled RPC in a static format.
24/// This log is intended to be collected, parsed and stored for audit or extended statistics purposes.
25///
26/// This middleware is disabled and unregistered by default.
27///
28/// ## Static options:
29/// The component name for static config is `"grpc-server-access-log"`.
30///
31/// Name | Description | Default value
32/// ---- | ----------- | -------------
33/// `access-tskv-logger` | logger name for `access-tskv.log`, must have `format: raw` | -
34///
35/// ## Static configuration example:
36///
37/// @snippet grpc/functional_tests/basic_chaos/static_config.yaml grpc server access log
38///
39/// @see @ref scripts/docs/en/userver/grpc/server_middlewares.md
40class Component final : public MiddlewareFactoryComponentBase {
41public:
42 /// @ingroup userver_component_names
43 /// @brief The default name of ugrpc::server::middlewares::access_log::Component
44 static constexpr std::string_view kName = "grpc-server-access-log";
45
46 Component(const components::ComponentConfig& config, const components::ComponentContext& context);
47
48 std::shared_ptr<const MiddlewareBase> CreateMiddleware(
49 const ugrpc::server::ServiceInfo&,
50 const yaml_config::YamlConfig& middleware_config
51 ) const override;
52
53 yaml_config::Schema GetMiddlewareConfigSchema() const override;
54
55 static yaml_config::Schema GetStaticConfigSchema();
56
57private:
58 components::Logging& logging_component_;
59};
60
61} // namespace ugrpc::server::middlewares::access_log
62
63template <>
64inline constexpr bool components::kHasValidate<ugrpc::server::middlewares::access_log::Component> = true;
65
66template <>
67inline constexpr auto components::kConfigFileMode<ugrpc::server::middlewares::access_log::Component> =
69
70USERVER_NAMESPACE_END