diff options
author | monster <monster@ydb.tech> | 2022-07-07 14:41:37 +0300 |
---|---|---|
committer | monster <monster@ydb.tech> | 2022-07-07 14:41:37 +0300 |
commit | 06e5c21a835c0e923506c4ff27929f34e00761c2 (patch) | |
tree | 75efcbc6854ef9bd476eb8bf00cc5c900da436a2 /library/cpp/neh/multi.cpp | |
parent | 03f024c4412e3aa613bb543cf1660176320ba8f4 (diff) | |
download | ydb-06e5c21a835c0e923506c4ff27929f34e00761c2.tar.gz |
fix ya.make
Diffstat (limited to 'library/cpp/neh/multi.cpp')
-rw-r--r-- | library/cpp/neh/multi.cpp | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/library/cpp/neh/multi.cpp b/library/cpp/neh/multi.cpp new file mode 100644 index 0000000000..4929d4efd9 --- /dev/null +++ b/library/cpp/neh/multi.cpp @@ -0,0 +1,35 @@ +#include "rpc.h" +#include "multi.h" +#include "location.h" +#include "factory.h" + +#include <util/string/cast.h> +#include <util/generic/hash.h> + +using namespace NNeh; + +namespace { + namespace NMulti { + class TRequester: public IRequester { + public: + inline TRequester(const TListenAddrs& addrs, IOnRequest* cb) { + for (const auto& addr : addrs) { + TParsedLocation loc(addr); + IRequesterRef& req = R_[ToString(loc.Scheme) + ToString(loc.GetPort())]; + + if (!req) { + req = ProtocolFactory()->Protocol(loc.Scheme)->CreateRequester(cb, loc); + } + } + } + + private: + typedef THashMap<TString, IRequesterRef> TRequesters; + TRequesters R_; + }; + } +} + +IRequesterRef NNeh::MultiRequester(const TListenAddrs& addrs, IOnRequest* cb) { + return new NMulti::TRequester(addrs, cb); +} |