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

Unified Diff: chrome/browser/automation/automation_util.cc

Issue 6705004: Return the full cookie details in TestingAutomationProvider and pass around (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: ... Created 9 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: chrome/browser/automation/automation_util.cc
diff --git a/chrome/browser/automation/automation_util.cc b/chrome/browser/automation/automation_util.cc
index 10f5da4fba19a12e659c13fdd873ff1f5981757a..44560202610405169409ebaa24ff2c3ffbd37ef5 100644
--- a/chrome/browser/automation/automation_util.cc
+++ b/chrome/browser/automation/automation_util.cc
@@ -6,6 +6,8 @@
#include <string>
+#include "base/scoped_ptr.h"
+#include "base/time.h"
#include "base/values.h"
#include "chrome/browser/automation/automation_provider_json.h"
#include "chrome/browser/profiles/profile.h"
@@ -14,6 +16,7 @@
#include "chrome/browser/ui/browser.h"
#include "content/browser/browser_thread.h"
#include "content/browser/renderer_host/render_view_host.h"
+#include "net/base/cookie_monster.h"
#include "net/base/cookie_store.h"
#include "net/url_request/url_request_context.h"
@@ -28,6 +31,16 @@ void GetCookiesOnIOThread(
event->Signal();
}
+void GetCanonicalCookiesOnIOThread(
+ const GURL& url,
+ const scoped_refptr<URLRequestContextGetter>& context_getter,
+ base::WaitableEvent* event,
+ net::CookieList* cookie_list) {
+ *cookie_list = context_getter->GetCookieStore()->GetCookieMonster()->
+ GetAllCookiesForURL(url);
+ event->Signal();
+}
+
void SetCookieOnIOThread(
const GURL& url,
const std::string& value,
@@ -38,6 +51,22 @@ void SetCookieOnIOThread(
event->Signal();
}
+void SetCookieWithDetailsOnIOThread(
+ const GURL& url,
+ const net::CookieMonster::CanonicalCookie& cookie,
+ const std::string& original_domain,
+ const scoped_refptr<URLRequestContextGetter>& context_getter,
+ base::WaitableEvent* event,
+ bool* success) {
+ net::CookieMonster* cookie_monster = context_getter->GetCookieStore()->
+ GetCookieMonster();
+ *success = cookie_monster->SetCookieWithDetails(
+ url, cookie.Name(), cookie.Value(), original_domain,
+ cookie.Path(), cookie.ExpiryDate(), cookie.IsSecure(),
+ cookie.IsHttpOnly());
+ event->Signal();
+}
+
void DeleteCookieOnIOThread(
const GURL& url,
const std::string& name,
@@ -132,12 +161,6 @@ void GetCookiesJSON(AutomationProvider* provider,
DictionaryValue* args,
IPC::Message* reply_message) {
AutomationJSONReply reply(provider, reply_message);
- Browser* browser;
- std::string error;
- if (!GetBrowserFromJSONArgs(args, &browser, &error)) {
- reply.SendError(error);
- return;
- }
std::string url;
if (!args->GetString("url", &url)) {
reply.SendError("'url' missing or invalid");
@@ -146,22 +169,36 @@ void GetCookiesJSON(AutomationProvider* provider,
// Since we may be on the UI thread don't call GetURLRequestContext().
scoped_refptr<URLRequestContextGetter> context_getter =
- browser->profile()->GetRequestContext();
+ provider->profile()->GetRequestContext();
- std::string cookies;
+ net::CookieList cookie_list;
base::WaitableEvent event(true /* manual reset */,
false /* not initially signaled */);
Task* task = NewRunnableFunction(
- &GetCookiesOnIOThread,
- GURL(url), context_getter, &event, &cookies);
+ &GetCanonicalCookiesOnIOThread,
+ GURL(url), context_getter, &event, &cookie_list);
if (!BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, task)) {
reply.SendError("Couldn't post task to get the cookies");
return;
}
event.Wait();
+ ListValue* list = new ListValue();
+ for (size_t i = 0; i < cookie_list.size(); ++i) {
+ const net::CookieMonster::CanonicalCookie& cookie = cookie_list[i];
+ DictionaryValue* cookie_dict = new DictionaryValue();
+ cookie_dict->SetString("name", cookie.Name());
+ cookie_dict->SetString("value", cookie.Value());
+ cookie_dict->SetString("path", cookie.Path());
+ cookie_dict->SetString("domain", cookie.Domain());
+ cookie_dict->SetBoolean("secure", cookie.IsSecure());
+ cookie_dict->SetBoolean("http_only", cookie.IsHttpOnly());
+ if (cookie.DoesExpire())
+ cookie_dict->SetDouble("expiry", cookie.ExpiryDate().ToDoubleT());
+ list->Append(cookie_dict);
+ }
DictionaryValue dict;
- dict.SetString("cookies", cookies);
+ dict.Set("cookies", list);
reply.SendSuccess(&dict);
}
@@ -169,12 +206,6 @@ void DeleteCookieJSON(AutomationProvider* provider,
DictionaryValue* args,
IPC::Message* reply_message) {
AutomationJSONReply reply(provider, reply_message);
- Browser* browser;
- std::string error;
- if (!GetBrowserFromJSONArgs(args, &browser, &error)) {
- reply.SendError(error);
- return;
- }
std::string url, name;
if (!args->GetString("url", &url)) {
reply.SendError("'url' missing or invalid");
@@ -187,7 +218,7 @@ void DeleteCookieJSON(AutomationProvider* provider,
// Since we may be on the UI thread don't call GetURLRequestContext().
scoped_refptr<URLRequestContextGetter> context_getter =
- browser->profile()->GetRequestContext();
+ provider->profile()->GetRequestContext();
base::WaitableEvent event(true /* manual reset */,
false /* not initially signaled */);
@@ -206,32 +237,79 @@ void SetCookieJSON(AutomationProvider* provider,
DictionaryValue* args,
IPC::Message* reply_message) {
AutomationJSONReply reply(provider, reply_message);
- Browser* browser;
- std::string error;
- if (!GetBrowserFromJSONArgs(args, &browser, &error)) {
- reply.SendError(error);
- return;
- }
- std::string url, cookie;
+ std::string url;
if (!args->GetString("url", &url)) {
reply.SendError("'url' missing or invalid");
return;
}
- if (!args->GetString("cookie", &cookie)) {
+ DictionaryValue* cookie_dict;
+ if (!args->GetDictionary("cookie", &cookie_dict)) {
reply.SendError("'cookie' missing or invalid");
return;
}
+ std::string name, value;
+ std::string domain;
+ std::string path = "/";
+ bool secure = false;
+ double expiry = 0;
+ bool http_only = false;
+ if (!cookie_dict->GetString("name", &name)) {
+ reply.SendError("'name' missing or invalid");
+ return;
+ }
+ if (!cookie_dict->GetString("value", &value)) {
+ reply.SendError("'value' missing or invalid");
+ return;
+ }
+ if (cookie_dict->HasKey("domain") &&
+ !cookie_dict->GetString("domain", &domain)) {
+ reply.SendError("optional 'domain' invalid");
+ return;
+ }
+ if (cookie_dict->HasKey("path") &&
+ !cookie_dict->GetString("path", &path)) {
+ reply.SendError("optional 'path' invalid");
+ return;
+ }
+ if (cookie_dict->HasKey("secure") &&
+ !cookie_dict->GetBoolean("secure", &secure)) {
+ reply.SendError("optional 'secure' invalid");
+ return;
+ }
+ if (cookie_dict->HasKey("expiry")) {
+ int expiry_int;
+ if (cookie_dict->GetInteger("expiry", &expiry_int)) {
+ expiry = expiry_int;
+ } else if (!cookie_dict->GetDouble("expiry", &expiry)) {
+ reply.SendError("optional 'expiry' invalid");
+ return;
+ }
+ }
+ if (cookie_dict->HasKey("http_only") &&
+ !cookie_dict->GetBoolean("http_only", &http_only)) {
+ reply.SendError("optional 'http_only' invalid");
+ return;
+ }
+
+ scoped_ptr<net::CookieMonster::CanonicalCookie> cookie(
+ net::CookieMonster::CanonicalCookie::Create(
+ GURL(url), name, value, domain, path, base::Time(),
+ base::Time::FromDoubleT(expiry), secure, http_only));
+ if (!cookie.get()) {
+ reply.SendError("given 'cookie' parameters are invalid");
+ return;
+ }
// Since we may be on the UI thread don't call GetURLRequestContext().
scoped_refptr<URLRequestContextGetter> context_getter =
- browser->profile()->GetRequestContext();
+ provider->profile()->GetRequestContext();
base::WaitableEvent event(true /* manual reset */,
false /* not initially signaled */);
bool success = false;
Task* task = NewRunnableFunction(
- &SetCookieOnIOThread,
- GURL(url), cookie, context_getter, &event, &success);
+ &SetCookieWithDetailsOnIOThread,
+ GURL(url), *cookie.get(), domain, context_getter, &event, &success);
if (!BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, task)) {
reply.SendError("Couldn't post task to set the cookie");
return;
« no previous file with comments | « chrome/browser/automation/automation_util.h ('k') | chrome/browser/automation/testing_automation_provider.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698