OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/extensions/api/identity/experimental_identity_api.h" | 5 #include "chrome/browser/extensions/api/identity/experimental_identity_api.h" |
6 | 6 |
7 #include <set> | 7 #include <set> |
8 #include <string> | 8 #include <string> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
(...skipping 251 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
262 error_ = identity_constants::kOffTheRecord; | 262 error_ = identity_constants::kOffTheRecord; |
263 return false; | 263 return false; |
264 } | 264 } |
265 | 265 |
266 scoped_ptr<identity_exp::LaunchWebAuthFlow::Params> params( | 266 scoped_ptr<identity_exp::LaunchWebAuthFlow::Params> params( |
267 identity_exp::LaunchWebAuthFlow::Params::Create(*args_)); | 267 identity_exp::LaunchWebAuthFlow::Params::Create(*args_)); |
268 EXTENSION_FUNCTION_VALIDATE(params.get()); | 268 EXTENSION_FUNCTION_VALIDATE(params.get()); |
269 const identity_exp::ExperimentalWebAuthFlowDetails& details = params->details; | 269 const identity_exp::ExperimentalWebAuthFlowDetails& details = params->details; |
270 | 270 |
271 GURL auth_url(params->details.url); | 271 GURL auth_url(params->details.url); |
272 WebAuthFlow::Mode mode = | 272 ExperimentalWebAuthFlow::Mode mode = |
273 params->details.interactive && *params->details.interactive ? | 273 params->details.interactive && *params->details.interactive ? |
274 WebAuthFlow::INTERACTIVE : WebAuthFlow::SILENT; | 274 ExperimentalWebAuthFlow::INTERACTIVE : ExperimentalWebAuthFlow::SILENT; |
275 | 275 |
276 // Set up acceptable target URLs. (Includes chrome-extension scheme | 276 // Set up acceptable target URLs. (Includes chrome-extension scheme |
277 // for this version of the API.) | 277 // for this version of the API.) |
278 InitFinalRedirectURLPrefixes(GetExtension()->id()); | 278 InitFinalRedirectURLPrefixes(GetExtension()->id()); |
279 | 279 |
280 // The bounds attributes are optional, but using 0 when they're not available | 280 // The bounds attributes are optional, but using 0 when they're not available |
281 // does the right thing. | 281 // does the right thing. |
282 gfx::Rect initial_bounds; | 282 gfx::Rect initial_bounds; |
283 if (details.width) | 283 if (details.width) |
284 initial_bounds.set_width(*details.width); | 284 initial_bounds.set_width(*details.width); |
285 if (details.height) | 285 if (details.height) |
286 initial_bounds.set_height(*details.height); | 286 initial_bounds.set_height(*details.height); |
287 if (details.left) | 287 if (details.left) |
288 initial_bounds.set_x(*details.left); | 288 initial_bounds.set_x(*details.left); |
289 if (details.top) | 289 if (details.top) |
290 initial_bounds.set_y(*details.top); | 290 initial_bounds.set_y(*details.top); |
291 | 291 |
292 AddRef(); // Balanced in OnAuthFlowSuccess/Failure. | 292 AddRef(); // Balanced in OnAuthFlowSuccess/Failure. |
293 | 293 |
294 Browser* current_browser = this->GetCurrentBrowser(); | 294 Browser* current_browser = this->GetCurrentBrowser(); |
295 chrome::HostDesktopType host_desktop_type = current_browser ? | 295 chrome::HostDesktopType host_desktop_type = current_browser ? |
296 current_browser->host_desktop_type() : chrome::GetActiveDesktop(); | 296 current_browser->host_desktop_type() : chrome::GetActiveDesktop(); |
297 auth_flow_.reset(new WebAuthFlow( | 297 auth_flow_.reset(new ExperimentalWebAuthFlow( |
298 this, profile(), auth_url, mode, initial_bounds, | 298 this, profile(), auth_url, mode, initial_bounds, |
299 host_desktop_type)); | 299 host_desktop_type)); |
300 auth_flow_->Start(); | 300 auth_flow_->Start(); |
301 return true; | 301 return true; |
302 } | 302 } |
303 | 303 |
304 bool ExperimentalIdentityLaunchWebAuthFlowFunction::IsFinalRedirectURL( | 304 bool ExperimentalIdentityLaunchWebAuthFlowFunction::IsFinalRedirectURL( |
305 const GURL& url) const { | 305 const GURL& url) const { |
306 std::vector<GURL>::const_iterator iter; | 306 std::vector<GURL>::const_iterator iter; |
307 for (iter = final_prefixes_.begin(); iter != final_prefixes_.end(); ++iter) { | 307 for (iter = final_prefixes_.begin(); iter != final_prefixes_.end(); ++iter) { |
308 if (url.GetWithEmptyPath() == *iter) { | 308 if (url.GetWithEmptyPath() == *iter) { |
309 return true; | 309 return true; |
310 } | 310 } |
311 } | 311 } |
312 return false; | 312 return false; |
313 } | 313 } |
314 | 314 |
315 void ExperimentalIdentityLaunchWebAuthFlowFunction:: | 315 void ExperimentalIdentityLaunchWebAuthFlowFunction:: |
316 InitFinalRedirectURLPrefixes(const std::string& extension_id) { | 316 InitFinalRedirectURLPrefixes(const std::string& extension_id) { |
317 final_prefixes_.push_back(Extension::GetBaseURLFromExtensionId(extension_id)); | 317 final_prefixes_.push_back(Extension::GetBaseURLFromExtensionId(extension_id)); |
318 final_prefixes_.push_back(GURL(base::StringPrintf( | 318 final_prefixes_.push_back(GURL(base::StringPrintf( |
319 kChromiumDomainRedirectUrlPattern, extension_id.c_str()))); | 319 kChromiumDomainRedirectUrlPattern, extension_id.c_str()))); |
320 } | 320 } |
321 | 321 |
322 void ExperimentalIdentityLaunchWebAuthFlowFunction::OnAuthFlowFailure( | 322 void ExperimentalIdentityLaunchWebAuthFlowFunction::OnAuthFlowFailure( |
323 WebAuthFlow::Failure failure) { | 323 ExperimentalWebAuthFlow::Failure failure) { |
324 switch (failure) { | 324 switch (failure) { |
325 case WebAuthFlow::WINDOW_CLOSED: | 325 case ExperimentalWebAuthFlow::WINDOW_CLOSED: |
326 error_ = identity_constants::kUserRejected; | 326 error_ = identity_constants::kUserRejected; |
327 break; | 327 break; |
328 case WebAuthFlow::INTERACTION_REQUIRED: | 328 case ExperimentalWebAuthFlow::INTERACTION_REQUIRED: |
329 error_ = identity_constants::kInteractionRequired; | 329 error_ = identity_constants::kInteractionRequired; |
330 break; | 330 break; |
331 default: | 331 default: |
332 NOTREACHED() << "Unexpected error from web auth flow: " << failure; | 332 NOTREACHED() << "Unexpected error from web auth flow: " << failure; |
333 error_ = identity_constants::kInvalidRedirect; | 333 error_ = identity_constants::kInvalidRedirect; |
334 break; | 334 break; |
335 } | 335 } |
336 SendResponse(false); | 336 SendResponse(false); |
337 Release(); // Balanced in RunImpl. | 337 Release(); // Balanced in RunImpl. |
338 } | 338 } |
339 | 339 |
340 void ExperimentalIdentityLaunchWebAuthFlowFunction::OnAuthFlowURLChange( | 340 void ExperimentalIdentityLaunchWebAuthFlowFunction::OnAuthFlowURLChange( |
341 const GURL& redirect_url) { | 341 const GURL& redirect_url) { |
342 if (IsFinalRedirectURL(redirect_url)) { | 342 if (IsFinalRedirectURL(redirect_url)) { |
343 SetResult(Value::CreateStringValue(redirect_url.spec())); | 343 SetResult(Value::CreateStringValue(redirect_url.spec())); |
344 SendResponse(true); | 344 SendResponse(true); |
345 Release(); // Balanced in RunImpl. | 345 Release(); // Balanced in RunImpl. |
346 } | 346 } |
347 } | 347 } |
348 | 348 |
349 void ExperimentalIdentityLaunchWebAuthFlowFunction:: | 349 void ExperimentalIdentityLaunchWebAuthFlowFunction:: |
350 InitFinalRedirectURLPrefixesForTest(const std::string& extension_id) { | 350 InitFinalRedirectURLPrefixesForTest(const std::string& extension_id) { |
351 final_prefixes_.clear(); | 351 final_prefixes_.clear(); |
352 InitFinalRedirectURLPrefixes(extension_id); | 352 InitFinalRedirectURLPrefixes(extension_id); |
353 } | 353 } |
354 | 354 |
355 } // namespace extensions | 355 } // namespace extensions |
OLD | NEW |