OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "media/mojo/services/mojo_cdm_service.h" | 5 #include "media/mojo/services/mojo_cdm_service.h" |
6 | 6 |
7 #include <map> | 7 #include <map> |
8 #include <utility> | 8 #include <utility> |
9 | 9 |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
(...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
118 base::Bind(&MojoCdmService::OnSessionMessage, weak_this), | 118 base::Bind(&MojoCdmService::OnSessionMessage, weak_this), |
119 base::Bind(&MojoCdmService::OnSessionClosed, weak_this), | 119 base::Bind(&MojoCdmService::OnSessionClosed, weak_this), |
120 base::Bind(&MojoCdmService::OnLegacySessionError, weak_this), | 120 base::Bind(&MojoCdmService::OnLegacySessionError, weak_this), |
121 base::Bind(&MojoCdmService::OnSessionKeysChange, weak_this), | 121 base::Bind(&MojoCdmService::OnSessionKeysChange, weak_this), |
122 base::Bind(&MojoCdmService::OnSessionExpirationUpdate, weak_this), | 122 base::Bind(&MojoCdmService::OnSessionExpirationUpdate, weak_this), |
123 base::Bind(&MojoCdmService::OnCdmCreated, weak_this, callback)); | 123 base::Bind(&MojoCdmService::OnCdmCreated, weak_this, callback)); |
124 } | 124 } |
125 | 125 |
126 void MojoCdmService::SetServerCertificate( | 126 void MojoCdmService::SetServerCertificate( |
127 mojo::Array<uint8_t> certificate_data, | 127 mojo::Array<uint8_t> certificate_data, |
128 const SetServerCertificateCallback& callback) { | 128 const mojo::Callback<void(mojom::CdmPromiseResultPtr)>& callback) { |
129 DVLOG(2) << __FUNCTION__; | 129 DVLOG(2) << __FUNCTION__; |
130 cdm_->SetServerCertificate( | 130 cdm_->SetServerCertificate( |
131 certificate_data.storage(), | 131 certificate_data.storage(), |
132 base::WrapUnique(new SimpleMojoCdmPromise(callback))); | 132 base::WrapUnique(new SimpleMojoCdmPromise(callback))); |
133 } | 133 } |
134 | 134 |
135 void MojoCdmService::CreateSessionAndGenerateRequest( | 135 void MojoCdmService::CreateSessionAndGenerateRequest( |
136 mojom::ContentDecryptionModule::SessionType session_type, | 136 mojom::ContentDecryptionModule::SessionType session_type, |
137 mojom::ContentDecryptionModule::InitDataType init_data_type, | 137 mojom::ContentDecryptionModule::InitDataType init_data_type, |
138 mojo::Array<uint8_t> init_data, | 138 mojo::Array<uint8_t> init_data, |
139 const CreateSessionAndGenerateRequestCallback& callback) { | 139 const mojo::Callback<void(mojom::CdmPromiseResultPtr, mojo::String)>& |
| 140 callback) { |
140 DVLOG(2) << __FUNCTION__; | 141 DVLOG(2) << __FUNCTION__; |
141 cdm_->CreateSessionAndGenerateRequest( | 142 cdm_->CreateSessionAndGenerateRequest( |
142 static_cast<MediaKeys::SessionType>(session_type), | 143 static_cast<MediaKeys::SessionType>(session_type), |
143 static_cast<EmeInitDataType>(init_data_type), init_data.storage(), | 144 static_cast<EmeInitDataType>(init_data_type), init_data.storage(), |
144 base::WrapUnique(new NewSessionMojoCdmPromise(callback))); | 145 base::WrapUnique(new NewSessionMojoCdmPromise(callback))); |
145 } | 146 } |
146 | 147 |
147 void MojoCdmService::LoadSession( | 148 void MojoCdmService::LoadSession( |
148 mojom::ContentDecryptionModule::SessionType session_type, | 149 mojom::ContentDecryptionModule::SessionType session_type, |
149 const mojo::String& session_id, | 150 const mojo::String& session_id, |
150 const LoadSessionCallback& callback) { | 151 const mojo::Callback<void(mojom::CdmPromiseResultPtr, mojo::String)>& |
| 152 callback) { |
151 DVLOG(2) << __FUNCTION__; | 153 DVLOG(2) << __FUNCTION__; |
152 cdm_->LoadSession(static_cast<MediaKeys::SessionType>(session_type), | 154 cdm_->LoadSession(static_cast<MediaKeys::SessionType>(session_type), |
153 session_id.To<std::string>(), | 155 session_id.To<std::string>(), |
154 base::WrapUnique(new NewSessionMojoCdmPromise(callback))); | 156 base::WrapUnique(new NewSessionMojoCdmPromise(callback))); |
155 } | 157 } |
156 | 158 |
157 void MojoCdmService::UpdateSession(const mojo::String& session_id, | 159 void MojoCdmService::UpdateSession( |
158 mojo::Array<uint8_t> response, | 160 const mojo::String& session_id, |
159 const UpdateSessionCallback& callback) { | 161 mojo::Array<uint8_t> response, |
| 162 const mojo::Callback<void(mojom::CdmPromiseResultPtr)>& callback) { |
160 DVLOG(2) << __FUNCTION__; | 163 DVLOG(2) << __FUNCTION__; |
161 cdm_->UpdateSession( | 164 cdm_->UpdateSession( |
162 session_id.To<std::string>(), response.storage(), | 165 session_id.To<std::string>(), response.storage(), |
163 std::unique_ptr<SimpleCdmPromise>(new SimpleMojoCdmPromise(callback))); | 166 std::unique_ptr<SimpleCdmPromise>(new SimpleMojoCdmPromise(callback))); |
164 } | 167 } |
165 | 168 |
166 void MojoCdmService::CloseSession(const mojo::String& session_id, | 169 void MojoCdmService::CloseSession( |
167 const CloseSessionCallback& callback) { | 170 const mojo::String& session_id, |
| 171 const mojo::Callback<void(mojom::CdmPromiseResultPtr)>& callback) { |
168 DVLOG(2) << __FUNCTION__; | 172 DVLOG(2) << __FUNCTION__; |
169 cdm_->CloseSession(session_id.To<std::string>(), | 173 cdm_->CloseSession(session_id.To<std::string>(), |
170 base::WrapUnique(new SimpleMojoCdmPromise(callback))); | 174 base::WrapUnique(new SimpleMojoCdmPromise(callback))); |
171 } | 175 } |
172 | 176 |
173 void MojoCdmService::RemoveSession(const mojo::String& session_id, | 177 void MojoCdmService::RemoveSession( |
174 const RemoveSessionCallback& callback) { | 178 const mojo::String& session_id, |
| 179 const mojo::Callback<void(mojom::CdmPromiseResultPtr)>& callback) { |
175 DVLOG(2) << __FUNCTION__; | 180 DVLOG(2) << __FUNCTION__; |
176 cdm_->RemoveSession(session_id.To<std::string>(), | 181 cdm_->RemoveSession(session_id.To<std::string>(), |
177 base::WrapUnique(new SimpleMojoCdmPromise(callback))); | 182 base::WrapUnique(new SimpleMojoCdmPromise(callback))); |
178 } | 183 } |
179 | 184 |
180 scoped_refptr<MediaKeys> MojoCdmService::GetCdm() { | 185 scoped_refptr<MediaKeys> MojoCdmService::GetCdm() { |
181 return cdm_; | 186 return cdm_; |
182 } | 187 } |
183 | 188 |
184 void MojoCdmService::OnCdmCreated(const InitializeCallback& callback, | 189 void MojoCdmService::OnCdmCreated(const InitializeCallback& callback, |
(...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
270 | 275 |
271 void MojoCdmService::OnDecryptorConnectionError() { | 276 void MojoCdmService::OnDecryptorConnectionError() { |
272 DVLOG(2) << __FUNCTION__; | 277 DVLOG(2) << __FUNCTION__; |
273 | 278 |
274 // MojoDecryptorService has lost connectivity to it's client, so it can be | 279 // MojoDecryptorService has lost connectivity to it's client, so it can be |
275 // freed. | 280 // freed. |
276 decryptor_.reset(); | 281 decryptor_.reset(); |
277 } | 282 } |
278 | 283 |
279 } // namespace media | 284 } // namespace media |
OLD | NEW |