userver: userver/ydb/builder.hpp Source File
Loading...
Searching...
No Matches
builder.hpp
1#pragma once
2
3#include <ydb-cpp-sdk/client/params/params.h>
4
5#include <string>
6#include <type_traits>
7#include <utility>
8
9#include <userver/ydb/impl/cast.hpp>
10#include <userver/ydb/io/traits.hpp>
11
12USERVER_NAMESPACE_BEGIN
13
14namespace ydb {
15
16class TableClient;
17class Transaction;
18
19class PreparedArgsBuilder final {
20public:
21 PreparedArgsBuilder(PreparedArgsBuilder&&) noexcept = default;
22 PreparedArgsBuilder& operator=(PreparedArgsBuilder&&) = delete;
23
24 /// Supported types and required includes are documented in:
25 /// <userver/ydb/io/supported_types.hpp>
26 template <typename T>
27 void Add(const std::string& name, T&& value);
28
29 /// @cond
30 // For internal use only.
31 explicit PreparedArgsBuilder(NYdb::TParamsBuilder&& builder)
32 : builder_(std::move(builder))
33 {}
34
35 // For internal use only.
36 template <typename... NamesValues>
37 void AddParams(NamesValues&&... names_values);
38 /// @endcond
39
40private:
41 friend class Transaction;
42 friend class TableClient;
43 struct PreparedArgsWithKey;
44
45 NYdb::TParams Build() && { return std::move(builder_).Build(); }
46
47 PreparedArgsWithKey operator<<(const std::string& key);
48
49 NYdb::TParamsBuilder builder_;
50};
51
52template <typename T>
53void PreparedArgsBuilder::Add(const std::string& name, T&& value) {
54 auto& param_builder = builder_.AddParam(impl::ToString(name));
55 Write(param_builder, std::forward<T>(value));
56 param_builder.Build();
57}
58
59/// @cond
60template <typename... NamesValues>
61void PreparedArgsBuilder::AddParams(NamesValues&&... names_values) {
62 [[maybe_unused]] decltype(auto) result = (*this << ... << std::forward<NamesValues>(names_values));
63 static_assert(std::is_same_v<decltype(result), PreparedArgsBuilder&>);
64}
65/// @endcond
66
67struct PreparedArgsBuilder::PreparedArgsWithKey final {
68 PreparedArgsBuilder& builder;
69 const std::string& key;
70
71 template <typename T>
72 PreparedArgsBuilder& operator<<(T&& value) const {
73 builder.Add(key, std::forward<T>(value));
74 return builder;
75 }
76};
77
78inline auto PreparedArgsBuilder::operator<<(const std::string& key) -> PreparedArgsWithKey {
79 return PreparedArgsWithKey{*this, key};
80}
81
82} // namespace ydb
83
84USERVER_NAMESPACE_END