// Copyright (c) 2014 GitHub, Inc. // Use of this source code is governed by the MIT license that can be // found in the LICENSE file. #include "atom/browser/atom_access_token_store.h" #include #include "atom/browser/atom_browser_context.h" #include "atom/common/google_api_key.h" #include "content/public/browser/browser_thread.h" #include "content/public/browser/geolocation_provider.h" using content::BrowserThread; namespace atom { namespace { // Notice that we just combined the api key with the url together here, because // if we use the standard {url: key} format Chromium would override our key with // the predefined one in common.gypi of libchromiumcontent, which is empty. const char* kGeolocationProviderURL = "https://www.googleapis.com/geolocation/v1/geolocate?key=" GOOGLEAPIS_API_KEY; // Loads access tokens and other necessary data on the UI thread, and // calls back to the originator on the originating thread. class TokenLoadingJob : public base::RefCountedThreadSafe { public: explicit TokenLoadingJob( const content::AccessTokenStore::LoadAccessTokensCallback& callback) : callback_(callback), request_context_getter_(nullptr) {} void Run() { BrowserThread::PostTaskAndReply( BrowserThread::UI, FROM_HERE, base::Bind(&TokenLoadingJob::PerformWorkOnUIThread, this), base::Bind(&TokenLoadingJob::RespondOnOriginatingThread, this)); } private: friend class base::RefCountedThreadSafe; ~TokenLoadingJob() {} void PerformWorkOnUIThread() { DCHECK_CURRENTLY_ON(BrowserThread::UI); auto browser_context = AtomBrowserContext::From("", false); request_context_getter_ = browser_context->GetRequestContext(); } void RespondOnOriginatingThread() { // Equivelent to access_token_map[kGeolocationProviderURL]. // Somehow base::string16 is causing compilation errors when used in a pair // of std::map on Linux, this can work around it. content::AccessTokenStore::AccessTokenMap access_token_map; std::pair token_pair; token_pair.first = GURL(kGeolocationProviderURL); access_token_map.insert(token_pair); callback_.Run(access_token_map, request_context_getter_); } content::AccessTokenStore::LoadAccessTokensCallback callback_; net::URLRequestContextGetter* request_context_getter_; }; } // namespace AtomAccessTokenStore::AtomAccessTokenStore() { content::GeolocationProvider::GetInstance()->UserDidOptIntoLocationServices(); } AtomAccessTokenStore::~AtomAccessTokenStore() { } void AtomAccessTokenStore::LoadAccessTokens( const LoadAccessTokensCallback& callback) { scoped_refptr job(new TokenLoadingJob(callback)); job->Run(); } void AtomAccessTokenStore::SaveAccessToken(const GURL& server_url, const base::string16& access_token) { } } // namespace atom