Attempt to fix binlog_pmc_ bug in ConfigSession::HandshakeActor
GitOrigin-RevId: 6486e37b16a39c4088faa5a2aedc674e6feb2e89
This commit is contained in:
parent
f4bea9a891
commit
a569a1eac7
@ -1120,21 +1120,22 @@ void Session::create_gen_auth_key_actor(HandshakeId handshake_id) {
|
|||||||
info.actor_ = create_actor<detail::GenAuthKeyActor>(
|
info.actor_ = create_actor<detail::GenAuthKeyActor>(
|
||||||
PSLICE() << get_name() << "::GenAuthKey", get_name(), std::move(info.handshake_),
|
PSLICE() << get_name() << "::GenAuthKey", get_name(), std::move(info.handshake_),
|
||||||
td::make_unique<AuthKeyHandshakeContext>(DhCache::instance(), shared_auth_data_->public_rsa_key()),
|
td::make_unique<AuthKeyHandshakeContext>(DhCache::instance(), shared_auth_data_->public_rsa_key()),
|
||||||
PromiseCreator::lambda([self = actor_id(this)](Result<unique_ptr<mtproto::RawConnection>> r_connection) {
|
|
||||||
if (r_connection.is_error()) {
|
|
||||||
if (r_connection.error().code() != 1) {
|
|
||||||
LOG(WARNING) << "Failed to open connection: " << r_connection.error();
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
send_closure(self, &Session::connection_add, r_connection.move_as_ok());
|
|
||||||
}),
|
|
||||||
PromiseCreator::lambda(
|
PromiseCreator::lambda(
|
||||||
[self = actor_shared(this, handshake_id + 1), handshake_perf = PerfWarningTimer("handshake", 1000.1)](
|
[self = actor_id(this), guard = callback_](Result<unique_ptr<mtproto::RawConnection>> r_connection) {
|
||||||
Result<unique_ptr<mtproto::AuthKeyHandshake>> handshake) mutable {
|
if (r_connection.is_error()) {
|
||||||
// later is just to avoid lost hangup
|
if (r_connection.error().code() != 1) {
|
||||||
send_closure_later(std::move(self), &Session::on_handshake_ready, std::move(handshake));
|
LOG(WARNING) << "Failed to open connection: " << r_connection.error();
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
send_closure(self, &Session::connection_add, r_connection.move_as_ok());
|
||||||
}),
|
}),
|
||||||
|
PromiseCreator::lambda([self = actor_shared(this, handshake_id + 1),
|
||||||
|
handshake_perf = PerfWarningTimer("handshake", 1000.1),
|
||||||
|
guard = callback_](Result<unique_ptr<mtproto::AuthKeyHandshake>> handshake) mutable {
|
||||||
|
// later is just to avoid lost hangup
|
||||||
|
send_closure_later(std::move(self), &Session::on_handshake_ready, std::move(handshake));
|
||||||
|
}),
|
||||||
callback_);
|
callback_);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user