2024-01-01 03:07:21 +03:00

115 lines
3.2 KiB
C++

//
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2024
//
// 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/CustomEmojiId.h"
#include "td/telegram/td_api.h"
#include "td/telegram/telegram_api.h"
#include "td/utils/common.h"
#include "td/utils/Promise.h"
#include "td/utils/StringBuilder.h"
#include "td/utils/tl_helpers.h"
namespace td {
class Td;
class EmojiStatus {
CustomEmojiId custom_emoji_id_;
int32 until_date_ = 0;
friend bool operator==(const EmojiStatus &lhs, const EmojiStatus &rhs);
friend StringBuilder &operator<<(StringBuilder &string_builder, const EmojiStatus &contact);
public:
EmojiStatus() = default;
explicit EmojiStatus(const td_api::object_ptr<td_api::emojiStatus> &emoji_status);
explicit EmojiStatus(tl_object_ptr<telegram_api::EmojiStatus> &&emoji_status);
tl_object_ptr<telegram_api::EmojiStatus> get_input_emoji_status() const;
td_api::object_ptr<td_api::emojiStatus> get_emoji_status_object() const;
EmojiStatus get_effective_emoji_status(bool is_premium, int32 unix_time) const;
bool is_empty() const {
return !custom_emoji_id_.is_valid();
}
CustomEmojiId get_custom_emoji_id() const {
return custom_emoji_id_;
}
int32 get_until_date() const {
return until_date_;
}
void clear_until_date() {
until_date_ = 0;
}
template <class StorerT>
void store(StorerT &storer) const {
bool has_custom_emoji_id = custom_emoji_id_.is_valid();
bool has_until_date = until_date_ != 0;
BEGIN_STORE_FLAGS();
STORE_FLAG(has_custom_emoji_id);
STORE_FLAG(has_until_date);
END_STORE_FLAGS();
if (has_custom_emoji_id) {
td::store(custom_emoji_id_, storer);
}
if (has_until_date) {
td::store(until_date_, storer);
}
}
template <class ParserT>
void parse(ParserT &parser) {
bool has_custom_emoji_id;
bool has_until_date;
BEGIN_PARSE_FLAGS();
PARSE_FLAG(has_custom_emoji_id);
PARSE_FLAG(has_until_date);
END_PARSE_FLAGS();
if (has_custom_emoji_id) {
td::parse(custom_emoji_id_, parser);
}
if (has_until_date) {
td::parse(until_date_, parser);
}
}
};
inline bool operator==(const EmojiStatus &lhs, const EmojiStatus &rhs) {
return lhs.custom_emoji_id_ == rhs.custom_emoji_id_ && lhs.until_date_ == rhs.until_date_;
}
inline bool operator!=(const EmojiStatus &lhs, const EmojiStatus &rhs) {
return !(lhs == rhs);
}
StringBuilder &operator<<(StringBuilder &string_builder, const EmojiStatus &emoji_status);
td_api::object_ptr<td_api::emojiStatuses> get_emoji_statuses_object(const vector<CustomEmojiId> &custom_emoji_ids);
void get_default_emoji_statuses(Td *td, Promise<td_api::object_ptr<td_api::emojiStatuses>> &&promise);
void get_default_channel_emoji_statuses(Td *td, Promise<td_api::object_ptr<td_api::emojiStatuses>> &&promise);
void get_recent_emoji_statuses(Td *td, Promise<td_api::object_ptr<td_api::emojiStatuses>> &&promise);
void add_recent_emoji_status(Td *td, EmojiStatus emoji_status);
void clear_recent_emoji_statuses(Td *td, Promise<Unit> &&promise);
} // namespace td