// // Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2022 // // Distributed under the Boost Software License, Version 1.0. (See accompanying // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) // #pragma once #include "td/telegram/Version.h" #include "td/utils/common.h" #include "td/utils/HashTableUtils.h" #include "td/utils/StringBuilder.h" #include namespace td { class UserId { int64 id = 0; public: static constexpr int64 MAX_USER_ID = (static_cast(1) << 40) - 1; UserId() = default; explicit UserId(int64 user_id) : id(user_id) { } template ::value>> UserId(T user_id) = delete; static vector get_user_ids(const vector &input_user_ids) { vector user_ids; user_ids.reserve(input_user_ids.size()); for (auto &input_user_id : input_user_ids) { user_ids.emplace_back(input_user_id); } return user_ids; } static vector get_input_user_ids(const vector &user_ids) { vector input_user_ids; input_user_ids.reserve(user_ids.size()); for (auto &user_id : user_ids) { input_user_ids.emplace_back(user_id.get()); } return input_user_ids; } bool is_valid() const { return 0 < id && id <= MAX_USER_ID; } int64 get() const { return id; } bool operator==(const UserId &other) const { return id == other.id; } bool operator!=(const UserId &other) const { return id != other.id; } template void store(StorerT &storer) const { storer.store_long(id); } template void parse(ParserT &parser) { if (parser.version() >= static_cast(Version::Support64BitIds)) { id = parser.fetch_long(); } else { id = parser.fetch_int(); } } }; struct UserIdHash { uint32 operator()(UserId user_id) const { return Hash()(user_id.get()); } }; inline StringBuilder &operator<<(StringBuilder &string_builder, UserId user_id) { return string_builder << "user " << user_id.get(); } } // namespace td