Add separate authorizationStateWaitRegistration.
GitOrigin-RevId: 1e41124d6174e956ce74266c9140ad346cf8a6f0
This commit is contained in:
parent
93ee925d69
commit
b1347c3226
@ -237,19 +237,21 @@ class TdExample {
|
|||||||
need_restart_ = true;
|
need_restart_ = true;
|
||||||
std::cerr << "Terminated" << std::endl;
|
std::cerr << "Terminated" << std::endl;
|
||||||
},
|
},
|
||||||
[this](td_api::authorizationStateWaitCode &wait_code) {
|
[this](td_api::authorizationStateWaitCode &) {
|
||||||
|
std::cerr << "Enter authentication code: ";
|
||||||
|
std::string code;
|
||||||
|
std::cin >> code;
|
||||||
|
send_query(td_api::make_object<td_api::checkAuthenticationCode>(code),
|
||||||
|
create_authentication_query_handler());
|
||||||
|
},
|
||||||
|
[this](td_api::authorizationStateWaitRegistration &) {
|
||||||
std::string first_name;
|
std::string first_name;
|
||||||
std::string last_name;
|
std::string last_name;
|
||||||
if (!wait_code.is_registered_) {
|
|
||||||
std::cerr << "Enter your first name: ";
|
std::cerr << "Enter your first name: ";
|
||||||
std::cin >> first_name;
|
std::cin >> first_name;
|
||||||
std::cerr << "Enter your last name: ";
|
std::cerr << "Enter your last name: ";
|
||||||
std::cin >> last_name;
|
std::cin >> last_name;
|
||||||
}
|
send_query(td_api::make_object<td_api::registerUser>(first_name, last_name),
|
||||||
std::cerr << "Enter authentication code: ";
|
|
||||||
std::string code;
|
|
||||||
std::cin >> code;
|
|
||||||
send_query(td_api::make_object<td_api::checkAuthenticationCode>(code, first_name, last_name),
|
|
||||||
create_authentication_query_handler());
|
create_authentication_query_handler());
|
||||||
},
|
},
|
||||||
[this](td_api::authorizationStateWaitPassword &) {
|
[this](td_api::authorizationStateWaitPassword &) {
|
||||||
|
@ -98,7 +98,13 @@ namespace TdExample
|
|||||||
else if (_authorizationState is TdApi.AuthorizationStateWaitCode)
|
else if (_authorizationState is TdApi.AuthorizationStateWaitCode)
|
||||||
{
|
{
|
||||||
string code = ReadLine("Please enter authentication code: ");
|
string code = ReadLine("Please enter authentication code: ");
|
||||||
_client.Send(new TdApi.CheckAuthenticationCode(code, "", ""), new AuthorizationRequestHandler());
|
_client.Send(new TdApi.CheckAuthenticationCode(code), new AuthorizationRequestHandler());
|
||||||
|
}
|
||||||
|
else if (_authorizationState is TdApi.AuthorizationStateWaitRegistration)
|
||||||
|
{
|
||||||
|
string firstName = ReadLine("Please enter your first name: ");
|
||||||
|
string lastName = ReadLine("Please enter your last name: ");
|
||||||
|
_client.Send(new TdApi.RegisterUser(firstName, lastName), new AuthorizationRequestHandler());
|
||||||
}
|
}
|
||||||
else if (_authorizationState is TdApi.AuthorizationStateWaitPassword)
|
else if (_authorizationState is TdApi.AuthorizationStateWaitPassword)
|
||||||
{
|
{
|
||||||
|
@ -117,7 +117,13 @@ public final class Example {
|
|||||||
}
|
}
|
||||||
case TdApi.AuthorizationStateWaitCode.CONSTRUCTOR: {
|
case TdApi.AuthorizationStateWaitCode.CONSTRUCTOR: {
|
||||||
String code = promptString("Please enter authentication code: ");
|
String code = promptString("Please enter authentication code: ");
|
||||||
client.send(new TdApi.CheckAuthenticationCode(code, "", ""), new AuthorizationRequestHandler());
|
client.send(new TdApi.CheckAuthenticationCode(code), new AuthorizationRequestHandler());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case TdApi.AuthorizationStateWaitRegistration.CONSTRUCTOR: {
|
||||||
|
String firstName = promptString("Please enter your first name: ");
|
||||||
|
String lastName = promptString("Please enter your last name: ");
|
||||||
|
client.send(new TdApi.RegisterUser(firstName, lastName), new AuthorizationRequestHandler());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case TdApi.AuthorizationStateWaitPassword.CONSTRUCTOR: {
|
case TdApi.AuthorizationStateWaitPassword.CONSTRUCTOR: {
|
||||||
|
@ -124,6 +124,12 @@ while True:
|
|||||||
code = input('Please enter the authentication code you received: ')
|
code = input('Please enter the authentication code you received: ')
|
||||||
td_send({'@type': 'checkAuthenticationCode', 'code': code})
|
td_send({'@type': 'checkAuthenticationCode', 'code': code})
|
||||||
|
|
||||||
|
# wait for first and last name for new users
|
||||||
|
if auth_state['@type'] == 'authorizationStateWaitRegistration':
|
||||||
|
first_name = input('Please enter your first name: ')
|
||||||
|
last_name = input('Please enter your last name: ')
|
||||||
|
td_send({'@type': 'registerUser', 'first_name': first_name, 'last_name': last_name})
|
||||||
|
|
||||||
# wait for password if present
|
# wait for password if present
|
||||||
if auth_state['@type'] == 'authorizationStateWaitPassword':
|
if auth_state['@type'] == 'authorizationStateWaitPassword':
|
||||||
password = input('Please enter your password: ')
|
password = input('Please enter your password: ')
|
||||||
|
@ -132,19 +132,19 @@ func updateAuthorizationState(authorizationState: Dictionary<String, Any>) {
|
|||||||
client.queryAsync(query:["@type":"setAuthenticationPhoneNumber", "phone_number":phone], f:checkAuthenticationError)
|
client.queryAsync(query:["@type":"setAuthenticationPhoneNumber", "phone_number":phone], f:checkAuthenticationError)
|
||||||
|
|
||||||
case "authorizationStateWaitCode":
|
case "authorizationStateWaitCode":
|
||||||
|
var code: String = ""
|
||||||
|
print("Enter (SMS) code: ")
|
||||||
|
code = myReadLine()
|
||||||
|
client.queryAsync(query:["@type":"checkAuthenticationCode", "code":code], f:checkAuthenticationError)
|
||||||
|
|
||||||
|
case "authorizationStateWaitRegistration":
|
||||||
var first_name: String = ""
|
var first_name: String = ""
|
||||||
var last_name: String = ""
|
var last_name: String = ""
|
||||||
var code: String = ""
|
|
||||||
if let is_registered = authorizationState["is_registered"] as? Bool, is_registered {
|
|
||||||
} else {
|
|
||||||
print("Enter your first name: ")
|
print("Enter your first name: ")
|
||||||
first_name = myReadLine()
|
first_name = myReadLine()
|
||||||
print("Enter your last name: ")
|
print("Enter your last name: ")
|
||||||
last_name = myReadLine()
|
last_name = myReadLine()
|
||||||
}
|
client.queryAsync(query:["@type":"registerUser", "first_name":first_name, "last_name":last_name], f:checkAuthenticationError)
|
||||||
print("Enter (SMS) code: ")
|
|
||||||
code = myReadLine()
|
|
||||||
client.queryAsync(query:["@type":"checkAuthenticationCode", "code":code, "first_name":first_name, "last_name":last_name], f:checkAuthenticationError)
|
|
||||||
|
|
||||||
case "authorizationStateWaitPassword":
|
case "authorizationStateWaitPassword":
|
||||||
print("Enter password: ")
|
print("Enter password: ")
|
||||||
|
@ -100,7 +100,7 @@ namespace TdApp
|
|||||||
{
|
{
|
||||||
var args = command.Split(" ".ToCharArray(), 2);
|
var args = command.Split(" ".ToCharArray(), 2);
|
||||||
AcceptCommand(command);
|
AcceptCommand(command);
|
||||||
_client.Send(new TdApi.CheckAuthenticationCode(args[1], String.Empty, String.Empty), _handler);
|
_client.Send(new TdApi.CheckAuthenticationCode(args[1]), _handler);
|
||||||
}
|
}
|
||||||
else if (command.StartsWith("cap"))
|
else if (command.StartsWith("cap"))
|
||||||
{
|
{
|
||||||
|
@ -88,8 +88,11 @@ authorizationStateWaitEncryptionKey is_encrypted:Bool = AuthorizationState;
|
|||||||
//@description TDLib needs the user's phone number to authorize
|
//@description TDLib needs the user's phone number to authorize
|
||||||
authorizationStateWaitPhoneNumber = AuthorizationState;
|
authorizationStateWaitPhoneNumber = AuthorizationState;
|
||||||
|
|
||||||
//@description TDLib needs the user's authentication code to finalize authorization @is_registered True, if the user is already registered @terms_of_service Telegram terms of service, which should be accepted before user can continue registration; may be null @code_info Information about the authorization code that was sent
|
//@description TDLib needs the user's authentication code to authorize @code_info Information about the authorization code that was sent
|
||||||
authorizationStateWaitCode is_registered:Bool terms_of_service:termsOfService code_info:authenticationCodeInfo = AuthorizationState;
|
authorizationStateWaitCode code_info:authenticationCodeInfo = AuthorizationState;
|
||||||
|
|
||||||
|
//@description The user is unregistered and need to accept terms of service and enter his first name and last name to finish registration @terms_of_service Telegram terms of service
|
||||||
|
authorizationStateWaitRegistration terms_of_service:termsOfService = AuthorizationState;
|
||||||
|
|
||||||
//@description The user has been authorized, but needs to enter a password to start using the application @password_hint Hint for the password; may be empty @has_recovery_email_address True, if a recovery email address has been set up
|
//@description The user has been authorized, but needs to enter a password to start using the application @password_hint Hint for the password; may be empty @has_recovery_email_address True, if a recovery email address has been set up
|
||||||
//@recovery_email_address_pattern Pattern of the email address to which the recovery email was sent; empty until a recovery email has been sent
|
//@recovery_email_address_pattern Pattern of the email address to which the recovery email was sent; empty until a recovery email has been sent
|
||||||
@ -2805,9 +2808,11 @@ setAuthenticationPhoneNumber phone_number:string settings:phoneNumberAuthenticat
|
|||||||
resendAuthenticationCode = Ok;
|
resendAuthenticationCode = Ok;
|
||||||
|
|
||||||
//@description Checks the authentication code. Works only when the current authorization state is authorizationStateWaitCode @code The verification code received via SMS, Telegram message, phone call, or flash call
|
//@description Checks the authentication code. Works only when the current authorization state is authorizationStateWaitCode @code The verification code received via SMS, Telegram message, phone call, or flash call
|
||||||
//@first_name If the user is not yet registered, the first name of the user; 1-64 characters. You can also pass an empty string for unregistered user there to check verification code validness. In the latter case PHONE_NUMBER_UNOCCUPIED error will be returned for a valid code
|
checkAuthenticationCode code:string = Ok;
|
||||||
//@last_name If the user is not yet registered; the last name of the user; optional; 0-64 characters
|
|
||||||
checkAuthenticationCode code:string first_name:string last_name:string = Ok;
|
//@description Finishes user registration. Works only when the current authorization state is authorizationStateWaitRegistration
|
||||||
|
//@first_name The first name of the user; 1-64 characters @last_name The last name of the user; 0-64 characters
|
||||||
|
registerUser first_name:string last_name:string = Ok;
|
||||||
|
|
||||||
//@description Checks the authentication password for correctness. Works only when the current authorization state is authorizationStateWaitPassword @password The password to check
|
//@description Checks the authentication password for correctness. Works only when the current authorization state is authorizationStateWaitPassword @password The password to check
|
||||||
checkAuthenticationPassword password:string = Ok;
|
checkAuthenticationPassword password:string = Ok;
|
||||||
|
Binary file not shown.
@ -99,9 +99,12 @@ tl_object_ptr<td_api::AuthorizationState> AuthManager::get_authorization_state_o
|
|||||||
case State::Ok:
|
case State::Ok:
|
||||||
return make_tl_object<td_api::authorizationStateReady>();
|
return make_tl_object<td_api::authorizationStateReady>();
|
||||||
case State::WaitCode:
|
case State::WaitCode:
|
||||||
return send_code_helper_.get_authorization_state_wait_code(terms_of_service_);
|
return send_code_helper_.get_authorization_state_wait_code();
|
||||||
case State::WaitPhoneNumber:
|
case State::WaitPhoneNumber:
|
||||||
return make_tl_object<td_api::authorizationStateWaitPhoneNumber>();
|
return make_tl_object<td_api::authorizationStateWaitPhoneNumber>();
|
||||||
|
case State::WaitRegistration:
|
||||||
|
return make_tl_object<td_api::authorizationStateWaitRegistration>(
|
||||||
|
terms_of_service_.get_terms_of_service_object());
|
||||||
case State::WaitPassword:
|
case State::WaitPassword:
|
||||||
return make_tl_object<td_api::authorizationStateWaitPassword>(
|
return make_tl_object<td_api::authorizationStateWaitPassword>(
|
||||||
wait_password_state_.hint_, wait_password_state_.has_recovery_, wait_password_state_.email_address_pattern_);
|
wait_password_state_.hint_, wait_password_state_.has_recovery_, wait_password_state_.email_address_pattern_);
|
||||||
@ -169,7 +172,8 @@ void AuthManager::check_bot_token(uint64 query_id, string bot_token) {
|
|||||||
void AuthManager::set_phone_number(uint64 query_id, string phone_number,
|
void AuthManager::set_phone_number(uint64 query_id, string phone_number,
|
||||||
td_api::object_ptr<td_api::phoneNumberAuthenticationSettings> settings) {
|
td_api::object_ptr<td_api::phoneNumberAuthenticationSettings> settings) {
|
||||||
if (state_ != State::WaitPhoneNumber) {
|
if (state_ != State::WaitPhoneNumber) {
|
||||||
if ((state_ == State::WaitCode || state_ == State::WaitPassword) && net_query_id_ == 0) {
|
if ((state_ == State::WaitCode || state_ == State::WaitPassword || state_ == State::WaitRegistration) &&
|
||||||
|
net_query_id_ == 0) {
|
||||||
// ok
|
// ok
|
||||||
} else {
|
} else {
|
||||||
return on_query_error(query_id, Status::Error(8, "setAuthenticationPhoneNumber unexpected"));
|
return on_query_error(query_id, Status::Error(8, "setAuthenticationPhoneNumber unexpected"));
|
||||||
@ -218,20 +222,26 @@ void AuthManager::resend_authentication_code(uint64 query_id) {
|
|||||||
NetQuery::Type::Common, NetQuery::AuthFlag::Off));
|
NetQuery::Type::Common, NetQuery::AuthFlag::Off));
|
||||||
}
|
}
|
||||||
|
|
||||||
void AuthManager::check_code(uint64 query_id, string code, string first_name, string last_name) {
|
void AuthManager::check_code(uint64 query_id, string code) {
|
||||||
if (state_ != State::WaitCode) {
|
if (state_ != State::WaitCode) {
|
||||||
return on_query_error(query_id, Status::Error(8, "checkAuthenticationCode unexpected"));
|
return on_query_error(query_id, Status::Error(8, "checkAuthenticationCode unexpected"));
|
||||||
}
|
}
|
||||||
|
|
||||||
code_ = code;
|
code_ = std::move(code);
|
||||||
on_new_query(query_id);
|
on_new_query(query_id);
|
||||||
if (send_code_helper_.phone_registered() || first_name.empty()) {
|
|
||||||
start_net_query(NetQueryType::SignIn,
|
start_net_query(NetQueryType::SignIn,
|
||||||
G()->net_query_creator().create(
|
G()->net_query_creator().create(
|
||||||
create_storer(telegram_api::auth_signIn(send_code_helper_.phone_number().str(),
|
create_storer(telegram_api::auth_signIn(send_code_helper_.phone_number().str(),
|
||||||
send_code_helper_.phone_code_hash().str(), code)),
|
send_code_helper_.phone_code_hash().str(), code_)),
|
||||||
DcId::main(), NetQuery::Type::Common, NetQuery::AuthFlag::Off));
|
DcId::main(), NetQuery::Type::Common, NetQuery::AuthFlag::Off));
|
||||||
} else {
|
}
|
||||||
|
|
||||||
|
void AuthManager::register_user(uint64 query_id, string first_name, string last_name) {
|
||||||
|
if (state_ != State::WaitRegistration) {
|
||||||
|
return on_query_error(query_id, Status::Error(8, "registerUser unexpected"));
|
||||||
|
}
|
||||||
|
|
||||||
|
on_new_query(query_id);
|
||||||
first_name = clean_name(first_name, MAX_NAME_LENGTH);
|
first_name = clean_name(first_name, MAX_NAME_LENGTH);
|
||||||
if (first_name.empty()) {
|
if (first_name.empty()) {
|
||||||
return on_query_error(Status::Error(8, "First name can't be empty"));
|
return on_query_error(Status::Error(8, "First name can't be empty"));
|
||||||
@ -240,12 +250,11 @@ void AuthManager::check_code(uint64 query_id, string code, string first_name, st
|
|||||||
last_name = clean_name(last_name, MAX_NAME_LENGTH);
|
last_name = clean_name(last_name, MAX_NAME_LENGTH);
|
||||||
start_net_query(
|
start_net_query(
|
||||||
NetQueryType::SignUp,
|
NetQueryType::SignUp,
|
||||||
G()->net_query_creator().create(create_storer(telegram_api::auth_signUp(
|
G()->net_query_creator().create(create_storer(telegram_api::auth_signUp(send_code_helper_.phone_number().str(),
|
||||||
send_code_helper_.phone_number().str(),
|
send_code_helper_.phone_code_hash().str(),
|
||||||
send_code_helper_.phone_code_hash().str(), code, first_name, last_name)),
|
code_, first_name, last_name)),
|
||||||
DcId::main(), NetQuery::Type::Common, NetQuery::AuthFlag::Off));
|
DcId::main(), NetQuery::Type::Common, NetQuery::AuthFlag::Off));
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void AuthManager::check_password(uint64 query_id, string password) {
|
void AuthManager::check_password(uint64 query_id, string password) {
|
||||||
if (state_ != State::WaitPassword) {
|
if (state_ != State::WaitPassword) {
|
||||||
@ -374,7 +383,9 @@ void AuthManager::on_send_code_result(NetQueryPtr &result) {
|
|||||||
|
|
||||||
LOG(INFO) << "Receive " << to_string(sent_code);
|
LOG(INFO) << "Receive " << to_string(sent_code);
|
||||||
|
|
||||||
|
if (terms_of_service_.get_id().empty()) {
|
||||||
terms_of_service_ = TermsOfService(std::move(sent_code->terms_of_service_));
|
terms_of_service_ = TermsOfService(std::move(sent_code->terms_of_service_));
|
||||||
|
}
|
||||||
|
|
||||||
send_code_helper_.on_sent_code(std::move(sent_code));
|
send_code_helper_.on_sent_code(std::move(sent_code));
|
||||||
|
|
||||||
@ -591,6 +602,12 @@ void AuthManager::on_result(NetQueryPtr result) {
|
|||||||
DcId::main(), NetQuery::Type::Common, NetQuery::AuthFlag::Off));
|
DcId::main(), NetQuery::Type::Common, NetQuery::AuthFlag::Off));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (type == NetQueryType::SignIn && result->error().message() == CSlice("PHONE_NUMBER_UNOCCUPIED")) {
|
||||||
|
code_ = "11111";
|
||||||
|
update_state(State::WaitRegistration);
|
||||||
|
on_query_ok();
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (type != NetQueryType::LogOut) {
|
if (type != NetQueryType::LogOut) {
|
||||||
if (query_id_ != 0) {
|
if (query_id_ != 0) {
|
||||||
if (state_ == State::WaitPhoneNumber) {
|
if (state_ == State::WaitPhoneNumber) {
|
||||||
@ -686,6 +703,9 @@ bool AuthManager::load_state() {
|
|||||||
terms_of_service_ = std::move(db_state.terms_of_service_);
|
terms_of_service_ = std::move(db_state.terms_of_service_);
|
||||||
} else if (db_state.state_ == State::WaitPassword) {
|
} else if (db_state.state_ == State::WaitPassword) {
|
||||||
wait_password_state_ = std::move(db_state.wait_password_state_);
|
wait_password_state_ = std::move(db_state.wait_password_state_);
|
||||||
|
} else if (db_state.state_ == State::WaitRegistration) {
|
||||||
|
code_ = "11111"; // the code has already been checked
|
||||||
|
terms_of_service_ = std::move(db_state.terms_of_service_);
|
||||||
} else {
|
} else {
|
||||||
UNREACHABLE();
|
UNREACHABLE();
|
||||||
}
|
}
|
||||||
@ -694,21 +714,23 @@ bool AuthManager::load_state() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void AuthManager::save_state() {
|
void AuthManager::save_state() {
|
||||||
if (state_ != State::WaitCode && state_ != State::WaitPassword) {
|
if (state_ != State::WaitCode && state_ != State::WaitPassword && state_ != State::WaitRegistration) {
|
||||||
if (state_ != State::Closing) {
|
if (state_ != State::Closing) {
|
||||||
G()->td_db()->get_binlog_pmc()->erase("auth_state");
|
G()->td_db()->get_binlog_pmc()->erase("auth_state");
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
DbState db_state;
|
DbState db_state = [&] {
|
||||||
if (state_ == State::WaitCode) {
|
if (state_ == State::WaitCode) {
|
||||||
db_state = DbState::wait_code(api_id_, api_hash_, send_code_helper_, terms_of_service_);
|
return DbState::wait_code(api_id_, api_hash_, send_code_helper_, terms_of_service_);
|
||||||
} else if (state_ == State::WaitPassword) {
|
} else if (state_ == State::WaitPassword) {
|
||||||
db_state = DbState::wait_password(api_id_, api_hash_, wait_password_state_);
|
return DbState::wait_password(api_id_, api_hash_, wait_password_state_);
|
||||||
} else {
|
} else {
|
||||||
UNREACHABLE();
|
CHECK(state_ == State::WaitRegistration);
|
||||||
|
return DbState::wait_registration(api_id_, api_hash_, terms_of_service_);
|
||||||
}
|
}
|
||||||
|
}();
|
||||||
G()->td_db()->get_binlog_pmc()->set("auth_state", log_event_store(db_state).as_slice().str());
|
G()->td_db()->get_binlog_pmc()->set("auth_state", log_event_store(db_state).as_slice().str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -35,7 +35,8 @@ class AuthManager : public NetActor {
|
|||||||
void set_phone_number(uint64 query_id, string phone_number,
|
void set_phone_number(uint64 query_id, string phone_number,
|
||||||
td_api::object_ptr<td_api::phoneNumberAuthenticationSettings> settings);
|
td_api::object_ptr<td_api::phoneNumberAuthenticationSettings> settings);
|
||||||
void resend_authentication_code(uint64 query_id);
|
void resend_authentication_code(uint64 query_id);
|
||||||
void check_code(uint64 query_id, string code, string first_name, string last_name);
|
void check_code(uint64 query_id, string code);
|
||||||
|
void register_user(uint64 query_id, string first_name, string last_name);
|
||||||
void check_bot_token(uint64 query_id, string bot_token);
|
void check_bot_token(uint64 query_id, string bot_token);
|
||||||
void check_password(uint64 query_id, string password);
|
void check_password(uint64 query_id, string password);
|
||||||
void request_password_recovery(uint64 query_id);
|
void request_password_recovery(uint64 query_id);
|
||||||
@ -57,6 +58,7 @@ class AuthManager : public NetActor {
|
|||||||
WaitPhoneNumber,
|
WaitPhoneNumber,
|
||||||
WaitCode,
|
WaitCode,
|
||||||
WaitPassword,
|
WaitPassword,
|
||||||
|
WaitRegistration,
|
||||||
Ok,
|
Ok,
|
||||||
LoggingOut,
|
LoggingOut,
|
||||||
DestroyingKeys,
|
DestroyingKeys,
|
||||||
@ -102,30 +104,32 @@ class AuthManager : public NetActor {
|
|||||||
|
|
||||||
// WaitCode
|
// WaitCode
|
||||||
SendCodeHelper send_code_helper_;
|
SendCodeHelper send_code_helper_;
|
||||||
TermsOfService terms_of_service_;
|
|
||||||
|
|
||||||
// WaitPassword
|
// WaitPassword
|
||||||
WaitPasswordState wait_password_state_;
|
WaitPasswordState wait_password_state_;
|
||||||
|
|
||||||
|
// WaitRegistration
|
||||||
|
TermsOfService terms_of_service_;
|
||||||
|
|
||||||
|
DbState() = default;
|
||||||
|
// TODO layer 104+: remove terms_of_service
|
||||||
static DbState wait_code(int32 api_id, string api_hash, SendCodeHelper send_code_helper,
|
static DbState wait_code(int32 api_id, string api_hash, SendCodeHelper send_code_helper,
|
||||||
TermsOfService terms_of_service) {
|
TermsOfService terms_of_service) {
|
||||||
DbState state;
|
DbState state(State::WaitCode, api_id, api_hash);
|
||||||
state.state_ = State::WaitCode;
|
|
||||||
state.api_id_ = api_id;
|
|
||||||
state.api_hash_ = api_hash;
|
|
||||||
state.send_code_helper_ = std::move(send_code_helper);
|
state.send_code_helper_ = std::move(send_code_helper);
|
||||||
state.terms_of_service_ = std::move(terms_of_service);
|
state.terms_of_service_ = std::move(terms_of_service);
|
||||||
state.state_timestamp_ = Timestamp::now();
|
|
||||||
return state;
|
return state;
|
||||||
}
|
}
|
||||||
|
|
||||||
static DbState wait_password(int32 api_id, string api_hash, WaitPasswordState wait_password_state) {
|
static DbState wait_password(int32 api_id, string api_hash, WaitPasswordState wait_password_state) {
|
||||||
DbState state;
|
DbState state(State::WaitPassword, api_id, api_hash);
|
||||||
state.state_ = State::WaitPassword;
|
|
||||||
state.api_id_ = api_id;
|
|
||||||
state.api_hash_ = api_hash;
|
|
||||||
state.wait_password_state_ = std::move(wait_password_state);
|
state.wait_password_state_ = std::move(wait_password_state);
|
||||||
state.state_timestamp_ = Timestamp::now();
|
return state;
|
||||||
|
}
|
||||||
|
|
||||||
|
static DbState wait_registration(int32 api_id, string api_hash, TermsOfService terms_of_service) {
|
||||||
|
DbState state(State::WaitRegistration, api_id, api_hash);
|
||||||
|
state.terms_of_service_ = std::move(terms_of_service);
|
||||||
return state;
|
return state;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -133,6 +137,11 @@ class AuthManager : public NetActor {
|
|||||||
void store(StorerT &storer) const;
|
void store(StorerT &storer) const;
|
||||||
template <class ParserT>
|
template <class ParserT>
|
||||||
void parse(ParserT &parser);
|
void parse(ParserT &parser);
|
||||||
|
|
||||||
|
private:
|
||||||
|
DbState(State state, int32 api_id, string api_hash)
|
||||||
|
: state_(state), api_id_(api_id), api_hash_(api_hash), state_timestamp_(Timestamp::now()) {
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
bool load_state();
|
bool load_state();
|
||||||
@ -148,7 +157,11 @@ class AuthManager : public NetActor {
|
|||||||
// State::WaitCode
|
// State::WaitCode
|
||||||
SendCodeHelper send_code_helper_;
|
SendCodeHelper send_code_helper_;
|
||||||
string code_;
|
string code_;
|
||||||
|
|
||||||
|
// State::WaitPassword
|
||||||
string password_;
|
string password_;
|
||||||
|
|
||||||
|
// State::WaitRegistration
|
||||||
TermsOfService terms_of_service_;
|
TermsOfService terms_of_service_;
|
||||||
|
|
||||||
// for bots
|
// for bots
|
||||||
|
@ -51,10 +51,12 @@ void AuthManager::DbState::store(StorerT &storer) const {
|
|||||||
bool has_terms_of_service = !terms_of_service_.get_id().empty();
|
bool has_terms_of_service = !terms_of_service_.get_id().empty();
|
||||||
bool is_pbkdf2_supported = true;
|
bool is_pbkdf2_supported = true;
|
||||||
bool is_srp_supported = true;
|
bool is_srp_supported = true;
|
||||||
|
bool is_wait_registration_supported = true;
|
||||||
BEGIN_STORE_FLAGS();
|
BEGIN_STORE_FLAGS();
|
||||||
STORE_FLAG(has_terms_of_service);
|
STORE_FLAG(has_terms_of_service);
|
||||||
STORE_FLAG(is_pbkdf2_supported);
|
STORE_FLAG(is_pbkdf2_supported);
|
||||||
STORE_FLAG(is_srp_supported);
|
STORE_FLAG(is_srp_supported);
|
||||||
|
STORE_FLAG(is_wait_registration_supported);
|
||||||
END_STORE_FLAGS();
|
END_STORE_FLAGS();
|
||||||
store(state_, storer);
|
store(state_, storer);
|
||||||
store(api_id_, storer);
|
store(api_id_, storer);
|
||||||
@ -69,6 +71,7 @@ void AuthManager::DbState::store(StorerT &storer) const {
|
|||||||
store(send_code_helper_, storer);
|
store(send_code_helper_, storer);
|
||||||
} else if (state_ == State::WaitPassword) {
|
} else if (state_ == State::WaitPassword) {
|
||||||
store(wait_password_state_, storer);
|
store(wait_password_state_, storer);
|
||||||
|
} else if (state_ == State::WaitRegistration) {
|
||||||
} else {
|
} else {
|
||||||
UNREACHABLE();
|
UNREACHABLE();
|
||||||
}
|
}
|
||||||
@ -80,13 +83,21 @@ void AuthManager::DbState::parse(ParserT &parser) {
|
|||||||
bool has_terms_of_service = false;
|
bool has_terms_of_service = false;
|
||||||
bool is_pbkdf2_supported = false;
|
bool is_pbkdf2_supported = false;
|
||||||
bool is_srp_supported = false;
|
bool is_srp_supported = false;
|
||||||
|
bool is_wait_registration_supported = false;
|
||||||
if (parser.version() >= static_cast<int32>(Version::AddTermsOfService)) {
|
if (parser.version() >= static_cast<int32>(Version::AddTermsOfService)) {
|
||||||
BEGIN_PARSE_FLAGS();
|
BEGIN_PARSE_FLAGS();
|
||||||
PARSE_FLAG(has_terms_of_service);
|
PARSE_FLAG(has_terms_of_service);
|
||||||
PARSE_FLAG(is_pbkdf2_supported);
|
PARSE_FLAG(is_pbkdf2_supported);
|
||||||
PARSE_FLAG(is_srp_supported);
|
PARSE_FLAG(is_srp_supported);
|
||||||
|
PARSE_FLAG(is_wait_registration_supported);
|
||||||
END_PARSE_FLAGS();
|
END_PARSE_FLAGS();
|
||||||
}
|
}
|
||||||
|
if (!is_wait_registration_supported) {
|
||||||
|
return parser.set_error("Have no wait registration support");
|
||||||
|
}
|
||||||
|
CHECK(is_pbkdf2_supported);
|
||||||
|
CHECK(is_srp_supported);
|
||||||
|
|
||||||
parse(state_, parser);
|
parse(state_, parser);
|
||||||
parse(api_id_, parser);
|
parse(api_id_, parser);
|
||||||
parse(api_hash_, parser);
|
parse(api_hash_, parser);
|
||||||
@ -98,17 +109,9 @@ void AuthManager::DbState::parse(ParserT &parser) {
|
|||||||
|
|
||||||
if (state_ == State::WaitCode) {
|
if (state_ == State::WaitCode) {
|
||||||
parse(send_code_helper_, parser);
|
parse(send_code_helper_, parser);
|
||||||
if (parser.version() < static_cast<int32>(Version::AddTermsOfService)) {
|
|
||||||
return parser.set_error("Have no terms of service");
|
|
||||||
}
|
|
||||||
} else if (state_ == State::WaitPassword) {
|
} else if (state_ == State::WaitPassword) {
|
||||||
if (!is_pbkdf2_supported) {
|
|
||||||
return parser.set_error("Need PBKDF2 support");
|
|
||||||
}
|
|
||||||
if (!is_srp_supported) {
|
|
||||||
return parser.set_error("Need SRP support");
|
|
||||||
}
|
|
||||||
parse(wait_password_state_, parser);
|
parse(wait_password_state_, parser);
|
||||||
|
} else if (state_ == State::WaitRegistration) {
|
||||||
} else {
|
} else {
|
||||||
parser.set_error(PSTRING() << "Unexpected " << tag("state", static_cast<int32>(state_)));
|
parser.set_error(PSTRING() << "Unexpected " << tag("state", static_cast<int32>(state_)));
|
||||||
}
|
}
|
||||||
|
@ -11,17 +11,14 @@
|
|||||||
namespace td {
|
namespace td {
|
||||||
|
|
||||||
void SendCodeHelper::on_sent_code(telegram_api::object_ptr<telegram_api::auth_sentCode> sent_code) {
|
void SendCodeHelper::on_sent_code(telegram_api::object_ptr<telegram_api::auth_sentCode> sent_code) {
|
||||||
phone_registered_ = (sent_code->flags_ & SENT_CODE_FLAG_IS_USER_REGISTERED) != 0;
|
|
||||||
phone_code_hash_ = sent_code->phone_code_hash_;
|
phone_code_hash_ = sent_code->phone_code_hash_;
|
||||||
sent_code_info_ = get_authentication_code_info(std::move(sent_code->type_));
|
sent_code_info_ = get_authentication_code_info(std::move(sent_code->type_));
|
||||||
next_code_info_ = get_authentication_code_info(std::move(sent_code->next_type_));
|
next_code_info_ = get_authentication_code_info(std::move(sent_code->next_type_));
|
||||||
next_code_timestamp_ = Timestamp::in((sent_code->flags_ & SENT_CODE_FLAG_HAS_TIMEOUT) != 0 ? sent_code->timeout_ : 0);
|
next_code_timestamp_ = Timestamp::in((sent_code->flags_ & SENT_CODE_FLAG_HAS_TIMEOUT) != 0 ? sent_code->timeout_ : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
td_api::object_ptr<td_api::authorizationStateWaitCode> SendCodeHelper::get_authorization_state_wait_code(
|
td_api::object_ptr<td_api::authorizationStateWaitCode> SendCodeHelper::get_authorization_state_wait_code() const {
|
||||||
const TermsOfService &terms_of_service) const {
|
return make_tl_object<td_api::authorizationStateWaitCode>(get_authentication_code_info_object());
|
||||||
return make_tl_object<td_api::authorizationStateWaitCode>(
|
|
||||||
phone_registered_, terms_of_service.get_terms_of_service_object(), get_authentication_code_info_object());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
td_api::object_ptr<td_api::authenticationCodeInfo> SendCodeHelper::get_authentication_code_info_object() const {
|
td_api::object_ptr<td_api::authenticationCodeInfo> SendCodeHelper::get_authentication_code_info_object() const {
|
||||||
|
@ -8,7 +8,6 @@
|
|||||||
|
|
||||||
#include "td/telegram/td_api.h"
|
#include "td/telegram/td_api.h"
|
||||||
#include "td/telegram/telegram_api.h"
|
#include "td/telegram/telegram_api.h"
|
||||||
#include "td/telegram/TermsOfService.h"
|
|
||||||
|
|
||||||
#include "td/utils/common.h"
|
#include "td/utils/common.h"
|
||||||
#include "td/utils/Slice.h"
|
#include "td/utils/Slice.h"
|
||||||
@ -20,8 +19,7 @@ namespace td {
|
|||||||
class SendCodeHelper {
|
class SendCodeHelper {
|
||||||
public:
|
public:
|
||||||
void on_sent_code(telegram_api::object_ptr<telegram_api::auth_sentCode> sent_code);
|
void on_sent_code(telegram_api::object_ptr<telegram_api::auth_sentCode> sent_code);
|
||||||
td_api::object_ptr<td_api::authorizationStateWaitCode> get_authorization_state_wait_code(
|
td_api::object_ptr<td_api::authorizationStateWaitCode> get_authorization_state_wait_code() const;
|
||||||
const TermsOfService &terms_of_service) const;
|
|
||||||
td_api::object_ptr<td_api::authenticationCodeInfo> get_authentication_code_info_object() const;
|
td_api::object_ptr<td_api::authenticationCodeInfo> get_authentication_code_info_object() const;
|
||||||
Result<telegram_api::auth_resendCode> resend_code();
|
Result<telegram_api::auth_resendCode> resend_code();
|
||||||
|
|
||||||
@ -45,9 +43,6 @@ class SendCodeHelper {
|
|||||||
Slice phone_code_hash() const {
|
Slice phone_code_hash() const {
|
||||||
return phone_code_hash_;
|
return phone_code_hash_;
|
||||||
}
|
}
|
||||||
bool phone_registered() const {
|
|
||||||
return phone_registered_;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class StorerT>
|
template <class StorerT>
|
||||||
void store(StorerT &storer) const;
|
void store(StorerT &storer) const;
|
||||||
@ -77,7 +72,6 @@ class SendCodeHelper {
|
|||||||
};
|
};
|
||||||
|
|
||||||
string phone_number_;
|
string phone_number_;
|
||||||
bool phone_registered_;
|
|
||||||
string phone_code_hash_;
|
string phone_code_hash_;
|
||||||
|
|
||||||
SendCodeHelper::AuthenticationCodeInfo sent_code_info_;
|
SendCodeHelper::AuthenticationCodeInfo sent_code_info_;
|
||||||
|
@ -32,7 +32,7 @@ template <class StorerT>
|
|||||||
void SendCodeHelper::store(StorerT &storer) const {
|
void SendCodeHelper::store(StorerT &storer) const {
|
||||||
using td::store;
|
using td::store;
|
||||||
store(phone_number_, storer);
|
store(phone_number_, storer);
|
||||||
store(phone_registered_, storer);
|
store(true, storer);
|
||||||
store(phone_code_hash_, storer);
|
store(phone_code_hash_, storer);
|
||||||
store(sent_code_info_, storer);
|
store(sent_code_info_, storer);
|
||||||
store(next_code_info_, storer);
|
store(next_code_info_, storer);
|
||||||
@ -41,9 +41,10 @@ void SendCodeHelper::store(StorerT &storer) const {
|
|||||||
|
|
||||||
template <class ParserT>
|
template <class ParserT>
|
||||||
void SendCodeHelper::parse(ParserT &parser) {
|
void SendCodeHelper::parse(ParserT &parser) {
|
||||||
|
bool legacy_is_registered = false;
|
||||||
using td::parse;
|
using td::parse;
|
||||||
parse(phone_number_, parser);
|
parse(phone_number_, parser);
|
||||||
parse(phone_registered_, parser);
|
parse(legacy_is_registered, parser);
|
||||||
parse(phone_code_hash_, parser);
|
parse(phone_code_hash_, parser);
|
||||||
parse(sent_code_info_, parser);
|
parse(sent_code_info_, parser);
|
||||||
parse(next_code_info_, parser);
|
parse(next_code_info_, parser);
|
||||||
|
@ -3254,6 +3254,7 @@ bool Td::is_authentication_request(int32 id) {
|
|||||||
case td_api::setAuthenticationPhoneNumber::ID:
|
case td_api::setAuthenticationPhoneNumber::ID:
|
||||||
case td_api::resendAuthenticationCode::ID:
|
case td_api::resendAuthenticationCode::ID:
|
||||||
case td_api::checkAuthenticationCode::ID:
|
case td_api::checkAuthenticationCode::ID:
|
||||||
|
case td_api::registerUser::ID:
|
||||||
case td_api::checkAuthenticationPassword::ID:
|
case td_api::checkAuthenticationPassword::ID:
|
||||||
case td_api::requestAuthenticationPasswordRecovery::ID:
|
case td_api::requestAuthenticationPasswordRecovery::ID:
|
||||||
case td_api::recoverAuthenticationPassword::ID:
|
case td_api::recoverAuthenticationPassword::ID:
|
||||||
@ -4741,10 +4742,14 @@ void Td::on_request(uint64 id, const td_api::resendAuthenticationCode &request)
|
|||||||
|
|
||||||
void Td::on_request(uint64 id, td_api::checkAuthenticationCode &request) {
|
void Td::on_request(uint64 id, td_api::checkAuthenticationCode &request) {
|
||||||
CLEAN_INPUT_STRING(request.code_);
|
CLEAN_INPUT_STRING(request.code_);
|
||||||
|
send_closure(auth_manager_actor_, &AuthManager::check_code, id, std::move(request.code_));
|
||||||
|
}
|
||||||
|
|
||||||
|
void Td::on_request(uint64 id, td_api::registerUser &request) {
|
||||||
CLEAN_INPUT_STRING(request.first_name_);
|
CLEAN_INPUT_STRING(request.first_name_);
|
||||||
CLEAN_INPUT_STRING(request.last_name_);
|
CLEAN_INPUT_STRING(request.last_name_);
|
||||||
send_closure(auth_manager_actor_, &AuthManager::check_code, id, std::move(request.code_),
|
send_closure(auth_manager_actor_, &AuthManager::register_user, id, std::move(request.first_name_),
|
||||||
std::move(request.first_name_), std::move(request.last_name_));
|
std::move(request.last_name_));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Td::on_request(uint64 id, td_api::checkAuthenticationPassword &request) {
|
void Td::on_request(uint64 id, td_api::checkAuthenticationPassword &request) {
|
||||||
|
@ -372,6 +372,8 @@ class Td final : public NetQueryCallback {
|
|||||||
|
|
||||||
void on_request(uint64 id, td_api::checkAuthenticationCode &request);
|
void on_request(uint64 id, td_api::checkAuthenticationCode &request);
|
||||||
|
|
||||||
|
void on_request(uint64 id, td_api::registerUser &request);
|
||||||
|
|
||||||
void on_request(uint64 id, td_api::checkAuthenticationPassword &request);
|
void on_request(uint64 id, td_api::checkAuthenticationPassword &request);
|
||||||
|
|
||||||
void on_request(uint64 id, const td_api::requestAuthenticationPasswordRecovery &request);
|
void on_request(uint64 id, const td_api::requestAuthenticationPasswordRecovery &request);
|
||||||
|
@ -1264,14 +1264,14 @@ class CliClient final : public Actor {
|
|||||||
} else if (op == "sdek" || op == "SetDatabaseEncryptionKey") {
|
} else if (op == "sdek" || op == "SetDatabaseEncryptionKey") {
|
||||||
send_request(td_api::make_object<td_api::setDatabaseEncryptionKey>(args));
|
send_request(td_api::make_object<td_api::setDatabaseEncryptionKey>(args));
|
||||||
} else if (op == "cac") {
|
} else if (op == "cac") {
|
||||||
string code;
|
send_request(td_api::make_object<td_api::checkAuthenticationCode>(args));
|
||||||
|
} else if (op == "ru") {
|
||||||
string first_name;
|
string first_name;
|
||||||
string last_name;
|
string last_name;
|
||||||
|
|
||||||
std::tie(code, args) = split(args);
|
|
||||||
std::tie(first_name, last_name) = split(args);
|
std::tie(first_name, last_name) = split(args);
|
||||||
|
|
||||||
send_request(td_api::make_object<td_api::checkAuthenticationCode>(code, first_name, last_name));
|
send_request(td_api::make_object<td_api::registerUser>(first_name, last_name));
|
||||||
} else if (op == "cap") {
|
} else if (op == "cap") {
|
||||||
send_request(td_api::make_object<td_api::checkAuthenticationPassword>(args));
|
send_request(td_api::make_object<td_api::checkAuthenticationPassword>(args));
|
||||||
} else if (op == "cab" || op == "cabt") {
|
} else if (op == "cab" || op == "cabt") {
|
||||||
|
@ -215,7 +215,10 @@ class DoAuthentication : public Task {
|
|||||||
function = make_tl_object<td_api::setAuthenticationPhoneNumber>(phone_, nullptr);
|
function = make_tl_object<td_api::setAuthenticationPhoneNumber>(phone_, nullptr);
|
||||||
break;
|
break;
|
||||||
case td_api::authorizationStateWaitCode::ID:
|
case td_api::authorizationStateWaitCode::ID:
|
||||||
function = make_tl_object<td_api::checkAuthenticationCode>(code_, name_, "");
|
function = make_tl_object<td_api::checkAuthenticationCode>(code_);
|
||||||
|
break;
|
||||||
|
case td_api::authorizationStateWaitRegistration::ID:
|
||||||
|
function = make_tl_object<td_api::registerUser>(name_, "");
|
||||||
break;
|
break;
|
||||||
case td_api::authorizationStateWaitTdlibParameters::ID: {
|
case td_api::authorizationStateWaitTdlibParameters::ID: {
|
||||||
auto parameters = td_api::make_object<td_api::tdlibParameters>();
|
auto parameters = td_api::make_object<td_api::tdlibParameters>();
|
||||||
|
Reference in New Issue
Block a user