tdesktop/Telegram/SourceFiles/boxes/passcode_box.h

187 lines
4.8 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
class PasscodeBox : public BoxContent, private MTP::Sender {
public:
PasscodeBox(QWidget*, bool turningOff);
PasscodeBox(
QWidget*,
2018-08-10 19:19:46 +00:00
const Core::CloudPasswordCheckRequest &curRequest,
2018-08-03 21:48:00 +00:00
const Core::CloudPasswordAlgo &newAlgo,
bool hasRecovery,
bool notEmptyPassport,
const QString &hint,
2018-08-03 21:48:00 +00:00
const Core::SecureSecretAlgo &newSecureSecretAlgo,
bool turningOff = false);
rpl::producer<QByteArray> newPasswordSet() const;
rpl::producer<> passwordReloadNeeded() const;
2018-11-07 09:39:31 +00:00
rpl::producer<> clearUnconfirmedPassword() const;
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;
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 clearCloudPassword(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 sendClearCloudPassword(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;
mtpRequestId _setRequest = 0;
2018-08-10 19:19:46 +00:00
Core::CloudPasswordCheckRequest _curRequest;
crl::time _lastSrpIdInvalidTime = 0;
2018-08-03 21:48:00 +00:00
Core::CloudPasswordAlgo _newAlgo;
Core::SecureSecretAlgo _newSecureSecretAlgo;
bool _hasRecovery = false;
bool _notEmptyPassport = false;
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);