diff options
Diffstat (limited to 'remoting/client/plugin/chromoting_scriptable_object.cc')
-rw-r--r-- | remoting/client/plugin/chromoting_scriptable_object.cc | 109 |
1 files changed, 44 insertions, 65 deletions
diff --git a/remoting/client/plugin/chromoting_scriptable_object.cc b/remoting/client/plugin/chromoting_scriptable_object.cc index 89c8793..106141f 100644 --- a/remoting/client/plugin/chromoting_scriptable_object.cc +++ b/remoting/client/plugin/chromoting_scriptable_object.cc @@ -85,8 +85,8 @@ void ChromotingScriptableObject::Init() { AddAttribute(kRoundTripLatencyAttribute, Var()); AddMethod("connect", &ChromotingScriptableObject::DoConnect); - AddMethod("connectUnsandboxed", - &ChromotingScriptableObject::DoConnectUnsandboxed); + AddMethod("connectSandboxed", + &ChromotingScriptableObject::DoConnectSandboxed); AddMethod("disconnect", &ChromotingScriptableObject::DoDisconnect); AddMethod("submitLoginInfo", &ChromotingScriptableObject::DoSubmitLogin); AddMethod("setScaleToFit", &ChromotingScriptableObject::DoSetScaleToFit); @@ -327,100 +327,79 @@ void ChromotingScriptableObject::SendIq(const std::string& message_xml) { cb.Call(Var(), Var(message_xml), &exception); if (!exception.is_undefined()) - LogDebugInfo("Exception when invoking sendiq JS callback."); + LogDebugInfo("Exception when invoking loginChallenge JS callback."); } Var ChromotingScriptableObject::DoConnect(const std::vector<Var>& args, Var* exception) { - // Parameter order is: - // host_jid - // client_jid - // access_code (optional) - unsigned int arg = 0; - if (!args[arg].is_string()) { - *exception = Var("The host_jid must be a string."); + if (args.size() != 4) { + *exception = Var("Usage: connect(username, host_jid, auth_token)"); return Var(); } - std::string host_jid = args[arg++].AsString(); - if (!args[arg].is_string()) { - *exception = Var("The client_jid must be a string."); + ClientConfig config; + + if (!args[0].is_string()) { + *exception = Var("The username must be a string."); return Var(); } - std::string client_jid = args[arg++].AsString(); - - std::string access_code; - if (args.size() > arg) { - if (!args[arg].is_string()) { - *exception = Var("The access code must be a string."); - return Var(); - } - access_code = args[arg++].AsString(); + config.username = args[0].AsString(); + + if (!args[1].is_string()) { + *exception = Var("The host_jid must be a string."); + return Var(); } + config.host_jid = args[1].AsString(); - if (args.size() != arg) { - *exception = Var("Too many agruments passed to connect()."); + if (!args[2].is_string()) { + *exception = Var("The auth_token must be a string."); return Var(); } + config.auth_token = args[2].AsString(); + + if (!args[3].is_string()) { + *exception = Var("nonce must be a string."); + return Var(); + } + config.nonce = args[3].AsString(); LogDebugInfo("Connecting to host."); - VLOG(1) << "client_jid: " << client_jid << ", host_jid: " << host_jid - << ", access_code: " << access_code; - instance_->ConnectSandboxed(client_jid, host_jid, access_code); + instance_->Connect(config); return Var(); } -Var ChromotingScriptableObject::DoConnectUnsandboxed( - const std::vector<Var>& args, - Var* exception) { - // Parameter order is: - // host_jid - // username - // xmpp_token - // access_code (optional) - unsigned int arg = 0; - if (!args[arg].is_string()) { - *exception = Var("The host_jid must be a string."); +Var ChromotingScriptableObject::DoConnectSandboxed( + const std::vector<Var>& args, Var* exception) { + if (args.size() != 3) { + *exception = Var("Usage: connectSandboxed(your_jid, host_jid, nonce)"); return Var(); } - std::string host_jid = args[arg++].AsString(); - if (!args[arg].is_string()) { - *exception = Var("The username must be a string."); + std::string your_jid; + if (!args[0].is_string()) { + *exception = Var("your_jid must be a string."); return Var(); } - std::string username = args[arg++].AsString(); + your_jid = args[0].AsString(); - if (!args[arg].is_string()) { - *exception = Var("The auth_token must be a string."); + std::string host_jid; + if (!args[1].is_string()) { + *exception = Var("host_jid must be a string."); return Var(); } - std::string auth_token = args[arg++].AsString(); - - std::string access_code; - if (args.size() > arg) { - if (!args[arg].is_string()) { - *exception = Var("The access code must be a string."); - return Var(); - } - access_code = args[arg++].AsString(); - } + host_jid = args[1].AsString(); - if (args.size() != arg) { - *exception = Var("Too many agruments passed to connect()."); + std::string nonce; + if (!args[2].is_string()) { + *exception = Var("nonce must be a string."); return Var(); } + nonce = args[2].AsString(); - LogDebugInfo("Connecting to host."); - ClientConfig config; - config.host_jid = host_jid; - config.username = username; - config.auth_token = auth_token; - config.nonce = access_code; - VLOG(1) << "host_jid: " << host_jid << ", username: " << username - << ", access_code: " << access_code; - instance_->Connect(config); + VLOG(1) << "your_jid: " << your_jid << ", host_jid: " << host_jid + << ", nonce: " << nonce; + instance_->ConnectSandboxed(your_jid, host_jid, nonce); return Var(); } |