Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(176)

Side by Side Diff: content/renderer/media/webcontentdecryptionmodulesession_impl.cc

Issue 171073002: Move SessionIdAdapter out of WebContentDecryptionModuleImpl (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: cdm_session_id_adapter renamed cdm_session_adapter Created 6 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/renderer/media/webcontentdecryptionmodulesession_impl.h" 5 #include "content/renderer/media/webcontentdecryptionmodulesession_impl.h"
6 6
7 #include "base/callback_helpers.h" 7 #include "base/callback_helpers.h"
8 #include "base/logging.h" 8 #include "base/logging.h"
9 #include "base/strings/string_util.h" 9 #include "base/strings/string_util.h"
10 #include "content/renderer/media/cdm_session_adapter.h"
10 #include "third_party/WebKit/public/platform/WebURL.h" 11 #include "third_party/WebKit/public/platform/WebURL.h"
11 12
12 namespace content { 13 namespace content {
13 14
14 WebContentDecryptionModuleSessionImpl::WebContentDecryptionModuleSessionImpl( 15 WebContentDecryptionModuleSessionImpl::WebContentDecryptionModuleSessionImpl(
15 uint32 session_id, 16 uint32 session_id,
16 media::MediaKeys* media_keys,
17 Client* client, 17 Client* client,
18 const SessionClosedCB& session_closed_cb) 18 scoped_refptr<CdmSessionAdapter> adapter)
19 : media_keys_(media_keys), 19 : adapter_(adapter),
20 client_(client), 20 client_(client),
21 session_closed_cb_(session_closed_cb), 21 session_id_(session_id),
22 session_id_(session_id) { 22 is_closed_(false) {
23 DCHECK(media_keys_);
24 } 23 }
25 24
26 WebContentDecryptionModuleSessionImpl:: 25 WebContentDecryptionModuleSessionImpl::
27 ~WebContentDecryptionModuleSessionImpl() { 26 ~WebContentDecryptionModuleSessionImpl() {
27 if (!is_closed_)
28 adapter_->RemoveSession(session_id_);
28 } 29 }
29 30
30 blink::WebString WebContentDecryptionModuleSessionImpl::sessionId() const { 31 blink::WebString WebContentDecryptionModuleSessionImpl::sessionId() const {
31 return web_session_id_; 32 return web_session_id_;
32 } 33 }
33 34
34 void WebContentDecryptionModuleSessionImpl::initializeNewSession( 35 void WebContentDecryptionModuleSessionImpl::initializeNewSession(
35 const blink::WebString& mime_type, 36 const blink::WebString& mime_type,
36 const uint8* init_data, size_t init_data_length) { 37 const uint8* init_data, size_t init_data_length) {
37 // TODO(ddorwin): Guard against this in supported types check and remove this. 38 // TODO(ddorwin): Guard against this in supported types check and remove this.
38 // Chromium only supports ASCII MIME types. 39 // Chromium only supports ASCII MIME types.
39 if (!IsStringASCII(mime_type)) { 40 if (!IsStringASCII(mime_type)) {
40 NOTREACHED(); 41 NOTREACHED();
41 OnSessionError(media::MediaKeys::kUnknownError, 0); 42 OnSessionError(media::MediaKeys::kUnknownError, 0);
42 return; 43 return;
43 } 44 }
44 45
45 media_keys_->CreateSession( 46 adapter_->CreateSession(
46 session_id_, UTF16ToASCII(mime_type), init_data, init_data_length); 47 session_id_, UTF16ToASCII(mime_type), init_data, init_data_length);
47 } 48 }
48 49
49 void WebContentDecryptionModuleSessionImpl::update(const uint8* response, 50 void WebContentDecryptionModuleSessionImpl::update(const uint8* response,
50 size_t response_length) { 51 size_t response_length) {
51 DCHECK(response); 52 DCHECK(response);
52 media_keys_->UpdateSession(session_id_, response, response_length); 53 adapter_->UpdateSession(session_id_, response, response_length);
53 } 54 }
54 55
55 void WebContentDecryptionModuleSessionImpl::release() { 56 void WebContentDecryptionModuleSessionImpl::release() {
56 media_keys_->ReleaseSession(session_id_); 57 adapter_->ReleaseSession(session_id_);
57 } 58 }
58 59
59 void WebContentDecryptionModuleSessionImpl::OnSessionCreated( 60 void WebContentDecryptionModuleSessionImpl::OnSessionCreated(
60 const std::string& web_session_id) { 61 const std::string& web_session_id) {
61 // Due to heartbeat messages, OnSessionCreated() can get called multiple 62 // Due to heartbeat messages, OnSessionCreated() can get called multiple
62 // times. 63 // times.
63 // TODO(jrummell): Once all CDMs are updated to support reference ids, 64 // TODO(jrummell): Once all CDMs are updated to support reference ids,
64 // OnSessionCreated() should only be called once, and the second check can be 65 // OnSessionCreated() should only be called once, and the second check can be
65 // removed. 66 // removed.
66 blink::WebString id = blink::WebString::fromUTF8(web_session_id); 67 blink::WebString id = blink::WebString::fromUTF8(web_session_id);
67 DCHECK(web_session_id_.isEmpty() || web_session_id_ == id) 68 DCHECK(web_session_id_.isEmpty() || web_session_id_ == id)
68 << "Session ID may not be changed once set."; 69 << "Session ID may not be changed once set.";
69 web_session_id_ = id; 70 web_session_id_ = id;
70 } 71 }
71 72
72 void WebContentDecryptionModuleSessionImpl::OnSessionMessage( 73 void WebContentDecryptionModuleSessionImpl::OnSessionMessage(
73 const std::vector<uint8>& message, 74 const std::vector<uint8>& message,
74 const std::string& destination_url) { 75 const std::string& destination_url) {
75 client_->message(message.empty() ? NULL : &message[0], 76 client_->message(message.empty() ? NULL : &message[0],
76 message.size(), 77 message.size(),
77 GURL(destination_url)); 78 GURL(destination_url));
78 } 79 }
79 80
80 void WebContentDecryptionModuleSessionImpl::OnSessionReady() { 81 void WebContentDecryptionModuleSessionImpl::OnSessionReady() {
81 client_->ready(); 82 client_->ready();
82 } 83 }
83 84
84 void WebContentDecryptionModuleSessionImpl::OnSessionClosed() { 85 void WebContentDecryptionModuleSessionImpl::OnSessionClosed() {
85 client_->close(); 86 client_->close();
86 if (!session_closed_cb_.is_null()) 87
87 base::ResetAndReturn(&session_closed_cb_).Run(session_id_); 88 // Now that the session is closed, no more events will come from the CDM.
89 is_closed_ = true;
90 adapter_->RemoveSession(session_id_);
ddorwin 2014/02/19 01:41:53 Is there any advantage in de-registering the sessi
jrummell 2014/02/19 20:42:10 Not really. I just added it here in case the Blink
88 } 91 }
89 92
90 void WebContentDecryptionModuleSessionImpl::OnSessionError( 93 void WebContentDecryptionModuleSessionImpl::OnSessionError(
91 media::MediaKeys::KeyError error_code, 94 media::MediaKeys::KeyError error_code,
92 int system_code) { 95 int system_code) {
93 client_->error(static_cast<Client::MediaKeyErrorCode>(error_code), 96 client_->error(static_cast<Client::MediaKeyErrorCode>(error_code),
94 system_code); 97 system_code);
95 } 98 }
96 99
97 } // namespace content 100 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698