// Copyright 2014 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 "components/enhanced_bookmarks/bookmark_server_service.h" #include "base/auto_reset.h" #include "components/enhanced_bookmarks/enhanced_bookmark_model.h" #include "components/signin/core/browser/profile_oauth2_token_service.h" #include "components/signin/core/browser/signin_manager_base.h" #include "google_apis/gaia/gaia_constants.h" #include "net/base/load_flags.h" #include "net/url_request/url_request_context_getter.h" #include "ui/base/models/tree_node_iterator.h" namespace enhanced_bookmarks { BookmarkServerService::BookmarkServerService( scoped_refptr<net::URLRequestContextGetter> request_context_getter, ProfileOAuth2TokenService* token_service, SigninManagerBase* signin_manager, EnhancedBookmarkModel* enhanced_bookmark_model) : OAuth2TokenService::Consumer("bookmark_server_service"), model_(enhanced_bookmark_model), token_service_(token_service), signin_manager_(signin_manager), request_context_getter_(request_context_getter) { DCHECK(request_context_getter.get()); DCHECK(token_service); DCHECK(signin_manager); DCHECK(enhanced_bookmark_model); model_->AddObserver(this); } BookmarkServerService::~BookmarkServerService() { model_->RemoveObserver(this); } void BookmarkServerService::AddObserver( BookmarkServerServiceObserver* observer) { observers_.AddObserver(observer); } void BookmarkServerService::RemoveObserver( BookmarkServerServiceObserver* observer) { observers_.RemoveObserver(observer); } const BookmarkNode* BookmarkServerService::BookmarkForRemoteId( const std::string& remote_id) const { std::map<std::string, const BookmarkNode*>::const_iterator it = starsid_to_bookmark_.find(remote_id); if (it == starsid_to_bookmark_.end()) return NULL; return it->second; } const std::string BookmarkServerService::RemoteIDForBookmark( const BookmarkNode* bookmark) const { return model_->GetRemoteId(bookmark); } void BookmarkServerService::Notify() { FOR_EACH_OBSERVER(BookmarkServerServiceObserver, observers_, OnChange(this)); } void BookmarkServerService::TriggerTokenRequest(bool cancel_previous) { if (cancel_previous) url_fetcher_.reset(); if (token_request_ || url_fetcher_) return; // Fetcher is already running. const std::string username(signin_manager_->GetAuthenticatedUsername()); if (!username.length()) { // User is not signed in. CleanAfterFailure(); Notify(); return; } // Find a token. OAuth2TokenService::ScopeSet scopes; scopes.insert(GaiaConstants::kChromeSyncOAuth2Scope); token_request_ = token_service_->StartRequest(username, scopes, this); } // // OAuth2AccessTokenConsumer methods. // void BookmarkServerService::OnGetTokenSuccess( const OAuth2TokenService::Request* request, const std::string& access_token, const base::Time& expiration_time) { url_fetcher_.reset(CreateFetcher()); // Free the token request. token_request_.reset(); if (!url_fetcher_) { CleanAfterFailure(); Notify(); return; } url_fetcher_->SetRequestContext(request_context_getter_.get()); // Add the token. std::string headers; headers = "Authorization: Bearer "; headers += access_token; headers += "\r\n"; url_fetcher_->SetExtraRequestHeaders(headers); // Do not pollute the cookie store with cruft, or mix the users cookie in this // request. url_fetcher_->SetLoadFlags(net::LOAD_DO_NOT_SEND_COOKIES | net::LOAD_DO_NOT_SAVE_COOKIES); url_fetcher_->Start(); } void BookmarkServerService::OnGetTokenFailure( const OAuth2TokenService::Request* request, const GoogleServiceAuthError& error) { // Free the request. token_request_.reset(); CleanAfterFailure(); Notify(); } // // net::URLFetcherDelegate methods. // void BookmarkServerService::OnURLFetchComplete(const net::URLFetcher* source) { scoped_ptr<net::URLFetcher> url_fetcher(url_fetcher_.Pass()); std::string response; bool should_notify = true; if (url_fetcher->GetResponseCode() != 200 || !url_fetcher->GetResponseAsString(&response) || !ProcessResponse(response, &should_notify)) { CleanAfterFailure(); } if (should_notify) Notify(); } void BookmarkServerService::EnhancedBookmarkModelShuttingDown() { NOTREACHED(); } SigninManagerBase* BookmarkServerService::GetSigninManager() { DCHECK(signin_manager_); return signin_manager_; } } // namespace enhanced_bookmarks