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

Unified Diff: remoting/client/plugin/chromoting_instance.cc

Issue 12518027: Protocol / client plugin changes to support interactively asking for a PIN (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Created 7 years, 9 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/client/plugin/chromoting_instance.cc
diff --git a/remoting/client/plugin/chromoting_instance.cc b/remoting/client/plugin/chromoting_instance.cc
index 92476103c15fed2b5052592e854cc5c9822c2a37..004317e77390cdbaf8d2af3e3d29ed4d20d3d978 100644
--- a/remoting/client/plugin/chromoting_instance.cc
+++ b/remoting/client/plugin/chromoting_instance.cc
@@ -34,6 +34,7 @@
#include "remoting/client/frame_consumer_proxy.h"
#include "remoting/client/plugin/pepper_audio_player.h"
#include "remoting/client/plugin/pepper_input_handler.h"
+#include "remoting/client/plugin/pepper_pin_fetcher.h"
#include "remoting/client/plugin/pepper_port_allocator.h"
#include "remoting/client/plugin/pepper_view.h"
#include "remoting/client/plugin/pepper_xmpp_proxy.h"
@@ -134,7 +135,8 @@ logging::LogMessageHandlerFunction g_logging_old_handler = NULL;
// String sent in the "hello" message to the plugin to describe features.
const char ChromotingInstance::kApiFeatures[] =
"highQualityScaling injectKeyEvent sendClipboardItem remapKey trapKey "
- "notifyClientDimensions notifyClientResolution pauseVideo pauseAudio";
+ "notifyClientDimensions notifyClientResolution pauseVideo pauseAudio "
+ "onPinFetched useAsyncPinDialog";
Sergey Ulanov 2013/03/17 21:29:21 Don't need two separate features
rmsousa 2013/03/18 21:07:26 Done.
bool ChromotingInstance::ParseAuthMethods(const std::string& auth_methods_str,
ClientConfig* config) {
@@ -171,6 +173,7 @@ ChromotingInstance::ChromotingInstance(PP_Instance pp_instance)
key_mapper_(&input_tracker_),
#endif
input_handler_(&key_mapper_),
+ use_async_pin_dialog_(false),
weak_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)) {
RequestInputEvents(PP_INPUTEVENT_CLASS_MOUSE | PP_INPUTEVENT_CLASS_WHEEL);
RequestFilteringInputEvents(PP_INPUTEVENT_CLASS_KEYBOARD);
@@ -277,7 +280,6 @@ void ChromotingInstance::HandleMessage(const pp::Var& message) {
LOG(ERROR) << "Invalid connect() data.";
return;
}
-
Connect(config);
} else if (method == "disconnect") {
Disconnect();
@@ -373,6 +375,15 @@ void ChromotingInstance::HandleMessage(const pp::Var& message) {
return;
}
PauseAudio(pause);
+ } else if (method == "useAsyncPinDialog") {
+ use_async_pin_dialog_ = true;
+ } else if (method == "onPinFetched") {
+ std::string pin;
+ if (!data->GetString("pin", &pin)) {
+ LOG(ERROR) << "Invalid onPinFetched.";
+ return;
+ }
+ OnPinFetched(pin);
}
}
@@ -424,6 +435,20 @@ void ChromotingInstance::OnConnectionReady(bool ready) {
PostChromotingMessage("onConnectionReady", data.Pass());
}
+scoped_ptr<protocol::PinFetcher> ChromotingInstance::CreatePinFetcher() {
+ return scoped_ptr<protocol::PinFetcher>(new PepperPinFetcher(AsWeakPtr()));
+}
+
+void ChromotingInstance::FetchPin(base::WeakPtr<PepperPinFetcher> pin_fetcher) {
+ // Once the Session object calls this function, it won't continue the
+ // authentication until the callback is called (or connection is canceled).
+ // So, it's impossible to reach this with a pin fetcher already registered.
+ DCHECK(!pin_fetcher_);
+ pin_fetcher_ = pin_fetcher;
+ scoped_ptr<base::DictionaryValue> data(new base::DictionaryValue());
+ PostChromotingMessage("fetchPin", data.Pass());
+}
+
protocol::ClipboardStub* ChromotingInstance::GetClipboardStub() {
// TODO(sergeyu): Move clipboard handling to a separate class.
// crbug.com/138108
@@ -436,6 +461,15 @@ protocol::CursorShapeStub* ChromotingInstance::GetCursorShapeStub() {
return this;
}
+protocol::PinFetcherFactory* ChromotingInstance::GetPinFetcherFactory() {
+ // TODO(rmsousa): Move pin fetcher code to a separate class.
Sergey Ulanov 2013/03/17 21:29:21 Isn't it already in a separate class?
rmsousa 2013/03/18 21:07:26 Done.
+ if (use_async_pin_dialog_) {
+ return this;
+ } else {
+ return NULL;
+ }
+}
+
void ChromotingInstance::InjectClipboardEvent(
const protocol::ClipboardEvent& event) {
scoped_ptr<base::DictionaryValue> data(new base::DictionaryValue());
@@ -650,6 +684,16 @@ void ChromotingInstance::PauseAudio(bool pause) {
host_connection_->host_stub()->ControlAudio(audio_control);
}
+void ChromotingInstance::OnPinFetched(const std::string& shared_secret) {
+ if (pin_fetcher_) {
+ pin_fetcher_->OnPinFetched(shared_secret);
+ pin_fetcher_.reset();
+ } else {
+ VLOG(1) <<
+ "Ignored OnPinFetched received without a pending fetch.";
+ }
+}
+
ChromotingStats* ChromotingInstance::GetStats() {
if (!client_.get())
return NULL;

Powered by Google App Engine
This is Rietveld 408576698