2022-08-30 16:02:25 +03:00
|
|
|
//
|
2024-01-01 03:07:21 +03:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2024
|
2022-08-30 16:02:25 +03: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
|
|
|
|
|
2022-10-03 01:26:32 +03:00
|
|
|
#include "td/telegram/CustomEmojiId.h"
|
2022-08-30 16:48:26 +03:00
|
|
|
#include "td/telegram/td_api.h"
|
2022-08-30 16:02:25 +03:00
|
|
|
#include "td/telegram/telegram_api.h"
|
|
|
|
|
|
|
|
#include "td/utils/common.h"
|
2022-08-30 18:03:57 +03:00
|
|
|
#include "td/utils/Promise.h"
|
2022-08-30 16:02:25 +03:00
|
|
|
#include "td/utils/StringBuilder.h"
|
|
|
|
#include "td/utils/tl_helpers.h"
|
|
|
|
|
|
|
|
namespace td {
|
|
|
|
|
2022-08-30 18:03:57 +03:00
|
|
|
class Td;
|
|
|
|
|
2022-08-30 16:02:25 +03:00
|
|
|
class EmojiStatus {
|
2022-10-03 01:26:32 +03:00
|
|
|
CustomEmojiId custom_emoji_id_;
|
2022-09-01 22:04:33 +03:00
|
|
|
int32 until_date_ = 0;
|
2022-08-30 16:02:25 +03:00
|
|
|
|
|
|
|
friend bool operator==(const EmojiStatus &lhs, const EmojiStatus &rhs);
|
|
|
|
|
|
|
|
friend StringBuilder &operator<<(StringBuilder &string_builder, const EmojiStatus &contact);
|
|
|
|
|
|
|
|
public:
|
|
|
|
EmojiStatus() = default;
|
|
|
|
|
2023-07-06 20:14:42 +03:00
|
|
|
explicit EmojiStatus(const td_api::object_ptr<td_api::emojiStatus> &emoji_status);
|
2022-08-30 16:02:25 +03:00
|
|
|
|
2022-08-30 17:23:46 +03:00
|
|
|
explicit EmojiStatus(tl_object_ptr<telegram_api::EmojiStatus> &&emoji_status);
|
2022-08-30 16:02:25 +03:00
|
|
|
|
2022-08-30 17:23:46 +03:00
|
|
|
tl_object_ptr<telegram_api::EmojiStatus> get_input_emoji_status() const;
|
2022-08-30 16:02:25 +03:00
|
|
|
|
2022-09-07 10:25:21 +03:00
|
|
|
td_api::object_ptr<td_api::emojiStatus> get_emoji_status_object() const;
|
2022-08-30 16:02:25 +03:00
|
|
|
|
2023-07-06 20:14:42 +03:00
|
|
|
EmojiStatus get_effective_emoji_status(bool is_premium, int32 unix_time) const;
|
2022-09-01 20:33:41 +03:00
|
|
|
|
2022-08-30 16:02:25 +03:00
|
|
|
bool is_empty() const {
|
2022-10-03 01:26:32 +03:00
|
|
|
return !custom_emoji_id_.is_valid();
|
2022-08-30 16:02:25 +03:00
|
|
|
}
|
|
|
|
|
2022-10-03 01:26:32 +03:00
|
|
|
CustomEmojiId get_custom_emoji_id() const {
|
2022-09-02 15:39:07 +03:00
|
|
|
return custom_emoji_id_;
|
|
|
|
}
|
|
|
|
|
2022-09-01 22:26:04 +03:00
|
|
|
int32 get_until_date() const {
|
|
|
|
return until_date_;
|
|
|
|
}
|
|
|
|
|
2022-09-02 13:16:55 +03:00
|
|
|
void clear_until_date() {
|
|
|
|
until_date_ = 0;
|
|
|
|
}
|
|
|
|
|
2022-08-30 16:02:25 +03:00
|
|
|
template <class StorerT>
|
|
|
|
void store(StorerT &storer) const {
|
2022-10-03 01:26:32 +03:00
|
|
|
bool has_custom_emoji_id = custom_emoji_id_.is_valid();
|
2022-09-01 22:04:33 +03:00
|
|
|
bool has_until_date = until_date_ != 0;
|
|
|
|
BEGIN_STORE_FLAGS();
|
2022-09-02 15:39:07 +03:00
|
|
|
STORE_FLAG(has_custom_emoji_id);
|
2022-09-01 22:04:33 +03:00
|
|
|
STORE_FLAG(has_until_date);
|
|
|
|
END_STORE_FLAGS();
|
2022-09-02 15:39:07 +03:00
|
|
|
if (has_custom_emoji_id) {
|
|
|
|
td::store(custom_emoji_id_, storer);
|
|
|
|
}
|
2022-09-01 22:04:33 +03:00
|
|
|
if (has_until_date) {
|
|
|
|
td::store(until_date_, storer);
|
|
|
|
}
|
2022-08-30 16:02:25 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
template <class ParserT>
|
|
|
|
void parse(ParserT &parser) {
|
2022-09-02 15:39:07 +03:00
|
|
|
bool has_custom_emoji_id;
|
2022-09-01 22:04:33 +03:00
|
|
|
bool has_until_date;
|
|
|
|
BEGIN_PARSE_FLAGS();
|
2022-09-02 15:39:07 +03:00
|
|
|
PARSE_FLAG(has_custom_emoji_id);
|
2022-09-01 22:04:33 +03:00
|
|
|
PARSE_FLAG(has_until_date);
|
|
|
|
END_PARSE_FLAGS();
|
2022-09-02 15:39:07 +03:00
|
|
|
if (has_custom_emoji_id) {
|
|
|
|
td::parse(custom_emoji_id_, parser);
|
|
|
|
}
|
2022-09-01 22:04:33 +03:00
|
|
|
if (has_until_date) {
|
|
|
|
td::parse(until_date_, parser);
|
|
|
|
}
|
2022-08-30 16:02:25 +03:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
inline bool operator==(const EmojiStatus &lhs, const EmojiStatus &rhs) {
|
2022-09-01 22:04:33 +03:00
|
|
|
return lhs.custom_emoji_id_ == rhs.custom_emoji_id_ && lhs.until_date_ == rhs.until_date_;
|
2022-08-30 16:02:25 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
inline bool operator!=(const EmojiStatus &lhs, const EmojiStatus &rhs) {
|
|
|
|
return !(lhs == rhs);
|
|
|
|
}
|
|
|
|
|
2022-08-30 17:23:46 +03:00
|
|
|
StringBuilder &operator<<(StringBuilder &string_builder, const EmojiStatus &emoji_status);
|
2022-08-30 16:02:25 +03:00
|
|
|
|
2023-12-24 02:30:49 +03:00
|
|
|
td_api::object_ptr<td_api::emojiStatuses> get_emoji_statuses_object(const vector<CustomEmojiId> &custom_emoji_ids);
|
|
|
|
|
2022-09-07 10:25:21 +03:00
|
|
|
void get_default_emoji_statuses(Td *td, Promise<td_api::object_ptr<td_api::emojiStatuses>> &&promise);
|
2022-08-30 18:03:57 +03:00
|
|
|
|
2023-12-22 12:29:12 +03:00
|
|
|
void get_default_channel_emoji_statuses(Td *td, Promise<td_api::object_ptr<td_api::emojiStatuses>> &&promise);
|
|
|
|
|
2022-09-07 10:25:21 +03:00
|
|
|
void get_recent_emoji_statuses(Td *td, Promise<td_api::object_ptr<td_api::emojiStatuses>> &&promise);
|
2022-08-31 15:47:51 +03:00
|
|
|
|
2022-09-02 15:39:07 +03:00
|
|
|
void add_recent_emoji_status(Td *td, EmojiStatus emoji_status);
|
2022-08-31 17:46:03 +03:00
|
|
|
|
2022-08-31 16:41:13 +03:00
|
|
|
void clear_recent_emoji_statuses(Td *td, Promise<Unit> &&promise);
|
|
|
|
|
2022-08-30 16:02:25 +03:00
|
|
|
} // namespace td
|