tdesktop/Telegram/SourceFiles/boxes/passcode_box.h

200 lines
5.2 KiB
C
Raw Normal View History

/*
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
*/
#pragma once
2017-04-06 14:38:10 +00:00
#include "boxes/abstract_box.h"
#include "mtproto/sender.h"
2018-08-03 21:48:00 +00:00
#include "core/core_cloud_password.h"
namespace Ui {
class InputField;
class PasswordInput;
class LinkButton;
} // namespace Ui
namespace Core {
struct CloudPasswordState;
} // namespace Core
class PasscodeBox : public BoxContent, private MTP::Sender {
public:
PasscodeBox(QWidget*, bool turningOff);
struct CloudFields {
static CloudFields From(const Core::CloudPasswordState &current);
Core::CloudPasswordCheckRequest curRequest;
Core::CloudPasswordAlgo newAlgo;
bool hasRecovery = false;
bool notEmptyPassport = false;
QString hint;
Core::SecureSecretAlgo newSecureSecretAlgo;
bool turningOff = false;
// Check cloud password for some action.
2019-06-14 14:04:30 +00:00
Fn<void(const Core::CloudPasswordResult &)> customCheckCallback;
2019-06-19 11:22:25 +00:00
rpl::producer<QString> customTitle;
2019-06-14 14:04:30 +00:00
std::optional<QString> customDescription;
2019-06-19 11:22:25 +00:00
rpl::producer<QString> customSubmitButton;
};
PasscodeBox(QWidget*, const CloudFields &fields);
rpl::producer<QByteArray> newPasswordSet() const;
rpl::producer<> passwordReloadNeeded() const;
2018-11-07 09:39:31 +00:00
rpl::producer<> clearUnconfirmedPassword() const;
2019-06-14 14:04:30 +00:00
bool handleCustomCheckError(const RPCError &error);
protected:
void prepare() override;
void setInnerFocus() override;
void paintEvent(QPaintEvent *e) override;
void resizeEvent(QResizeEvent *e) override;
private:
2018-08-10 19:19:46 +00:00
using CheckPasswordCallback = Fn<void(
const Core::CloudPasswordResult &check)>;
void submit();
void closeReplacedBy();
void oldChanged();
void newChanged();
void emailChanged();
void save(bool force = false);
void badOldPasscode();
void recoverByEmail();
void recoverExpired();
2018-08-03 21:48:00 +00:00
bool currentlyHave() const;
bool onlyCheckCurrent() const;
void setPasswordDone(const QByteArray &newPasswordBytes);
2018-08-10 19:19:46 +00:00
void setPasswordFail(const RPCError &error);
void setPasswordFail(
const QByteArray &newPasswordBytes,
2018-11-07 09:39:31 +00:00
const QString &email,
const RPCError &error);
2018-11-07 09:39:31 +00:00
void validateEmail(
const QString &email,
int codeLength,
const QByteArray &newPasswordBytes);
void recoverStarted(const MTPauth_PasswordRecovery &result);
2018-08-10 19:19:46 +00:00
void recoverStartFail(const RPCError &error);
void recover();
void submitOnlyCheckCloudPassword(const QString &oldPassword);
void setNewCloudPassword(const QString &newPassword);
2018-08-10 19:19:46 +00:00
void checkPassword(
const QString &oldPassword,
CheckPasswordCallback callback);
void checkPasswordHash(CheckPasswordCallback callback);
void changeCloudPassword(
const QString &oldPassword,
const QString &newPassword);
void changeCloudPassword(
const QString &oldPassword,
2018-08-10 19:19:46 +00:00
const Core::CloudPasswordResult &check,
const QString &newPassword);
2018-08-10 19:19:46 +00:00
void sendChangeCloudPassword(
2018-08-10 19:19:46 +00:00
const Core::CloudPasswordResult &check,
const QString &newPassword,
const QByteArray &secureSecret);
2018-08-10 19:19:46 +00:00
void suggestSecretReset(const QString &newPassword);
void resetSecret(
const Core::CloudPasswordResult &check,
const QString &newPassword,
Fn<void()> callback);
void sendOnlyCheckCloudPassword(const QString &oldPassword);
2018-08-10 19:19:46 +00:00
void sendClearCloudPassword(const Core::CloudPasswordResult &check);
void handleSrpIdInvalid();
void requestPasswordData();
void passwordChecked();
void serverError();
QString _pattern;
QPointer<BoxContent> _replacedBy;
bool _turningOff = false;
bool _cloudPwd = false;
CloudFields _cloudFields;
mtpRequestId _setRequest = 0;
crl::time _lastSrpIdInvalidTime = 0;
bool _skipEmailWarning = false;
2018-08-10 19:19:46 +00:00
CheckPasswordCallback _checkPasswordCallback;
bytes::vector _checkPasswordHash;
int _aboutHeight = 0;
2019-06-12 13:26:04 +00:00
Ui::Text::String _about, _hintText;
object_ptr<Ui::PasswordInput> _oldPasscode;
object_ptr<Ui::PasswordInput> _newPasscode;
object_ptr<Ui::PasswordInput> _reenterPasscode;
object_ptr<Ui::InputField> _passwordHint;
object_ptr<Ui::InputField> _recoverEmail;
object_ptr<Ui::LinkButton> _recover;
QString _oldError, _newError, _emailError;
rpl::event_stream<QByteArray> _newPasswordSet;
rpl::event_stream<> _passwordReloadNeeded;
2018-11-07 09:39:31 +00:00
rpl::event_stream<> _clearUnconfirmedPassword;
};
class RecoverBox : public BoxContent, public RPCSender {
public:
RecoverBox(QWidget*, const QString &pattern, bool notEmptyPassport);
rpl::producer<> passwordCleared() const;
rpl::producer<> recoveryExpired() const;
//void reloadPassword();
//void recoveryExpired();
protected:
void prepare() override;
void setInnerFocus() override;
void paintEvent(QPaintEvent *e) override;
void resizeEvent(QResizeEvent *e) override;
private:
void submit();
void codeChanged();
void codeSubmitDone(bool recover, const MTPauth_Authorization &result);
bool codeSubmitFail(const RPCError &error);
mtpRequestId _submitRequest = 0;
QString _pattern;
bool _notEmptyPassport = false;
object_ptr<Ui::InputField> _recoverCode;
QString _error;
rpl::event_stream<> _passwordCleared;
rpl::event_stream<> _recoveryExpired;
};
2018-11-07 09:39:31 +00:00
struct RecoveryEmailValidation {
object_ptr<BoxContent> box;
rpl::producer<> reloadRequests;
rpl::producer<> cancelRequests;
};
RecoveryEmailValidation ConfirmRecoveryEmail(const QString &pattern);