| Index: chrome/browser/google_apis/gdata_wapi_url_generator.cc
|
| diff --git a/chrome/browser/google_apis/gdata_wapi_url_generator.cc b/chrome/browser/google_apis/gdata_wapi_url_generator.cc
|
| deleted file mode 100644
|
| index 9d09bf181c51098c31cb3d1ab7dcbf11657dec40..0000000000000000000000000000000000000000
|
| --- a/chrome/browser/google_apis/gdata_wapi_url_generator.cc
|
| +++ /dev/null
|
| @@ -1,250 +0,0 @@
|
| -// Copyright (c) 2012 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/google_apis/gdata_wapi_url_generator.h"
|
| -
|
| -#include "base/logging.h"
|
| -#include "base/strings/string_number_conversions.h"
|
| -#include "base/strings/stringprintf.h"
|
| -#include "net/base/escape.h"
|
| -#include "net/base/url_util.h"
|
| -#include "url/gurl.h"
|
| -
|
| -namespace google_apis {
|
| -namespace {
|
| -
|
| -// Content URL for modification or resource list retrieval in a particular
|
| -// directory specified by "%s" which will be replaced with its resource id.
|
| -const char kContentURLFormat[] = "/feeds/default/private/full/%s/contents";
|
| -
|
| -// Content URL for removing a resource specified by the latter "%s" from the
|
| -// directory specified by the former "%s".
|
| -const char kResourceURLForRemovalFormat[] =
|
| - "/feeds/default/private/full/%s/contents/%s";
|
| -
|
| -// URL requesting single resource entry whose resource id is followed by this
|
| -// prefix.
|
| -const char kGetEditURLPrefix[] = "/feeds/default/private/full/";
|
| -
|
| -// Root resource list url.
|
| -const char kResourceListRootURL[] = "/feeds/default/private/full";
|
| -
|
| -// Metadata feed with things like user quota.
|
| -const char kAccountMetadataURL[] = "/feeds/metadata/default";
|
| -
|
| -// URL to upload a new file under a particular directory specified by "%s".
|
| -const char kInitiateUploadNewFileURLFormat[] =
|
| - "/feeds/upload/create-session/default/private/full/%s/contents";
|
| -
|
| -// URL to upload a file content to overwrite a file whose resource id is
|
| -// followed by this prefix.
|
| -const char kInitiateUploadExistingFileURLPrefix[] =
|
| - "/feeds/upload/create-session/default/private/full/";
|
| -
|
| -// Maximum number of resource entries to include in a feed.
|
| -// Be careful not to use something too small because it might overload the
|
| -// server. Be careful not to use something too large because it makes the
|
| -// "fetched N items" UI less responsive.
|
| -const int kMaxDocumentsPerFeed = 500;
|
| -const int kMaxDocumentsPerSearchFeed = 50;
|
| -
|
| -// URL requesting documents list of changes to documents collections.
|
| -const char kGetChangesListURL[] = "/feeds/default/private/changes";
|
| -
|
| -} // namespace
|
| -
|
| -const char GDataWapiUrlGenerator::kBaseUrlForProduction[] =
|
| - "https://docs.google.com/";
|
| -
|
| -const char GDataWapiUrlGenerator::kBaseDownloadUrlForProduction[] =
|
| - "https://www.googledrive.com/host/";
|
| -
|
| -// static
|
| -GURL GDataWapiUrlGenerator::AddStandardUrlParams(const GURL& url) {
|
| - GURL result = net::AppendOrReplaceQueryParameter(url, "v", "3");
|
| - result = net::AppendOrReplaceQueryParameter(result, "alt", "json");
|
| - result = net::AppendOrReplaceQueryParameter(result, "showroot", "true");
|
| - return result;
|
| -}
|
| -
|
| -// static
|
| -GURL GDataWapiUrlGenerator::AddInitiateUploadUrlParams(const GURL& url) {
|
| - GURL result = net::AppendOrReplaceQueryParameter(url, "convert", "false");
|
| - return AddStandardUrlParams(result);
|
| -}
|
| -
|
| -// static
|
| -GURL GDataWapiUrlGenerator::AddFeedUrlParams(
|
| - const GURL& url,
|
| - int num_items_to_fetch) {
|
| - GURL result = AddStandardUrlParams(url);
|
| - result = net::AppendOrReplaceQueryParameter(result, "showfolders", "true");
|
| - result = net::AppendOrReplaceQueryParameter(result, "include-shared", "true");
|
| - result = net::AppendOrReplaceQueryParameter(
|
| - result, "max-results", base::IntToString(num_items_to_fetch));
|
| - return result;
|
| -}
|
| -
|
| -GDataWapiUrlGenerator::GDataWapiUrlGenerator(const GURL& base_url,
|
| - const GURL& base_download_url)
|
| - : base_url_(base_url),
|
| - base_download_url_(base_download_url) {
|
| -}
|
| -
|
| -GDataWapiUrlGenerator::~GDataWapiUrlGenerator() {
|
| -}
|
| -
|
| -GURL GDataWapiUrlGenerator::GenerateResourceListUrl(
|
| - const GURL& override_url,
|
| - int64 start_changestamp,
|
| - const std::string& search_string,
|
| - const std::string& directory_resource_id) const {
|
| - DCHECK_LE(0, start_changestamp);
|
| -
|
| - int max_docs = search_string.empty() ? kMaxDocumentsPerFeed :
|
| - kMaxDocumentsPerSearchFeed;
|
| - GURL url;
|
| - if (!override_url.is_empty()) {
|
| - // |override_url| specifies the URL of the continuation feed when the feed
|
| - // is broken up to multiple chunks. In this case we must not add the
|
| - // |start_changestamp| that provides the original start point.
|
| - start_changestamp = 0;
|
| - url = override_url;
|
| - } else if (start_changestamp > 0) {
|
| - // The start changestamp shouldn't be used for a search.
|
| - DCHECK(search_string.empty());
|
| - url = base_url_.Resolve(kGetChangesListURL);
|
| - } else if (!directory_resource_id.empty()) {
|
| - url = base_url_.Resolve(
|
| - base::StringPrintf(kContentURLFormat,
|
| - net::EscapePath(
|
| - directory_resource_id).c_str()));
|
| - } else {
|
| - url = base_url_.Resolve(kResourceListRootURL);
|
| - }
|
| -
|
| - url = AddFeedUrlParams(url, max_docs);
|
| -
|
| - if (start_changestamp) {
|
| - url = net::AppendOrReplaceQueryParameter(
|
| - url, "start-index", base::Int64ToString(start_changestamp));
|
| - }
|
| - if (!search_string.empty()) {
|
| - url = net::AppendOrReplaceQueryParameter(url, "q", search_string);
|
| - }
|
| -
|
| - return url;
|
| -}
|
| -
|
| -GURL GDataWapiUrlGenerator::GenerateSearchByTitleUrl(
|
| - const std::string& title,
|
| - const std::string& directory_resource_id) const {
|
| - DCHECK(!title.empty());
|
| -
|
| - GURL url = directory_resource_id.empty() ?
|
| - base_url_.Resolve(kResourceListRootURL) :
|
| - base_url_.Resolve(base::StringPrintf(
|
| - kContentURLFormat, net::EscapePath(directory_resource_id).c_str()));
|
| - url = AddFeedUrlParams(url, kMaxDocumentsPerFeed);
|
| - url = net::AppendOrReplaceQueryParameter(url, "title", title);
|
| - url = net::AppendOrReplaceQueryParameter(url, "title-exact", "true");
|
| - return url;
|
| -}
|
| -
|
| -GURL GDataWapiUrlGenerator::GenerateEditUrl(
|
| - const std::string& resource_id) const {
|
| - return AddStandardUrlParams(GenerateEditUrlWithoutParams(resource_id));
|
| -}
|
| -
|
| -GURL GDataWapiUrlGenerator::GenerateEditUrlWithoutParams(
|
| - const std::string& resource_id) const {
|
| - return base_url_.Resolve(kGetEditURLPrefix + net::EscapePath(resource_id));
|
| -}
|
| -
|
| -GURL GDataWapiUrlGenerator::GenerateEditUrlWithEmbedOrigin(
|
| - const std::string& resource_id, const GURL& embed_origin) const {
|
| - GURL url = GenerateEditUrl(resource_id);
|
| - if (!embed_origin.is_empty()) {
|
| - // Construct a valid serialized embed origin from an url, according to
|
| - // WD-html5-20110525. Such string has to be built manually, since
|
| - // GURL::spec() always adds the trailing slash. Moreover, ports are
|
| - // currently not supported.
|
| - DCHECK(!embed_origin.has_port());
|
| - DCHECK(!embed_origin.has_path() || embed_origin.path() == "/");
|
| - const std::string serialized_embed_origin =
|
| - embed_origin.scheme() + "://" + embed_origin.host();
|
| - url = net::AppendOrReplaceQueryParameter(
|
| - url, "embedOrigin", serialized_embed_origin);
|
| - }
|
| - return url;
|
| -}
|
| -
|
| -GURL GDataWapiUrlGenerator::GenerateContentUrl(
|
| - const std::string& resource_id) const {
|
| - if (resource_id.empty()) {
|
| - // |resource_id| must not be empty. Return an empty GURL as an error.
|
| - return GURL();
|
| - }
|
| -
|
| - GURL result = base_url_.Resolve(
|
| - base::StringPrintf(kContentURLFormat,
|
| - net::EscapePath(resource_id).c_str()));
|
| - return AddStandardUrlParams(result);
|
| -}
|
| -
|
| -GURL GDataWapiUrlGenerator::GenerateResourceUrlForRemoval(
|
| - const std::string& parent_resource_id,
|
| - const std::string& resource_id) const {
|
| - if (resource_id.empty() || parent_resource_id.empty()) {
|
| - // Both |resource_id| and |parent_resource_id| must be non-empty.
|
| - // Return an empty GURL as an error.
|
| - return GURL();
|
| - }
|
| -
|
| - GURL result = base_url_.Resolve(
|
| - base::StringPrintf(kResourceURLForRemovalFormat,
|
| - net::EscapePath(parent_resource_id).c_str(),
|
| - net::EscapePath(resource_id).c_str()));
|
| - return AddStandardUrlParams(result);
|
| -}
|
| -
|
| -GURL GDataWapiUrlGenerator::GenerateInitiateUploadNewFileUrl(
|
| - const std::string& parent_resource_id) const {
|
| - GURL result = base_url_.Resolve(
|
| - base::StringPrintf(kInitiateUploadNewFileURLFormat,
|
| - net::EscapePath(parent_resource_id).c_str()));
|
| - return AddInitiateUploadUrlParams(result);
|
| -}
|
| -
|
| -GURL GDataWapiUrlGenerator::GenerateInitiateUploadExistingFileUrl(
|
| - const std::string& resource_id) const {
|
| - GURL result = base_url_.Resolve(
|
| - kInitiateUploadExistingFileURLPrefix + net::EscapePath(resource_id));
|
| - return AddInitiateUploadUrlParams(result);
|
| -}
|
| -
|
| -GURL GDataWapiUrlGenerator::GenerateResourceListRootUrl() const {
|
| - return AddStandardUrlParams(base_url_.Resolve(kResourceListRootURL));
|
| -}
|
| -
|
| -GURL GDataWapiUrlGenerator::GenerateAccountMetadataUrl(
|
| - bool include_installed_apps) const {
|
| - GURL result = AddStandardUrlParams(base_url_.Resolve(kAccountMetadataURL));
|
| - if (include_installed_apps) {
|
| - result = net::AppendOrReplaceQueryParameter(
|
| - result, "include-installed-apps", "true");
|
| - }
|
| - return result;
|
| -}
|
| -
|
| -GURL GDataWapiUrlGenerator::GenerateDownloadFileUrl(
|
| - const std::string& resource_id) const {
|
| - // Strip the file type prefix before the colon character.
|
| - size_t colon = resource_id.find(':');
|
| - return base_download_url_.Resolve(net::EscapePath(
|
| - colon == std::string::npos ? resource_id
|
| - : resource_id.substr(colon + 1)));
|
| -}
|
| -
|
| -} // namespace google_apis
|
|
|