2018-03-14 21:04:41 +03:00
|
|
|
//
|
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2018
|
|
|
|
//
|
|
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
2018-07-03 22:29:04 +03:00
|
|
|
#pragma once
|
|
|
|
|
2018-03-14 21:04:41 +03:00
|
|
|
#include "td/telegram/AuthManager.h"
|
|
|
|
|
2018-06-08 17:20:42 +03:00
|
|
|
#include "td/telegram/Version.h"
|
|
|
|
|
2018-03-27 16:11:15 +03:00
|
|
|
#include "td/utils/format.h"
|
|
|
|
#include "td/utils/logging.h"
|
2018-03-14 21:04:41 +03:00
|
|
|
#include "td/utils/tl_helpers.h"
|
|
|
|
|
|
|
|
namespace td {
|
2018-06-07 21:42:17 +03:00
|
|
|
|
2018-03-14 21:04:41 +03:00
|
|
|
template <class T>
|
|
|
|
void SendCodeHelper::AuthenticationCodeInfo::store(T &storer) const {
|
|
|
|
using td::store;
|
2018-03-14 22:47:08 +03:00
|
|
|
store(type, storer);
|
2018-03-14 21:04:41 +03:00
|
|
|
store(length, storer);
|
|
|
|
store(pattern, storer);
|
|
|
|
}
|
2018-06-07 21:42:17 +03:00
|
|
|
|
2018-03-14 21:04:41 +03:00
|
|
|
template <class T>
|
|
|
|
void SendCodeHelper::AuthenticationCodeInfo::parse(T &parser) {
|
|
|
|
using td::parse;
|
2018-03-14 22:47:08 +03:00
|
|
|
parse(type, parser);
|
2018-03-14 21:04:41 +03:00
|
|
|
parse(length, parser);
|
|
|
|
parse(pattern, parser);
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
void SendCodeHelper::store(T &storer) const {
|
|
|
|
using td::store;
|
|
|
|
store(phone_number_, storer);
|
|
|
|
store(phone_registered_, storer);
|
|
|
|
store(phone_code_hash_, storer);
|
|
|
|
store(sent_code_info_, storer);
|
|
|
|
store(next_code_info_, storer);
|
|
|
|
store(next_code_timestamp_, storer);
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
void SendCodeHelper::parse(T &parser) {
|
|
|
|
using td::parse;
|
|
|
|
parse(phone_number_, parser);
|
|
|
|
parse(phone_registered_, parser);
|
|
|
|
parse(phone_code_hash_, parser);
|
|
|
|
parse(sent_code_info_, parser);
|
|
|
|
parse(next_code_info_, parser);
|
|
|
|
parse(next_code_timestamp_, parser);
|
|
|
|
}
|
2018-06-07 21:42:17 +03:00
|
|
|
|
2018-03-15 13:06:26 +03:00
|
|
|
template <class T>
|
|
|
|
void AuthManager::WaitPasswordState::store(T &storer) const {
|
|
|
|
using td::store;
|
2018-08-04 09:55:49 +03:00
|
|
|
store(current_client_salt_, storer);
|
|
|
|
store(current_server_salt_, storer);
|
2018-08-10 16:22:48 +03:00
|
|
|
store(srp_g_, storer);
|
|
|
|
store(srp_p_, storer);
|
|
|
|
store(srp_B_, storer);
|
|
|
|
store(srp_id_, storer);
|
2018-03-15 13:06:26 +03:00
|
|
|
store(hint_, storer);
|
|
|
|
store(has_recovery_, storer);
|
|
|
|
store(email_address_pattern_, storer);
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
void AuthManager::WaitPasswordState::parse(T &parser) {
|
|
|
|
using td::parse;
|
2018-08-04 09:55:49 +03:00
|
|
|
parse(current_client_salt_, parser);
|
|
|
|
parse(current_server_salt_, parser);
|
2018-08-10 16:22:48 +03:00
|
|
|
parse(srp_g_, parser);
|
|
|
|
parse(srp_p_, parser);
|
|
|
|
parse(srp_B_, parser);
|
|
|
|
parse(srp_id_, parser);
|
2018-03-15 13:06:26 +03:00
|
|
|
parse(hint_, parser);
|
|
|
|
parse(has_recovery_, parser);
|
|
|
|
parse(email_address_pattern_, parser);
|
|
|
|
}
|
2018-03-14 21:04:41 +03:00
|
|
|
|
|
|
|
template <class T>
|
|
|
|
void AuthManager::DbState::store(T &storer) const {
|
|
|
|
using td::store;
|
2018-06-07 21:42:17 +03:00
|
|
|
bool has_terms_of_service = !terms_of_service_.get_id().empty();
|
2018-08-04 09:55:49 +03:00
|
|
|
bool is_pbkdf2_supported = true;
|
2018-08-10 16:22:48 +03:00
|
|
|
bool is_srp_supported = true;
|
2018-06-07 21:42:17 +03:00
|
|
|
BEGIN_STORE_FLAGS();
|
|
|
|
STORE_FLAG(has_terms_of_service);
|
2018-08-04 09:55:49 +03:00
|
|
|
STORE_FLAG(is_pbkdf2_supported);
|
2018-08-10 16:22:48 +03:00
|
|
|
STORE_FLAG(is_srp_supported);
|
2018-06-07 21:42:17 +03:00
|
|
|
END_STORE_FLAGS();
|
2018-03-14 22:47:08 +03:00
|
|
|
store(state_, storer);
|
2018-03-14 21:04:41 +03:00
|
|
|
store(api_id_, storer);
|
|
|
|
store(api_hash_, storer);
|
|
|
|
store(state_timestamp_, storer);
|
2018-03-15 13:06:26 +03:00
|
|
|
|
2018-06-07 21:42:17 +03:00
|
|
|
if (has_terms_of_service) {
|
|
|
|
store(terms_of_service_, storer);
|
|
|
|
}
|
|
|
|
|
2018-03-15 13:06:26 +03:00
|
|
|
if (state_ == State::WaitCode) {
|
|
|
|
store(send_code_helper_, storer);
|
|
|
|
} else if (state_ == State::WaitPassword) {
|
|
|
|
store(wait_password_state_, storer);
|
|
|
|
} else {
|
|
|
|
UNREACHABLE();
|
|
|
|
}
|
2018-03-14 21:04:41 +03:00
|
|
|
}
|
2018-06-07 21:42:17 +03:00
|
|
|
|
2018-03-14 21:04:41 +03:00
|
|
|
template <class T>
|
|
|
|
void AuthManager::DbState::parse(T &parser) {
|
|
|
|
using td::parse;
|
2018-06-07 21:42:17 +03:00
|
|
|
bool has_terms_of_service = false;
|
2018-08-04 09:55:49 +03:00
|
|
|
bool is_pbkdf2_supported = false;
|
2018-08-10 16:22:48 +03:00
|
|
|
bool is_srp_supported = false;
|
2018-06-07 21:42:17 +03:00
|
|
|
if (parser.version() >= static_cast<int32>(Version::AddTermsOfService)) {
|
|
|
|
BEGIN_PARSE_FLAGS();
|
|
|
|
PARSE_FLAG(has_terms_of_service);
|
2018-08-04 09:55:49 +03:00
|
|
|
PARSE_FLAG(is_pbkdf2_supported);
|
2018-08-10 16:22:48 +03:00
|
|
|
PARSE_FLAG(is_srp_supported);
|
2018-06-07 21:42:17 +03:00
|
|
|
END_PARSE_FLAGS();
|
|
|
|
}
|
2018-03-14 22:47:08 +03:00
|
|
|
parse(state_, parser);
|
2018-03-14 21:04:41 +03:00
|
|
|
parse(api_id_, parser);
|
|
|
|
parse(api_hash_, parser);
|
|
|
|
parse(state_timestamp_, parser);
|
2018-03-15 13:06:26 +03:00
|
|
|
|
2018-06-07 21:42:17 +03:00
|
|
|
if (has_terms_of_service) {
|
|
|
|
parse(terms_of_service_, parser);
|
|
|
|
}
|
|
|
|
|
2018-03-15 13:06:26 +03:00
|
|
|
if (state_ == State::WaitCode) {
|
|
|
|
parse(send_code_helper_, parser);
|
2018-06-07 21:42:17 +03:00
|
|
|
if (parser.version() < static_cast<int32>(Version::AddTermsOfService)) {
|
2018-08-04 09:55:49 +03:00
|
|
|
return parser.set_error("Have no terms of service");
|
2018-06-07 21:42:17 +03:00
|
|
|
}
|
2018-03-15 13:06:26 +03:00
|
|
|
} else if (state_ == State::WaitPassword) {
|
2018-08-04 09:55:49 +03:00
|
|
|
if (!is_pbkdf2_supported) {
|
|
|
|
return parser.set_error("Need PBKDF2 support");
|
|
|
|
}
|
2018-08-10 16:22:48 +03:00
|
|
|
if (!is_srp_supported) {
|
|
|
|
return parser.set_error("Need SRP support");
|
|
|
|
}
|
2018-03-15 13:06:26 +03:00
|
|
|
parse(wait_password_state_, parser);
|
|
|
|
} else {
|
|
|
|
parser.set_error(PSTRING() << "Unexpected " << tag("state", static_cast<int32>(state_)));
|
|
|
|
}
|
2018-03-14 21:04:41 +03:00
|
|
|
}
|
2018-06-07 21:42:17 +03:00
|
|
|
|
2018-03-14 21:04:41 +03:00
|
|
|
} // namespace td
|