OLD | NEW |
---|---|
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 "chrome/renderer/extensions/cast_streaming_native_handler.h" | 5 #include "chrome/renderer/extensions/cast_streaming_native_handler.h" |
6 | 6 |
7 #include <functional> | 7 #include <functional> |
8 #include <iterator> | 8 #include <iterator> |
9 | 9 |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
(...skipping 20 matching lines...) Expand all Loading... | |
31 | 31 |
32 namespace extensions { | 32 namespace extensions { |
33 | 33 |
34 namespace { | 34 namespace { |
35 const char kRtpStreamNotFound[] = "The RTP stream cannot be found"; | 35 const char kRtpStreamNotFound[] = "The RTP stream cannot be found"; |
36 const char kUdpTransportNotFound[] = "The UDP transport cannot be found"; | 36 const char kUdpTransportNotFound[] = "The UDP transport cannot be found"; |
37 const char kInvalidDestination[] = "Invalid destination"; | 37 const char kInvalidDestination[] = "Invalid destination"; |
38 const char kInvalidRtpParams[] = "Invalid value for RTP params"; | 38 const char kInvalidRtpParams[] = "Invalid value for RTP params"; |
39 const char kInvalidAesKey[] = "Invalid value for AES key"; | 39 const char kInvalidAesKey[] = "Invalid value for AES key"; |
40 const char kInvalidAesIvMask[] = "Invalid value for AES IV mask"; | 40 const char kInvalidAesIvMask[] = "Invalid value for AES IV mask"; |
41 const char kInvalidStreamArgs[] = "Invalid stream arguments"; | |
41 const char kUnableToConvertArgs[] = "Unable to convert arguments"; | 42 const char kUnableToConvertArgs[] = "Unable to convert arguments"; |
42 const char kUnableToConvertParams[] = "Unable to convert params"; | 43 const char kUnableToConvertParams[] = "Unable to convert params"; |
44 const int kInvalidId = 0; | |
43 | 45 |
44 // These helper methods are used to convert between Extension API | 46 // These helper methods are used to convert between Extension API |
45 // types and Cast types. | 47 // types and Cast types. |
46 void ToCastCodecSpecificParams(const CodecSpecificParams& ext_params, | 48 void ToCastCodecSpecificParams(const CodecSpecificParams& ext_params, |
47 CastCodecSpecificParams* cast_params) { | 49 CastCodecSpecificParams* cast_params) { |
48 cast_params->key = ext_params.key; | 50 cast_params->key = ext_params.key; |
49 cast_params->value = ext_params.value; | 51 cast_params->value = ext_params.value; |
50 } | 52 } |
51 | 53 |
52 void FromCastCodecSpecificParams(const CastCodecSpecificParams& cast_params, | 54 void FromCastCodecSpecificParams(const CastCodecSpecificParams& cast_params, |
(...skipping 136 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
189 base::Bind(&CastStreamingNativeHandler::GetStats, | 191 base::Bind(&CastStreamingNativeHandler::GetStats, |
190 base::Unretained(this))); | 192 base::Unretained(this))); |
191 } | 193 } |
192 | 194 |
193 CastStreamingNativeHandler::~CastStreamingNativeHandler() { | 195 CastStreamingNativeHandler::~CastStreamingNativeHandler() { |
194 } | 196 } |
195 | 197 |
196 void CastStreamingNativeHandler::CreateCastSession( | 198 void CastStreamingNativeHandler::CreateCastSession( |
197 const v8::FunctionCallbackInfo<v8::Value>& args) { | 199 const v8::FunctionCallbackInfo<v8::Value>& args) { |
198 CHECK_EQ(3, args.Length()); | 200 CHECK_EQ(3, args.Length()); |
199 CHECK(args[0]->IsObject()); | |
200 CHECK(args[1]->IsObject()); | |
201 CHECK(args[2]->IsFunction()); | 201 CHECK(args[2]->IsFunction()); |
202 | 202 |
203 blink::WebDOMMediaStreamTrack track1 = | 203 if (args[0]->IsNull() && args[1]->IsNull()) { |
204 blink::WebDOMMediaStreamTrack::fromV8Value(args[0]); | 204 v8::Isolate* isolate = context()->v8_context()->GetIsolate(); |
205 if (track1.isNull()) | 205 isolate->ThrowException(v8::Exception::Error( |
206 v8::String::NewFromUtf8(isolate, kInvalidStreamArgs))); | |
206 return; | 207 return; |
207 blink::WebDOMMediaStreamTrack track2 = | 208 } |
208 blink::WebDOMMediaStreamTrack::fromV8Value(args[1]); | |
209 if (track2.isNull()) | |
210 return; | |
211 | 209 |
212 scoped_refptr<CastSession> session(new CastSession()); | 210 scoped_refptr<CastSession> session(new CastSession()); |
213 scoped_ptr<CastRtpStream> stream1( | 211 scoped_ptr<CastRtpStream> stream1, stream2; |
214 new CastRtpStream(track1.component(), session)); | 212 if (!args[0]->IsNull()) { |
215 scoped_ptr<CastRtpStream> stream2( | 213 CHECK(args[0]->IsObject()); |
216 new CastRtpStream(track2.component(), session)); | 214 blink::WebDOMMediaStreamTrack track = |
215 blink::WebDOMMediaStreamTrack::fromV8Value(args[0]); | |
216 stream1.reset(new CastRtpStream(track.component(), session)); | |
217 } | |
218 if (!args[1]->IsNull()) { | |
219 CHECK(args[1]->IsObject()); | |
220 blink::WebDOMMediaStreamTrack track = | |
221 blink::WebDOMMediaStreamTrack::fromV8Value(args[1]); | |
222 stream2.reset(new CastRtpStream(track.component(), session)); | |
223 } | |
217 scoped_ptr<CastUdpTransport> udp_transport( | 224 scoped_ptr<CastUdpTransport> udp_transport( |
218 new CastUdpTransport(session)); | 225 new CastUdpTransport(session)); |
219 | 226 |
220 // TODO(imcheng): Use a weak reference to ensure we don't call into an | 227 // TODO(imcheng): Use a weak reference to ensure we don't call into an |
221 // invalid context when the callback is invoked. | 228 // invalid context when the callback is invoked. |
222 create_callback_.reset(args[2].As<v8::Function>()); | 229 create_callback_.reset(args[2].As<v8::Function>()); |
223 | 230 |
224 base::MessageLoop::current()->PostTask( | 231 base::MessageLoop::current()->PostTask( |
225 FROM_HERE, | 232 FROM_HERE, |
226 base::Bind( | 233 base::Bind( |
227 &CastStreamingNativeHandler::CallCreateCallback, | 234 &CastStreamingNativeHandler::CallCreateCallback, |
228 weak_factory_.GetWeakPtr(), | 235 weak_factory_.GetWeakPtr(), |
229 base::Passed(&stream1), | 236 base::Passed(&stream1), |
230 base::Passed(&stream2), | 237 base::Passed(&stream2), |
231 base::Passed(&udp_transport))); | 238 base::Passed(&udp_transport))); |
232 } | 239 } |
233 | 240 |
234 void CastStreamingNativeHandler::CallCreateCallback( | 241 void CastStreamingNativeHandler::CallCreateCallback( |
235 scoped_ptr<CastRtpStream> stream1, | 242 scoped_ptr<CastRtpStream> stream1, |
236 scoped_ptr<CastRtpStream> stream2, | 243 scoped_ptr<CastRtpStream> stream2, |
237 scoped_ptr<CastUdpTransport> udp_transport) { | 244 scoped_ptr<CastUdpTransport> udp_transport) { |
238 v8::Isolate* isolate = context()->isolate(); | 245 v8::Isolate* isolate = context()->isolate(); |
239 v8::HandleScope handle_scope(isolate); | 246 v8::HandleScope handle_scope(isolate); |
240 v8::Context::Scope context_scope(context()->v8_context()); | 247 v8::Context::Scope context_scope(context()->v8_context()); |
241 | 248 |
242 const int stream1_id = last_transport_id_++; | 249 int stream1_id = kInvalidId; |
243 rtp_stream_map_[stream1_id] = | 250 int stream2_id = kInvalidId; |
244 linked_ptr<CastRtpStream>(stream1.release()); | 251 |
245 const int stream2_id = last_transport_id_++; | 252 if (stream1) { |
246 rtp_stream_map_[stream2_id] = | 253 stream1_id = last_transport_id_++; |
247 linked_ptr<CastRtpStream>(stream2.release()); | 254 rtp_stream_map_[stream1_id] = |
255 linked_ptr<CastRtpStream>(stream1.release()); | |
256 } | |
257 if (stream2) { | |
258 stream2_id = last_transport_id_++; | |
259 rtp_stream_map_[stream2_id] = | |
260 linked_ptr<CastRtpStream>(stream2.release()); | |
261 } | |
248 const int udp_id = last_transport_id_++; | 262 const int udp_id = last_transport_id_++; |
249 udp_transport_map_[udp_id] = | 263 udp_transport_map_[udp_id] = |
250 linked_ptr<CastUdpTransport>(udp_transport.release()); | 264 linked_ptr<CastUdpTransport>(udp_transport.release()); |
251 | 265 |
252 v8::Handle<v8::Value> callback_args[3]; | 266 v8::Handle<v8::Value> callback_args[3]; |
253 callback_args[0] = v8::Integer::New(isolate, stream1_id); | 267 callback_args[0] = v8::Null(isolate); |
254 callback_args[1] = v8::Integer::New(isolate, stream2_id); | 268 callback_args[1] = v8::Null(isolate); |
269 if (stream1_id != kInvalidId) | |
270 callback_args[0] = v8::Integer::New(isolate, stream1_id); | |
not at google - send to devlin
2014/07/15 23:32:18
can you put this up where it's guarded by the if (
Alpha Left Google
2014/07/15 23:48:42
Done.
| |
271 if (stream2_id != kInvalidId) | |
272 callback_args[1] = v8::Integer::New(isolate, stream2_id); | |
255 callback_args[2] = v8::Integer::New(isolate, udp_id); | 273 callback_args[2] = v8::Integer::New(isolate, udp_id); |
256 context()->CallFunction(create_callback_.NewHandle(isolate), | 274 context()->CallFunction(create_callback_.NewHandle(isolate), |
257 3, callback_args); | 275 3, callback_args); |
258 create_callback_.reset(); | 276 create_callback_.reset(); |
259 } | 277 } |
260 | 278 |
261 void CastStreamingNativeHandler::CallStartCallback(int stream_id) { | 279 void CastStreamingNativeHandler::CallStartCallback(int stream_id) { |
262 v8::Isolate* isolate = context()->isolate(); | 280 v8::Isolate* isolate = context()->isolate(); |
263 v8::HandleScope handle_scope(isolate); | 281 v8::HandleScope handle_scope(isolate); |
264 v8::Context::Scope context_scope(context()->v8_context()); | 282 v8::Context::Scope context_scope(context()->v8_context()); |
(...skipping 265 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
530 | 548 |
531 scoped_ptr<V8ValueConverter> converter(V8ValueConverter::create()); | 549 scoped_ptr<V8ValueConverter> converter(V8ValueConverter::create()); |
532 v8::Handle<v8::Value> callback_args[1]; | 550 v8::Handle<v8::Value> callback_args[1]; |
533 callback_args[0] = converter->ToV8Value(stats.get(), context()->v8_context()); | 551 callback_args[0] = converter->ToV8Value(stats.get(), context()->v8_context()); |
534 context()->CallFunction(it->second->NewHandle(isolate), 1, callback_args); | 552 context()->CallFunction(it->second->NewHandle(isolate), 1, callback_args); |
535 get_stats_callbacks_.erase(it); | 553 get_stats_callbacks_.erase(it); |
536 } | 554 } |
537 | 555 |
538 CastRtpStream* CastStreamingNativeHandler::GetRtpStreamOrThrow( | 556 CastRtpStream* CastStreamingNativeHandler::GetRtpStreamOrThrow( |
539 int transport_id) const { | 557 int transport_id) const { |
558 v8::Isolate* isolate = context()->v8_context()->GetIsolate(); | |
not at google - send to devlin
2014/07/15 23:32:18
this change doesn't seem necessary
Alpha Left Google
2014/07/15 23:48:42
Done.
| |
540 RtpStreamMap::const_iterator iter = rtp_stream_map_.find( | 559 RtpStreamMap::const_iterator iter = rtp_stream_map_.find( |
541 transport_id); | 560 transport_id); |
542 if (iter != rtp_stream_map_.end()) | 561 if (iter != rtp_stream_map_.end()) |
543 return iter->second.get(); | 562 return iter->second.get(); |
544 v8::Isolate* isolate = context()->v8_context()->GetIsolate(); | |
545 isolate->ThrowException(v8::Exception::RangeError(v8::String::NewFromUtf8( | 563 isolate->ThrowException(v8::Exception::RangeError(v8::String::NewFromUtf8( |
546 isolate, kRtpStreamNotFound))); | 564 isolate, kRtpStreamNotFound))); |
547 return NULL; | 565 return NULL; |
548 } | 566 } |
549 | 567 |
550 CastUdpTransport* CastStreamingNativeHandler::GetUdpTransportOrThrow( | 568 CastUdpTransport* CastStreamingNativeHandler::GetUdpTransportOrThrow( |
551 int transport_id) const { | 569 int transport_id) const { |
552 UdpTransportMap::const_iterator iter = udp_transport_map_.find( | 570 UdpTransportMap::const_iterator iter = udp_transport_map_.find( |
553 transport_id); | 571 transport_id); |
554 if (iter != udp_transport_map_.end()) | 572 if (iter != udp_transport_map_.end()) |
555 return iter->second.get(); | 573 return iter->second.get(); |
556 v8::Isolate* isolate = context()->v8_context()->GetIsolate(); | 574 v8::Isolate* isolate = context()->v8_context()->GetIsolate(); |
557 isolate->ThrowException(v8::Exception::RangeError( | 575 isolate->ThrowException(v8::Exception::RangeError( |
558 v8::String::NewFromUtf8(isolate, kUdpTransportNotFound))); | 576 v8::String::NewFromUtf8(isolate, kUdpTransportNotFound))); |
559 return NULL; | 577 return NULL; |
560 } | 578 } |
561 | 579 |
562 } // namespace extensions | 580 } // namespace extensions |
OLD | NEW |