Chromium Code Reviews| OLD | NEW | 
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "content/browser/presentation/presentation_service_impl.h" | 5 #include "content/browser/presentation/presentation_service_impl.h" | 
| 6 | 6 | 
| 7 #include <algorithm> | 7 #include <algorithm> | 
| 8 | 8 | 
| 9 #include "base/logging.h" | 9 #include "base/logging.h" | 
| 10 #include "content/browser/presentation/presentation_type_converters.h" | 10 #include "content/browser/presentation/presentation_type_converters.h" | 
| 11 #include "content/public/browser/content_browser_client.h" | 11 #include "content/public/browser/content_browser_client.h" | 
| 12 #include "content/public/browser/navigation_details.h" | 12 #include "content/public/browser/navigation_details.h" | 
| 13 #include "content/public/browser/presentation_session_message.h" | |
| 13 #include "content/public/browser/render_frame_host.h" | 14 #include "content/public/browser/render_frame_host.h" | 
| 14 #include "content/public/browser/render_process_host.h" | 15 #include "content/public/browser/render_process_host.h" | 
| 15 #include "content/public/browser/web_contents.h" | 16 #include "content/public/browser/web_contents.h" | 
| 16 #include "content/public/common/content_client.h" | 17 #include "content/public/common/content_client.h" | 
| 17 #include "content/public/common/frame_navigate_params.h" | 18 #include "content/public/common/frame_navigate_params.h" | 
| 18 | 19 | 
| 20 namespace { | |
| 21 | |
| 22 // The return value takes ownership of the actual message of |input|. | |
| 23 presentation::SessionMessagePtr ToMojoSessionMessage( | |
| 24 content::PresentationSessionMessage* input) { | |
| 25 presentation::SessionMessagePtr output(presentation::SessionMessage::New()); | |
| 26 output->presentation_url = input->presentation_url; | |
| 27 output->presentation_id = input->presentation_id; | |
| 28 if (input->is_binary()) { | |
| 29 // binary data | |
| 30 output->type = presentation::PresentationMessageType:: | |
| 31 PRESENTATION_MESSAGE_TYPE_ARRAY_BUFFER; | |
| 32 output->data.Swap(input->data.get()); | |
| 33 } else { | |
| 34 // string message | |
| 35 output->type = | |
| 36 presentation::PresentationMessageType::PRESENTATION_MESSAGE_TYPE_TEXT; | |
| 37 output->message.Swap(input->message.get()); | |
| 38 } | |
| 39 return output.Pass(); | |
| 40 } | |
| 41 | |
| 42 } // namespace | |
| 43 | |
| 19 namespace content { | 44 namespace content { | 
| 20 | 45 | 
| 21 PresentationServiceImpl::PresentationServiceImpl( | 46 PresentationServiceImpl::PresentationServiceImpl( | 
| 22 RenderFrameHost* render_frame_host, | 47 RenderFrameHost* render_frame_host, | 
| 23 WebContents* web_contents, | 48 WebContents* web_contents, | 
| 24 PresentationServiceDelegate* delegate) | 49 PresentationServiceDelegate* delegate) | 
| 25 : WebContentsObserver(web_contents), | 50 : WebContentsObserver(web_contents), | 
| 26 delegate_(delegate), | 51 delegate_(delegate), | 
| 27 is_start_session_pending_(false), | 52 is_start_session_pending_(false), | 
| 28 next_request_session_id_(0), | 53 next_request_session_id_(0), | 
| (...skipping 299 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 328 content::RenderFrameHost* render_frame_host) const { | 353 content::RenderFrameHost* render_frame_host) const { | 
| 329 if (!render_frame_host) | 354 if (!render_frame_host) | 
| 330 return false; | 355 return false; | 
| 331 | 356 | 
| 332 return render_frame_host->GetProcess()->GetID() == render_process_id_ && | 357 return render_frame_host->GetProcess()->GetID() == render_process_id_ && | 
| 333 render_frame_host->GetRoutingID() == render_frame_id_; | 358 render_frame_host->GetRoutingID() == render_frame_id_; | 
| 334 } | 359 } | 
| 335 | 360 | 
| 336 void PresentationServiceImpl::ListenForSessionMessages( | 361 void PresentationServiceImpl::ListenForSessionMessages( | 
| 337 const SessionMessagesCallback& callback) { | 362 const SessionMessagesCallback& callback) { | 
| 338 NOTIMPLEMENTED(); | 363 DVLOG(2) << "ListenForSessionMessages"; | 
| 364 if (!delegate_) { | |
| 365 callback.Run(mojo::Array<presentation::SessionMessagePtr>()); | |
| 366 return; | |
| 367 } | |
| 368 | |
| 369 DCHECK(!on_session_messages_callback_.get()); | |
| 
 
imcheng (use chromium acct)
2015/05/04 19:53:55
I think we should just CHECK here. If renderer is
 
haibinlu
2015/05/04 21:33:49
Acknowledged.
 
 | |
| 370 | |
| 371 on_session_messages_callback_.reset(new SessionMessagesCallback(callback)); | |
| 372 delegate_->ListenForSessionMessages( | |
| 373 render_process_id_, render_frame_id_, | |
| 374 base::Bind(&PresentationServiceImpl::OnSessionMessages, | |
| 375 weak_factory_.GetWeakPtr())); | |
| 376 } | |
| 377 | |
| 378 void PresentationServiceImpl::OnSessionMessages( | |
| 379 scoped_ptr<ScopedVector<PresentationSessionMessage>> messages) { | |
| 380 DCHECK(messages.get() && messages->size() > 0); | |
| 
 
imcheng (use chromium acct)
2015/05/04 19:53:55
nit: check !messages->empty() instead of size() >
 
haibinlu
2015/05/04 21:33:49
Done.
 
 | |
| 381 if (!on_session_messages_callback_.get()) { | |
| 382 // The Reset method of this class was invoked. | |
| 383 return; | |
| 384 } | |
| 385 | |
| 386 mojo::Array<presentation::SessionMessagePtr> mojoMessages(messages->size()); | |
| 387 for (size_t i = 0; i < messages->size(); ++i) { | |
| 388 mojoMessages[i] = ToMojoSessionMessage((*messages)[i]); | |
| 389 } | |
| 390 | |
| 391 on_session_messages_callback_->Run(mojoMessages.Pass()); | |
| 
 
imcheng (use chromium acct)
2015/05/04 19:53:55
Reset on_session_messages_callback_ after Run().
 
haibinlu
2015/05/04 21:33:49
Done.
 
 | |
| 339 } | 392 } | 
| 340 | 393 | 
| 341 void PresentationServiceImpl::DidNavigateAnyFrame( | 394 void PresentationServiceImpl::DidNavigateAnyFrame( | 
| 342 content::RenderFrameHost* render_frame_host, | 395 content::RenderFrameHost* render_frame_host, | 
| 343 const content::LoadCommittedDetails& details, | 396 const content::LoadCommittedDetails& details, | 
| 344 const content::FrameNavigateParams& params) { | 397 const content::FrameNavigateParams& params) { | 
| 345 DVLOG(2) << "PresentationServiceImpl::DidNavigateAnyFrame"; | 398 DVLOG(2) << "PresentationServiceImpl::DidNavigateAnyFrame"; | 
| 346 if (!FrameMatches(render_frame_host)) | 399 if (!FrameMatches(render_frame_host)) | 
| 347 return; | 400 return; | 
| 348 | 401 | 
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 381 DVLOG(2) << "PresentationServiceImpl::Reset"; | 434 DVLOG(2) << "PresentationServiceImpl::Reset"; | 
| 382 if (delegate_) | 435 if (delegate_) | 
| 383 delegate_->Reset(render_process_id_, render_frame_id_); | 436 delegate_->Reset(render_process_id_, render_frame_id_); | 
| 384 | 437 | 
| 385 default_presentation_url_.clear(); | 438 default_presentation_url_.clear(); | 
| 386 default_presentation_id_.clear(); | 439 default_presentation_id_.clear(); | 
| 387 availability_contexts_.clear(); | 440 availability_contexts_.clear(); | 
| 388 queued_start_session_requests_.clear(); | 441 queued_start_session_requests_.clear(); | 
| 389 FlushNewSessionCallbacks(); | 442 FlushNewSessionCallbacks(); | 
| 390 default_session_start_context_.reset(); | 443 default_session_start_context_.reset(); | 
| 444 if (on_session_messages_callback_.get()) { | |
| 445 on_session_messages_callback_->Run( | |
| 446 mojo::Array<presentation::SessionMessagePtr>()); | |
| 
 
imcheng (use chromium acct)
2015/05/04 19:53:55
It looks like you would also need to change Presen
 
haibinlu
2015/05/04 21:33:50
Done.
 
 | |
| 447 on_session_messages_callback_.reset(); | |
| 448 } | |
| 391 } | 449 } | 
| 392 | 450 | 
| 393 // static | 451 // static | 
| 394 void PresentationServiceImpl::InvokeNewSessionMojoCallbackWithError( | 452 void PresentationServiceImpl::InvokeNewSessionMojoCallbackWithError( | 
| 395 const NewSessionMojoCallback& callback) { | 453 const NewSessionMojoCallback& callback) { | 
| 396 callback.Run( | 454 callback.Run( | 
| 397 presentation::PresentationSessionInfoPtr(), | 455 presentation::PresentationSessionInfoPtr(), | 
| 398 presentation::PresentationError::From( | 456 presentation::PresentationError::From( | 
| 399 PresentationError(PRESENTATION_ERROR_UNKNOWN, "Internal error"))); | 457 PresentationError(PRESENTATION_ERROR_UNKNOWN, "Internal error"))); | 
| 400 } | 458 } | 
| (...skipping 129 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 530 void PresentationServiceImpl::DefaultSessionStartContext::Reset() { | 588 void PresentationServiceImpl::DefaultSessionStartContext::Reset() { | 
| 531 ScopedVector<DefaultSessionMojoCallback> callbacks; | 589 ScopedVector<DefaultSessionMojoCallback> callbacks; | 
| 532 callbacks.swap(callbacks_); | 590 callbacks.swap(callbacks_); | 
| 533 for (const auto& callback : callbacks) | 591 for (const auto& callback : callbacks) | 
| 534 callback->Run(presentation::PresentationSessionInfoPtr()); | 592 callback->Run(presentation::PresentationSessionInfoPtr()); | 
| 535 session_.reset(); | 593 session_.reset(); | 
| 536 } | 594 } | 
| 537 | 595 | 
| 538 } // namespace content | 596 } // namespace content | 
| 539 | 597 | 
| OLD | NEW |