userver: userver/server/handlers/auth/digest/standalone_checker.hpp Source File
Loading...
Searching...
No Matches
standalone_checker.hpp
Go to the documentation of this file.
1#pragma once
2
3/// @file userver/server/handlers/auth/digest/standalone_checker.hpp
4/// @brief @copybrief server::handlers::auth::digest::AuthStandaloneCheckerBase
5
6#include <chrono>
7#include <cstdint>
8#include <functional>
9#include <random>
10#include <string_view>
11
12#include <userver/cache/expirable_lru_cache.hpp>
13#include <userver/concurrent/mpsc_queue.hpp>
14#include <userver/concurrent/variable.hpp>
15#include <userver/crypto/hash.hpp>
16#include <userver/rcu/rcu_map.hpp>
17#include <userver/server/handlers/auth/digest/auth_checker_base.hpp>
18#include <userver/server/handlers/auth/digest/auth_checker_settings.hpp>
19#include <userver/server/handlers/auth/digest/directives_parser.hpp>
20#include <userver/server/http/http_request.hpp>
21#include <userver/server/http/http_response.hpp>
22#include <userver/server/http/http_status.hpp>
23#include <userver/server/request/request_context.hpp>
24
25USERVER_NAMESPACE_BEGIN
26
27namespace server::handlers::auth::digest {
28
29struct NonceInfo final {
30 NonceInfo();
31 NonceInfo(const std::string& nonce, TimePoint expiration_time,
32 std::int64_t nonce_count);
33 std::string nonce;
34 TimePoint expiration_time;
35 std::int64_t nonce_count;
36};
37
38/// @ingroup userver_base_classes
39///
40/// @brief Class for digest authentication checker. Implements a stand-alone
41/// digest-authentication logic.
43 public:
44 AuthStandaloneCheckerBase(const AuthCheckerSettings& digest_settings,
45 std::string&& realm, std::size_t ways,
46 std::size_t way_size);
47
48 [[nodiscard]] bool SupportsUserAuth() const noexcept override { return true; }
49
50 std::optional<UserData> FetchUserData(
51 const std::string& username) const override;
52 void SetUserData(const std::string& username, const std::string& nonce,
53 std::int64_t nonce_count,
54 TimePoint nonce_creation_time) const override;
55
56 void PushUnnamedNonce(std::string nonce) const override;
58 const std::string& nonce) const override;
59
60 virtual std::optional<UserData::HA1> GetHA1(
61 std::string_view username) const = 0;
62
63 private:
65 // potentially we store ALL user's data
66 // great chance to occupy large block of memory
67 mutable rcu::RcuMap<std::string, concurrent::Variable<NonceInfo>> user_data_;
68 // cache for "unnamed" nonces,
69 // i.e initial nonces not tied to any user
70 mutable NonceCache unnamed_nonces_;
71};
72
73} // namespace server::handlers::auth::digest
74
75USERVER_NAMESPACE_END