// Copyright (c) 2011 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 "chrome/browser/automation/automation_provider_json.h" #include "base/json/json_writer.h" #include "base/json/string_escape.h" #include "base/values.h" #include "chrome/browser/autocomplete/autocomplete_match.h" #include "chrome/browser/automation/automation_provider.h" #include "chrome/browser/automation/automation_util.h" #include "chrome/common/automation_messages.h" namespace { // Util for creating a JSON error return string (dict with key // 'error' and error string value). No need to quote input. std::string JSONErrorString(const std::string& err) { std::string prefix = "{\"error\": \""; std::string no_quote_err; std::string suffix = "\"}"; base::JsonDoubleQuote(err, false, &no_quote_err); return prefix + no_quote_err + suffix; } } // namespace AutomationJSONReply::AutomationJSONReply(AutomationProvider* provider, IPC::Message* reply_message) : provider_(provider), message_(reply_message) { } AutomationJSONReply::~AutomationJSONReply() { DCHECK(!message_) << "JSON automation request not replied!"; } void AutomationJSONReply::SendSuccess(const Value* value) { DCHECK(message_) << "Resending reply for JSON automation request"; std::string json_string = "{}"; if (value) base::JSONWriter::Write(value, false, &json_string); AutomationMsg_SendJSONRequest::WriteReplyParams( message_, json_string, true); provider_->Send(message_); message_ = NULL; } void AutomationJSONReply::SendError(const std::string& error_message) { DCHECK(message_) << "Resending reply for JSON automation request"; std::string json_string = JSONErrorString(error_message); AutomationMsg_SendJSONRequest::WriteReplyParams( message_, json_string, false); provider_->Send(message_); message_ = NULL; } bool GetBrowserFromJSONArgs( DictionaryValue* args, Browser** browser, std::string* error) { int browser_index; if (!args->GetInteger("windex", &browser_index)) { *error = "'windex' missing or invalid"; return false; } *browser = automation_util::GetBrowserAt(browser_index); if (!*browser) { *error = "Cannot locate browser from given index"; return false; } return true; } bool GetTabFromJSONArgs( DictionaryValue* args, TabContents** tab, std::string* error) { int browser_index, tab_index; if (!args->GetInteger("windex", &browser_index)) { *error = "'windex' missing or invalid"; return false; } if (!args->GetInteger("tab_index", &tab_index)) { *error = "'tab_index' missing or invalid"; return false; } *tab = automation_util::GetTabContentsAt(browser_index, tab_index); if (!*tab) { *error = "Cannot locate tab from given indices"; return false; } return true; } bool GetBrowserAndTabFromJSONArgs( DictionaryValue* args, Browser** browser, TabContents** tab, std::string* error) { return GetBrowserFromJSONArgs(args, browser, error) && GetTabFromJSONArgs(args, tab, error); }