1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
|
// Copyright 2013 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "remoting/protocol/pairing_client_authenticator.h"
#include "base/check.h"
#include "base/functional/bind.h"
#include "remoting/base/constants.h"
#include "remoting/protocol/auth_util.h"
#include "remoting/protocol/channel_authenticator.h"
#include "third_party/libjingle_xmpp/xmllite/xmlelement.h"
namespace remoting::protocol {
PairingClientAuthenticator::PairingClientAuthenticator(
const ClientAuthenticationConfig& client_auth_config,
const CreateBaseAuthenticatorCallback& create_base_authenticator_callback)
: client_auth_config_(client_auth_config),
create_base_authenticator_callback_(create_base_authenticator_callback) {}
PairingClientAuthenticator::~PairingClientAuthenticator() = default;
void PairingClientAuthenticator::Start(State initial_state,
base::OnceClosure resume_callback) {
if (client_auth_config_.pairing_client_id.empty() ||
client_auth_config_.pairing_secret.empty()) {
// Send pairing error to make it clear that PIN is being used instead of
// pairing secret.
error_message_ = "not-paired";
using_paired_secret_ = false;
CreateSpakeAuthenticatorWithPin(initial_state, std::move(resume_callback));
} else {
StartPaired(initial_state);
std::move(resume_callback).Run();
}
}
void PairingClientAuthenticator::StartPaired(State initial_state) {
DCHECK(!client_auth_config_.pairing_client_id.empty());
DCHECK(!client_auth_config_.pairing_secret.empty());
using_paired_secret_ = true;
spake2_authenticator_ = create_base_authenticator_callback_.Run(
client_auth_config_.pairing_secret, initial_state);
}
Authenticator::State PairingClientAuthenticator::state() const {
if (waiting_for_pin_) {
return PROCESSING_MESSAGE;
}
return PairingAuthenticatorBase::state();
}
void PairingClientAuthenticator::CreateSpakeAuthenticatorWithPin(
State initial_state,
base::OnceClosure resume_callback) {
DCHECK(!waiting_for_pin_);
waiting_for_pin_ = true;
client_auth_config_.fetch_secret_callback.Run(
true, base::BindRepeating(&PairingClientAuthenticator::OnPinFetched,
weak_factory_.GetWeakPtr(), initial_state,
base::Passed(std::move(resume_callback))));
}
void PairingClientAuthenticator::OnPinFetched(State initial_state,
base::OnceClosure resume_callback,
const std::string& pin) {
DCHECK(waiting_for_pin_);
DCHECK(!spake2_authenticator_);
waiting_for_pin_ = false;
spake2_authenticator_ = create_base_authenticator_callback_.Run(
GetSharedSecretHash(client_auth_config_.host_id, pin), initial_state);
std::move(resume_callback).Run();
}
} // namespace remoting::protocol
|