190 lines
4.9 KiB
C++
190 lines
4.9 KiB
C++
/*
|
|
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"
|
|
#include "main/main_session.h"
|
|
#include "main/main_account.h"
|
|
#include "main/main_app_config.h"
|
|
|
|
namespace Api {
|
|
|
|
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));
|
|
}
|
|
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([=] {
|
|
_requestId = 0;
|
|
for (const auto &callback : base::take(_callbacks)) {
|
|
callback();
|
|
}
|
|
}).send();
|
|
|
|
_session->account().appConfig().value(
|
|
) | rpl::start_with_next([=] {
|
|
_showArchiveAndMute = _session->account().appConfig().get<bool>(
|
|
u"autoarchive_setting_available"_q,
|
|
false);
|
|
}, _session->lifetime());
|
|
}
|
|
|
|
bool GlobalPrivacy::archiveAndMuteCurrent() const {
|
|
return _archiveAndMute.current();
|
|
}
|
|
|
|
rpl::producer<bool> GlobalPrivacy::archiveAndMute() const {
|
|
return _archiveAndMute.value();
|
|
}
|
|
|
|
UnarchiveOnNewMessage GlobalPrivacy::unarchiveOnNewMessageCurrent() const {
|
|
return _unarchiveOnNewMessage.current();
|
|
}
|
|
|
|
auto GlobalPrivacy::unarchiveOnNewMessage() const
|
|
-> rpl::producer<UnarchiveOnNewMessage> {
|
|
return _unarchiveOnNewMessage.value();
|
|
}
|
|
|
|
rpl::producer<bool> GlobalPrivacy::showArchiveAndMute() const {
|
|
using namespace rpl::mappers;
|
|
|
|
return rpl::combine(
|
|
archiveAndMute(),
|
|
_showArchiveAndMute.value(),
|
|
_1 || _2);
|
|
}
|
|
|
|
rpl::producer<> GlobalPrivacy::suggestArchiveAndMute() const {
|
|
return _session->account().appConfig().suggestionRequested(
|
|
u"AUTOARCHIVE_POPULAR"_q);
|
|
}
|
|
|
|
void GlobalPrivacy::dismissArchiveAndMuteSuggestion() {
|
|
_session->account().appConfig().dismissSuggestion(
|
|
u"AUTOARCHIVE_POPULAR"_q);
|
|
}
|
|
|
|
void GlobalPrivacy::updateHideReadTime(bool hide) {
|
|
update(
|
|
archiveAndMuteCurrent(),
|
|
unarchiveOnNewMessageCurrent(),
|
|
hide,
|
|
newRequirePremiumCurrent());
|
|
}
|
|
|
|
bool GlobalPrivacy::hideReadTimeCurrent() const {
|
|
return _hideReadTime.current();
|
|
}
|
|
|
|
rpl::producer<bool> GlobalPrivacy::hideReadTime() const {
|
|
return _hideReadTime.value();
|
|
}
|
|
|
|
void GlobalPrivacy::updateNewRequirePremium(bool value) {
|
|
update(
|
|
archiveAndMuteCurrent(),
|
|
unarchiveOnNewMessageCurrent(),
|
|
hideReadTimeCurrent(),
|
|
value);
|
|
}
|
|
|
|
bool GlobalPrivacy::newRequirePremiumCurrent() const {
|
|
return _newRequirePremium.current();
|
|
}
|
|
|
|
rpl::producer<bool> GlobalPrivacy::newRequirePremium() const {
|
|
return _newRequirePremium.value();
|
|
}
|
|
|
|
|
|
void GlobalPrivacy::updateArchiveAndMute(bool value) {
|
|
update(
|
|
value,
|
|
unarchiveOnNewMessageCurrent(),
|
|
hideReadTimeCurrent(),
|
|
newRequirePremiumCurrent());
|
|
}
|
|
|
|
void GlobalPrivacy::updateUnarchiveOnNewMessage(
|
|
UnarchiveOnNewMessage value) {
|
|
update(
|
|
archiveAndMuteCurrent(),
|
|
value,
|
|
hideReadTimeCurrent(),
|
|
newRequirePremiumCurrent());
|
|
}
|
|
|
|
void GlobalPrivacy::update(
|
|
bool archiveAndMute,
|
|
UnarchiveOnNewMessage unarchiveOnNewMessage,
|
|
bool hideReadTime,
|
|
bool newRequirePremium) {
|
|
using Flag = MTPDglobalPrivacySettings::Flag;
|
|
|
|
_api.request(_requestId).cancel();
|
|
const auto flags = Flag()
|
|
| (archiveAndMute
|
|
? Flag::f_archive_and_mute_new_noncontact_peers
|
|
: Flag())
|
|
| (unarchiveOnNewMessage == UnarchiveOnNewMessage::None
|
|
? Flag::f_keep_archived_unmuted
|
|
: Flag())
|
|
| (unarchiveOnNewMessage != UnarchiveOnNewMessage::AnyUnmuted
|
|
? Flag::f_keep_archived_folders
|
|
: Flag())
|
|
| (hideReadTime ? Flag::f_hide_read_marks : Flag())
|
|
| ((newRequirePremium && _session->premium())
|
|
? Flag::f_new_noncontact_peers_require_premium
|
|
: Flag());
|
|
_requestId = _api.request(MTPaccount_SetGlobalPrivacySettings(
|
|
MTP_globalPrivacySettings(MTP_flags(flags))
|
|
)).done([=](const MTPGlobalPrivacySettings &result) {
|
|
_requestId = 0;
|
|
apply(result);
|
|
}).fail([=](const MTP::Error &error) {
|
|
_requestId = 0;
|
|
if (error.type() == u"PREMIUM_ACCOUNT_REQUIRED"_q) {
|
|
update(archiveAndMute, unarchiveOnNewMessage, hideReadTime, {});
|
|
}
|
|
}).send();
|
|
_archiveAndMute = archiveAndMute;
|
|
_unarchiveOnNewMessage = unarchiveOnNewMessage;
|
|
_hideReadTime = hideReadTime;
|
|
_newRequirePremium = newRequirePremium;
|
|
}
|
|
|
|
void GlobalPrivacy::apply(const MTPGlobalPrivacySettings &data) {
|
|
data.match([&](const MTPDglobalPrivacySettings &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();
|
|
});
|
|
}
|
|
|
|
} // namespace Api
|