2018-12-31 20:04:05 +01:00
|
|
|
//
|
2024-01-01 01:07:21 +01:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2024
|
2018-12-31 20:04:05 +01:00
|
|
|
//
|
|
|
|
// 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
|
|
|
|
|
2021-09-08 22:57:10 +02:00
|
|
|
#include "td/telegram/Version.h"
|
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
#include "td/utils/common.h"
|
2022-11-23 17:37:32 +01:00
|
|
|
#include "td/utils/HashTableUtils.h"
|
2018-12-31 20:04:05 +01:00
|
|
|
#include "td/utils/StringBuilder.h"
|
|
|
|
|
|
|
|
#include <type_traits>
|
|
|
|
|
|
|
|
namespace td {
|
|
|
|
|
|
|
|
class UserId {
|
2021-09-03 11:27:59 +02:00
|
|
|
int64 id = 0;
|
2018-12-31 20:04:05 +01:00
|
|
|
|
|
|
|
public:
|
2021-12-31 07:36:24 +01:00
|
|
|
static constexpr int64 MAX_USER_ID = (static_cast<int64>(1) << 40) - 1;
|
2021-09-14 16:09:40 +02:00
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
UserId() = default;
|
|
|
|
|
2023-05-21 12:21:49 +02:00
|
|
|
explicit constexpr UserId(int64 user_id) : id(user_id) {
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
2021-09-03 11:27:59 +02:00
|
|
|
template <class T, typename = std::enable_if_t<std::is_convertible<T, int64>::value>>
|
2018-12-31 20:04:05 +01:00
|
|
|
UserId(T user_id) = delete;
|
|
|
|
|
2024-06-27 11:53:33 +02:00
|
|
|
static vector<UserId> get_user_ids(const vector<int64> &input_user_ids, bool only_valid = false) {
|
2021-03-28 23:50:15 +02:00
|
|
|
vector<UserId> user_ids;
|
|
|
|
user_ids.reserve(input_user_ids.size());
|
|
|
|
for (auto &input_user_id : input_user_ids) {
|
2024-06-27 11:53:33 +02:00
|
|
|
UserId user_id(input_user_id);
|
|
|
|
if (!only_valid || user_id.is_valid()) {
|
|
|
|
user_ids.emplace_back(user_id);
|
|
|
|
}
|
2021-03-28 23:50:15 +02:00
|
|
|
}
|
|
|
|
return user_ids;
|
|
|
|
}
|
|
|
|
|
2021-09-03 11:27:59 +02:00
|
|
|
static vector<int64> get_input_user_ids(const vector<UserId> &user_ids) {
|
|
|
|
vector<int64> input_user_ids;
|
2021-03-28 23:50:15 +02:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
bool is_valid() const {
|
2021-09-14 16:09:40 +02:00
|
|
|
return 0 < id && id <= MAX_USER_ID;
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
|
|
|
|
2021-09-03 11:27:59 +02:00
|
|
|
int64 get() const {
|
2018-12-31 20:04:05 +01:00
|
|
|
return id;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool operator==(const UserId &other) const {
|
|
|
|
return id == other.id;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool operator!=(const UserId &other) const {
|
|
|
|
return id != other.id;
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class StorerT>
|
|
|
|
void store(StorerT &storer) const {
|
2021-09-03 11:27:59 +02:00
|
|
|
storer.store_long(id);
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
template <class ParserT>
|
|
|
|
void parse(ParserT &parser) {
|
2021-09-03 11:27:59 +02:00
|
|
|
if (parser.version() >= static_cast<int32>(Version::Support64BitIds)) {
|
|
|
|
id = parser.fetch_long();
|
|
|
|
} else {
|
|
|
|
id = parser.fetch_int();
|
|
|
|
}
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct UserIdHash {
|
2022-11-23 17:37:32 +01:00
|
|
|
uint32 operator()(UserId user_id) const {
|
|
|
|
return Hash<int64>()(user_id.get());
|
2018-12-31 20:04:05 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
inline StringBuilder &operator<<(StringBuilder &string_builder, UserId user_id) {
|
|
|
|
return string_builder << "user " << user_id.get();
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace td
|