Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(511)

Unified Diff: remoting/protocol/validating_authenticator.cc

Issue 2277553002: Adding a new authenticator which can be used to validate the remote user (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@policy_change
Patch Set: fixing a ChromeOS build break Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: remoting/protocol/validating_authenticator.cc
diff --git a/remoting/protocol/validating_authenticator.cc b/remoting/protocol/validating_authenticator.cc
new file mode 100644
index 0000000000000000000000000000000000000000..5d5a1a2b1c8a81191a9ec03dac38eaeea379fac3
--- /dev/null
+++ b/remoting/protocol/validating_authenticator.cc
@@ -0,0 +1,157 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "remoting/protocol/validating_authenticator.h"
+
+#include <memory>
+#include <string>
+#include <utility>
+
+#include "base/bind.h"
+#include "base/callback.h"
+#include "base/logging.h"
+#include "base/macros.h"
+#include "base/memory/ref_counted.h"
+#include "base/memory/weak_ptr.h"
+#include "remoting/protocol/authenticator.h"
+#include "remoting/protocol/channel_authenticator.h"
+#include "third_party/webrtc/libjingle/xmllite/xmlelement.h"
+
+namespace remoting {
+namespace protocol {
+
+ValidatingAuthenticator::ValidatingAuthenticator(
+ const std::string& remote_jid,
+ const ValidationCallback& validation_callback,
+ std::unique_ptr<Authenticator> current_authenticator)
+ : remote_jid_(remote_jid),
+ validation_callback_(validation_callback),
+ current_authenticator_(std::move(current_authenticator)),
+ weak_factory_(this) {
+ DCHECK(!remote_jid_.empty());
+ DCHECK(!validation_callback_.is_null());
+ DCHECK(current_authenticator_);
+}
+
+ValidatingAuthenticator::~ValidatingAuthenticator() {}
+
+Authenticator::State ValidatingAuthenticator::state() const {
Jamie 2016/08/26 23:12:08 It seems we should be falling back on the underlyi
joedow 2016/08/29 23:43:22 I started off using a branching structure like thi
Jamie 2016/08/31 00:28:34 I'll make a couple of points in favour of my appro
joedow 2016/08/31 17:42:29 Discussed offline, I have tried this approach firs
+ return state_;
+}
+
+bool ValidatingAuthenticator::started() const {
+ return current_authenticator_->started();
+}
+
+Authenticator::RejectionReason ValidatingAuthenticator::rejection_reason()
+ const {
+ return rejection_reason_;
Jamie 2016/08/26 23:12:07 Similarly here, the underlying authenticator shoul
joedow 2016/08/29 23:43:22 Same as above, I think it is cleaner to just use |
+}
+
+const std::string& ValidatingAuthenticator::GetAuthKey() const {
+ DCHECK_EQ(state_, ACCEPTED);
Jamie 2016/08/26 23:12:08 I don't think you need this check; state() should
joedow 2016/08/29 23:43:22 I'm fine removing this as you are correct that the
+ return current_authenticator_->GetAuthKey();
+}
+
+std::unique_ptr<ChannelAuthenticator>
+ValidatingAuthenticator::CreateChannelAuthenticator() const {
+ DCHECK_EQ(state_, ACCEPTED);
+ return current_authenticator_->CreateChannelAuthenticator();
+}
+
+void ValidatingAuthenticator::ProcessMessage(
+ const buzz::XmlElement* message,
+ const base::Closure& resume_callback) {
+ DCHECK_EQ(state_, WAITING_MESSAGE);
+ state_ = PROCESSING_MESSAGE;
+
+ if (first_message_received_) {
+ current_authenticator_->ProcessMessage(
+ message, base::Bind(&ValidatingAuthenticator::UpdateState,
+ weak_factory_.GetWeakPtr(), resume_callback));
+ } else {
+ first_message_received_ = true;
+ validation_callback_.Run(
+ remote_jid_, base::Bind(&ValidatingAuthenticator::OnValidateComplete,
+ weak_factory_.GetWeakPtr(),
+ base::Owned(new buzz::XmlElement(*message)),
+ resume_callback));
+ }
+}
+
+std::unique_ptr<buzz::XmlElement> ValidatingAuthenticator::GetNextMessage() {
+ DCHECK_EQ(state_, MESSAGE_READY);
+
+ std::unique_ptr<buzz::XmlElement> result;
+ if (current_authenticator_->state() == MESSAGE_READY) {
+ result = current_authenticator_->GetNextMessage();
+ } else {
+ result = CreateEmptyAuthenticatorMessage();
Jamie 2016/08/26 23:12:07 I don't think this code should be reachable; if th
joedow 2016/08/29 23:43:22 I think that's a reasonable assumption, I'll leave
+ }
+
+ state_ = current_authenticator_->state();
+ DCHECK(state_ == ACCEPTED || state_ == WAITING_MESSAGE);
+
+ return result;
+}
+
+void ValidatingAuthenticator::OnValidateComplete(
+ const buzz::XmlElement* message,
+ const base::Closure& resume_callback,
+ Result validation_result) {
+ if (validation_result == Result::SUCCESS) {
+ current_authenticator_->ProcessMessage(
+ message, base::Bind(&ValidatingAuthenticator::UpdateState,
+ weak_factory_.GetWeakPtr(), resume_callback));
+ return;
+ }
+
+ // |validation_result| represents a rejected state so map the result to a
+ // rejection reason and call the callback to let the caller know the result.
+ state_ = Authenticator::REJECTED;
+
+ switch (validation_result) {
+ case Result::ERROR_INVALID_CREDENTIALS:
+ rejection_reason_ = Authenticator::INVALID_CREDENTIALS;
+ break;
+
+ case Result::ERROR_INVALID_ACCOUNT:
+ rejection_reason_ = Authenticator::INVALID_ACCOUNT;
+ break;
+
+ case Result::ERROR_REJECTED_BY_USER:
+ rejection_reason_ = Authenticator::REJECTED_BY_USER;
+ break;
+
+ default:
+ // Log an error and use the default value for |rejection_result_|.
Jamie 2016/08/26 23:12:08 By defaulting to INVALID_CREDENTIALS here, aren't
joedow 2016/08/29 23:43:22 What should happen is that the person adding the n
Jamie 2016/08/31 00:28:34 Better still, if you fold the SUCCESS case into th
joedow 2016/08/31 17:42:29 Fixed the comment. It looks like the compiler doe
+ NOTREACHED() << "Unknown validation result value: "
+ << static_cast<unsigned int>(validation_result);
+ }
+
+ resume_callback.Run();
+}
+
+void ValidatingAuthenticator::UpdateState(
+ const base::Closure& resume_callback) {
+ DCHECK_EQ(state_, PROCESSING_MESSAGE);
+
+ // After the underlying authenticator finishes processing the message,
+ // ValidatingAuthenticator must update its own state before running
+ // |resume_callback|.
+ state_ = current_authenticator_->state();
+
+ // Verify the new state represents a valid state transition.
+ DCHECK(state_ == MESSAGE_READY || state_ == ACCEPTED || state_ == REJECTED)
+ << "State: " << state_;
+
+ if (state_ == REJECTED) {
+ rejection_reason_ = current_authenticator_->rejection_reason();
+ }
+
+ resume_callback.Run();
+}
+
+} // namespace protocol
+} // namespace remoting

Powered by Google App Engine
This is Rietveld 408576698