2
0
mirror of https://github.com/telegramdesktop/tdesktop synced 2025-08-23 02:37:11 +00:00
tdesktop/Telegram/SourceFiles/api/api_global_privacy.cpp

337 lines
9.7 KiB
C++
Raw Normal View History

2020-07-03 20:53:24 +04:00
/*
This file is part of Telegram Desktop,
the official desktop application for the Telegram messaging service.
For license and copyright information please follow this link:
https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
*/
#include "api/api_global_privacy.h"
#include "apiwrap.h"
2025-03-21 18:34:26 +04:00
#include "data/data_user.h"
2020-07-03 20:53:24 +04:00
#include "main/main_session.h"
#include "main/main_app_config.h"
namespace Api {
2025-01-31 14:57:53 +04:00
PeerId ParsePaidReactionShownPeer(
not_null<Main::Session*> session,
const MTPPaidReactionPrivacy &value) {
return value.match([&](const MTPDpaidReactionPrivacyDefault &) {
return session->userPeerId();
}, [](const MTPDpaidReactionPrivacyAnonymous &) {
return PeerId();
}, [&](const MTPDpaidReactionPrivacyPeer &data) {
return data.vpeer().match([&](const MTPDinputPeerSelf &) {
return session->userPeerId();
}, [](const MTPDinputPeerUser &data) {
return peerFromUser(data.vuser_id());
}, [](const MTPDinputPeerChat &data) {
return peerFromChat(data.vchat_id());
}, [](const MTPDinputPeerChannel &data) {
return peerFromChannel(data.vchannel_id());
}, [](const MTPDinputPeerUserFromMessage &data) -> PeerId {
Unexpected("From message peer in ParsePaidReactionShownPeer.");
}, [](const MTPDinputPeerChannelFromMessage &data) -> PeerId {
Unexpected("From message peer in ParsePaidReactionShownPeer.");
}, [](const MTPDinputPeerEmpty &) -> PeerId {
Unexpected("Empty peer in ParsePaidReactionShownPeer.");
});
});
}
2020-07-03 20:53:24 +04:00
GlobalPrivacy::GlobalPrivacy(not_null<ApiWrap*> api)
: _session(&api->session())
, _api(&api->instance()) {
}
void GlobalPrivacy::reload(Fn<void()> callback) {
if (callback) {
_callbacks.push_back(std::move(callback));
}
2020-07-03 20:53:24 +04:00
if (_requestId) {
return;
}
_requestId = _api.request(MTPaccount_GetGlobalPrivacySettings(
)).done([=](const MTPGlobalPrivacySettings &result) {
_requestId = 0;
apply(result);
for (const auto &callback : base::take(_callbacks)) {
callback();
}
}).fail([=] {
2020-07-03 20:53:24 +04:00
_requestId = 0;
for (const auto &callback : base::take(_callbacks)) {
callback();
}
2020-07-03 20:53:24 +04:00
}).send();
2024-03-29 15:30:50 +04:00
_session->appConfig().value(
2020-07-03 20:53:24 +04:00
) | rpl::start_with_next([=] {
2024-03-29 15:30:50 +04:00
_showArchiveAndMute = _session->appConfig().get<bool>(
2020-07-03 20:53:24 +04:00
u"autoarchive_setting_available"_q,
false);
}, _session->lifetime());
2020-07-03 20:53:24 +04:00
}
bool GlobalPrivacy::archiveAndMuteCurrent() const {
return _archiveAndMute.current();
}
rpl::producer<bool> GlobalPrivacy::archiveAndMute() const {
return _archiveAndMute.value();
}
2023-07-13 19:33:57 +04:00
UnarchiveOnNewMessage GlobalPrivacy::unarchiveOnNewMessageCurrent() const {
return _unarchiveOnNewMessage.current();
}
auto GlobalPrivacy::unarchiveOnNewMessage() const
-> rpl::producer<UnarchiveOnNewMessage> {
return _unarchiveOnNewMessage.value();
}
2020-07-03 20:53:24 +04:00
rpl::producer<bool> GlobalPrivacy::showArchiveAndMute() const {
using namespace rpl::mappers;
return rpl::combine(
archiveAndMute(),
_showArchiveAndMute.value(),
_1 || _2);
}
rpl::producer<> GlobalPrivacy::suggestArchiveAndMute() const {
2024-03-29 15:30:50 +04:00
return _session->appConfig().suggestionRequested(
2020-07-03 20:53:24 +04:00
u"AUTOARCHIVE_POPULAR"_q);
}
void GlobalPrivacy::dismissArchiveAndMuteSuggestion() {
2024-03-29 15:30:50 +04:00
_session->appConfig().dismissSuggestion(
2020-07-03 20:53:24 +04:00
u"AUTOARCHIVE_POPULAR"_q);
}
2024-01-09 13:13:30 +04:00
void GlobalPrivacy::updateHideReadTime(bool hide) {
update(
archiveAndMuteCurrent(),
unarchiveOnNewMessageCurrent(),
hide,
newRequirePremiumCurrent(),
newChargeStarsCurrent(),
disallowedGiftTypesCurrent());
2024-01-09 13:13:30 +04:00
}
bool GlobalPrivacy::hideReadTimeCurrent() const {
return _hideReadTime.current();
}
rpl::producer<bool> GlobalPrivacy::hideReadTime() const {
return _hideReadTime.value();
}
bool GlobalPrivacy::newRequirePremiumCurrent() const {
return _newRequirePremium.current();
}
rpl::producer<bool> GlobalPrivacy::newRequirePremium() const {
return _newRequirePremium.value();
}
int GlobalPrivacy::newChargeStarsCurrent() const {
return _newChargeStars.current();
}
rpl::producer<int> GlobalPrivacy::newChargeStars() const {
return _newChargeStars.value();
}
void GlobalPrivacy::updateMessagesPrivacy(
bool requirePremium,
int chargeStars) {
update(
archiveAndMuteCurrent(),
unarchiveOnNewMessageCurrent(),
hideReadTimeCurrent(),
requirePremium,
chargeStars,
disallowedGiftTypesCurrent());
}
DisallowedGiftTypes GlobalPrivacy::disallowedGiftTypesCurrent() const {
return _disallowedGiftTypes.current();
}
auto GlobalPrivacy::disallowedGiftTypes() const
-> rpl::producer<DisallowedGiftTypes> {
return _disallowedGiftTypes.value();
}
2025-03-18 13:37:12 +04:00
void GlobalPrivacy::updateDisallowedGiftTypes(DisallowedGiftTypes types) {
update(
archiveAndMuteCurrent(),
unarchiveOnNewMessageCurrent(),
hideReadTimeCurrent(),
newRequirePremiumCurrent(),
newChargeStarsCurrent(),
types);
}
2025-01-31 14:57:53 +04:00
void GlobalPrivacy::loadPaidReactionShownPeer() {
if (_paidReactionShownPeerLoaded) {
return;
}
2025-01-31 14:57:53 +04:00
_paidReactionShownPeerLoaded = true;
_api.request(MTPmessages_GetPaidReactionPrivacy(
)).done([=](const MTPUpdates &result) {
_session->api().applyUpdates(result);
}).send();
}
2025-01-31 14:57:53 +04:00
void GlobalPrivacy::updatePaidReactionShownPeer(PeerId shownPeer) {
_paidReactionShownPeer = shownPeer;
}
2025-01-31 14:57:53 +04:00
PeerId GlobalPrivacy::paidReactionShownPeerCurrent() const {
return _paidReactionShownPeer.current();
}
2025-01-31 14:57:53 +04:00
rpl::producer<PeerId> GlobalPrivacy::paidReactionShownPeer() const {
return _paidReactionShownPeer.value();
}
2024-01-09 13:13:30 +04:00
2023-08-11 16:20:38 +02:00
void GlobalPrivacy::updateArchiveAndMute(bool value) {
2024-01-09 13:13:30 +04:00
update(
value,
unarchiveOnNewMessageCurrent(),
hideReadTimeCurrent(),
newRequirePremiumCurrent(),
newChargeStarsCurrent(),
disallowedGiftTypesCurrent());
2023-08-11 16:20:38 +02:00
}
void GlobalPrivacy::updateUnarchiveOnNewMessage(
UnarchiveOnNewMessage value) {
2024-01-09 13:13:30 +04:00
update(
archiveAndMuteCurrent(),
value,
hideReadTimeCurrent(),
newRequirePremiumCurrent(),
newChargeStarsCurrent(),
disallowedGiftTypesCurrent());
2023-08-11 16:20:38 +02:00
}
void GlobalPrivacy::update(
bool archiveAndMute,
2024-01-09 13:13:30 +04:00
UnarchiveOnNewMessage unarchiveOnNewMessage,
bool hideReadTime,
bool newRequirePremium,
int newChargeStars,
DisallowedGiftTypes disallowedGiftTypes) {
2020-07-03 20:53:24 +04:00
using Flag = MTPDglobalPrivacySettings::Flag;
2025-03-18 12:24:03 +04:00
using DisallowedFlag = MTPDdisallowedGiftsSettings::Flag;
2020-07-03 20:53:24 +04:00
_api.request(_requestId).cancel();
const auto newRequirePremiumAllowed = _session->premium()
|| _session->appConfig().newRequirePremiumFree();
2025-03-18 13:37:12 +04:00
const auto showGiftIcon
= (disallowedGiftTypes & DisallowedGiftType::SendHide);
2023-07-13 19:33:57 +04:00
const auto flags = Flag()
| (archiveAndMute
? Flag::f_archive_and_mute_new_noncontact_peers
: Flag())
| (unarchiveOnNewMessage == UnarchiveOnNewMessage::None
2023-07-13 19:33:57 +04:00
? Flag::f_keep_archived_unmuted
: Flag())
| (unarchiveOnNewMessage != UnarchiveOnNewMessage::AnyUnmuted
2023-07-13 19:33:57 +04:00
? Flag::f_keep_archived_folders
2024-01-09 13:13:30 +04:00
: Flag())
| (hideReadTime ? Flag::f_hide_read_marks : Flag())
| ((newRequirePremium && newRequirePremiumAllowed)
2024-01-09 13:13:30 +04:00
? Flag::f_new_noncontact_peers_require_premium
: Flag())
| Flag::f_noncontact_peers_paid_stars
| (showGiftIcon ? Flag::f_display_gifts_button : Flag())
2025-03-18 12:24:03 +04:00
| Flag::f_disallowed_gifts;
const auto disallowedFlags = DisallowedFlag()
| ((disallowedGiftTypes & DisallowedGiftType::Premium)
2025-03-18 12:24:03 +04:00
? DisallowedFlag::f_disallow_premium_gifts
: DisallowedFlag())
| ((disallowedGiftTypes & DisallowedGiftType::Unlimited)
? DisallowedFlag::f_disallow_unlimited_stargifts
: DisallowedFlag())
| ((disallowedGiftTypes & DisallowedGiftType::Limited)
? DisallowedFlag::f_disallow_limited_stargifts
: DisallowedFlag())
| ((disallowedGiftTypes & DisallowedGiftType::Unique)
? DisallowedFlag::f_disallow_unique_stargifts
: DisallowedFlag());
2025-03-21 18:34:26 +04:00
const auto typesWas = _disallowedGiftTypes.current();
const auto typesChanged = (typesWas != disallowedGiftTypes);
2020-07-03 20:53:24 +04:00
_requestId = _api.request(MTPaccount_SetGlobalPrivacySettings(
2025-02-11 12:11:47 +04:00
MTP_globalPrivacySettings(
MTP_flags(flags),
2025-03-10 14:54:34 +04:00
MTP_long(newChargeStars),
2025-03-18 12:24:03 +04:00
MTP_disallowedGiftsSettings(MTP_flags(disallowedFlags)))
2020-07-03 20:53:24 +04:00
)).done([=](const MTPGlobalPrivacySettings &result) {
_requestId = 0;
apply(result);
2025-03-21 18:34:26 +04:00
if (typesChanged) {
_session->user()->updateFullForced();
}
2024-01-09 13:13:30 +04:00
}).fail([=](const MTP::Error &error) {
2020-07-03 20:53:24 +04:00
_requestId = 0;
2024-01-09 13:13:30 +04:00
if (error.type() == u"PREMIUM_ACCOUNT_REQUIRED"_q) {
update(
archiveAndMute,
unarchiveOnNewMessage,
hideReadTime,
false,
0,
DisallowedGiftTypes());
2024-01-09 13:13:30 +04:00
}
2020-07-03 20:53:24 +04:00
}).send();
_archiveAndMute = archiveAndMute;
2023-08-11 16:20:38 +02:00
_unarchiveOnNewMessage = unarchiveOnNewMessage;
2024-01-09 13:13:30 +04:00
_hideReadTime = hideReadTime;
_newRequirePremium = newRequirePremium;
_newChargeStars = newChargeStars;
_disallowedGiftTypes = disallowedGiftTypes;
2020-07-03 20:53:24 +04:00
}
void GlobalPrivacy::apply(const MTPGlobalPrivacySettings &settings) {
const auto &data = settings.data();
_archiveAndMute = data.is_archive_and_mute_new_noncontact_peers();
_unarchiveOnNewMessage = data.is_keep_archived_unmuted()
? UnarchiveOnNewMessage::None
: data.is_keep_archived_folders()
? UnarchiveOnNewMessage::NotInFoldersUnmuted
: UnarchiveOnNewMessage::AnyUnmuted;
_hideReadTime = data.is_hide_read_marks();
_newRequirePremium = data.is_new_noncontact_peers_require_premium();
_newChargeStars = data.vnoncontact_peers_paid_stars().value_or_empty();
2025-03-18 12:24:03 +04:00
if (const auto gifts = data.vdisallowed_gifts()) {
2025-03-18 13:37:12 +04:00
const auto &disallow = gifts->data();
_disallowedGiftTypes = DisallowedGiftType()
2025-03-18 13:37:12 +04:00
| (disallow.is_disallow_unlimited_stargifts()
? DisallowedGiftType::Unlimited
: DisallowedGiftType())
2025-03-18 13:37:12 +04:00
| (disallow.is_disallow_limited_stargifts()
? DisallowedGiftType::Limited
: DisallowedGiftType())
2025-03-18 13:37:12 +04:00
| (disallow.is_disallow_unique_stargifts()
? DisallowedGiftType::Unique
2025-03-18 12:24:03 +04:00
: DisallowedGiftType())
2025-03-18 13:37:12 +04:00
| (disallow.is_disallow_premium_gifts()
2025-03-18 12:24:03 +04:00
? DisallowedGiftType::Premium
2025-03-18 13:37:12 +04:00
: DisallowedGiftType())
| (data.is_display_gifts_button()
? DisallowedGiftType::SendHide
: DisallowedGiftType());
} else {
2025-03-18 13:37:12 +04:00
_disallowedGiftTypes = data.is_display_gifts_button()
? DisallowedGiftType::SendHide
: DisallowedGiftType();
}
2020-07-03 20:53:24 +04:00
}
} // namespace Api