| 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 "ppapi/proxy/ppb_instance_proxy.h" | 5 #include "ppapi/proxy/ppb_instance_proxy.h" |
| 6 | 6 |
| 7 #include "base/memory/ref_counted.h" | 7 #include "base/memory/ref_counted.h" |
| 8 #include "base/stl_util.h" |
| 8 #include "build/build_config.h" | 9 #include "build/build_config.h" |
| 9 #include "media/base/limits.h" | 10 #include "media/base/limits.h" |
| 10 #include "ppapi/c/pp_errors.h" | 11 #include "ppapi/c/pp_errors.h" |
| 11 #include "ppapi/c/pp_time.h" | 12 #include "ppapi/c/pp_time.h" |
| 12 #include "ppapi/c/pp_var.h" | 13 #include "ppapi/c/pp_var.h" |
| 13 #include "ppapi/c/ppb_audio_config.h" | 14 #include "ppapi/c/ppb_audio_config.h" |
| 14 #include "ppapi/c/ppb_instance.h" | 15 #include "ppapi/c/ppb_instance.h" |
| 15 #include "ppapi/c/ppb_messaging.h" | 16 #include "ppapi/c/ppb_messaging.h" |
| 16 #include "ppapi/c/ppb_mouse_lock.h" | 17 #include "ppapi/c/ppb_mouse_lock.h" |
| 17 #include "ppapi/c/private/pp_content_decryptor.h" | 18 #include "ppapi/c/private/pp_content_decryptor.h" |
| (...skipping 157 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 175 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_DocumentCanAccessDocument, | 176 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_DocumentCanAccessDocument, |
| 176 OnHostMsgDocumentCanAccessDocument) | 177 OnHostMsgDocumentCanAccessDocument) |
| 177 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_GetPluginInstanceURL, | 178 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_GetPluginInstanceURL, |
| 178 OnHostMsgGetPluginInstanceURL) | 179 OnHostMsgGetPluginInstanceURL) |
| 179 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_GetPluginReferrerURL, | 180 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_GetPluginReferrerURL, |
| 180 OnHostMsgGetPluginReferrerURL) | 181 OnHostMsgGetPluginReferrerURL) |
| 181 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_PromiseResolved, | 182 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_PromiseResolved, |
| 182 OnHostMsgPromiseResolved) | 183 OnHostMsgPromiseResolved) |
| 183 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_PromiseResolvedWithSession, | 184 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_PromiseResolvedWithSession, |
| 184 OnHostMsgPromiseResolvedWithSession) | 185 OnHostMsgPromiseResolvedWithSession) |
| 185 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_PromiseResolvedWithKeyIds, | |
| 186 OnHostMsgPromiseResolvedWithKeyIds) | |
| 187 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_PromiseRejected, | 186 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_PromiseRejected, |
| 188 OnHostMsgPromiseRejected) | 187 OnHostMsgPromiseRejected) |
| 189 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_SessionMessage, | 188 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_SessionMessage, |
| 190 OnHostMsgSessionMessage) | 189 OnHostMsgSessionMessage) |
| 191 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_SessionKeysChange, | 190 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_SessionKeysChange, |
| 192 OnHostMsgSessionKeysChange) | 191 OnHostMsgSessionKeysChange) |
| 193 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_SessionExpirationChange, | 192 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_SessionExpirationChange, |
| 194 OnHostMsgSessionExpirationChange) | 193 OnHostMsgSessionExpirationChange) |
| 195 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_SessionReady, | |
| 196 OnHostMsgSessionReady) | |
| 197 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_SessionClosed, | 194 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_SessionClosed, |
| 198 OnHostMsgSessionClosed) | 195 OnHostMsgSessionClosed) |
| 199 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_SessionError, | 196 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_SessionError, |
| 200 OnHostMsgSessionError) | 197 OnHostMsgSessionError) |
| 201 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_DeliverBlock, | 198 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_DeliverBlock, |
| 202 OnHostMsgDeliverBlock) | 199 OnHostMsgDeliverBlock) |
| 203 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_DecoderInitializeDone, | 200 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_DecoderInitializeDone, |
| 204 OnHostMsgDecoderInitializeDone) | 201 OnHostMsgDecoderInitializeDone) |
| 205 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_DecoderDeinitializeDone, | 202 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBInstance_DecoderDeinitializeDone, |
| 206 OnHostMsgDecoderDeinitializeDone) | 203 OnHostMsgDecoderDeinitializeDone) |
| (...skipping 372 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 579 void PPB_Instance_Proxy::PromiseResolvedWithSession(PP_Instance instance, | 576 void PPB_Instance_Proxy::PromiseResolvedWithSession(PP_Instance instance, |
| 580 uint32 promise_id, | 577 uint32 promise_id, |
| 581 PP_Var web_session_id_var) { | 578 PP_Var web_session_id_var) { |
| 582 dispatcher()->Send(new PpapiHostMsg_PPBInstance_PromiseResolvedWithSession( | 579 dispatcher()->Send(new PpapiHostMsg_PPBInstance_PromiseResolvedWithSession( |
| 583 API_ID_PPB_INSTANCE, | 580 API_ID_PPB_INSTANCE, |
| 584 instance, | 581 instance, |
| 585 promise_id, | 582 promise_id, |
| 586 SerializedVarSendInput(dispatcher(), web_session_id_var))); | 583 SerializedVarSendInput(dispatcher(), web_session_id_var))); |
| 587 } | 584 } |
| 588 | 585 |
| 589 void PPB_Instance_Proxy::PromiseResolvedWithKeyIds(PP_Instance instance, | |
| 590 uint32 promise_id, | |
| 591 PP_Var key_ids_var) { | |
| 592 ArrayVar* key_ids_array = ArrayVar::FromPPVar(key_ids_var); | |
| 593 if (!key_ids_array || | |
| 594 key_ids_array->GetLength() > media::limits::kMaxKeyIds) { | |
| 595 NOTREACHED(); | |
| 596 return; | |
| 597 } | |
| 598 | |
| 599 std::vector<std::vector<uint8_t> > key_ids; | |
| 600 for (size_t i = 0; i < key_ids_array->GetLength(); ++i) { | |
| 601 ArrayBufferVar* key_id = ArrayBufferVar::FromPPVar(key_ids_array->Get(i)); | |
| 602 if (!key_id || key_id->ByteLength() < media::limits::kMinKeyIdLength || | |
| 603 key_id->ByteLength() > media::limits::kMaxKeyIdLength) { | |
| 604 NOTREACHED(); | |
| 605 continue; | |
| 606 } | |
| 607 | |
| 608 const uint8_t* key_id_ptr = static_cast<const uint8_t*>(key_id->Map()); | |
| 609 const uint32_t key_id_size = key_id->ByteLength(); | |
| 610 std::vector<uint8_t> key_id_vector(key_id_ptr, key_id_ptr + key_id_size); | |
| 611 key_ids.push_back(key_id_vector); | |
| 612 } | |
| 613 | |
| 614 dispatcher()->Send(new PpapiHostMsg_PPBInstance_PromiseResolvedWithKeyIds( | |
| 615 API_ID_PPB_INSTANCE, instance, promise_id, key_ids)); | |
| 616 } | |
| 617 | |
| 618 void PPB_Instance_Proxy::PromiseRejected(PP_Instance instance, | 586 void PPB_Instance_Proxy::PromiseRejected(PP_Instance instance, |
| 619 uint32 promise_id, | 587 uint32 promise_id, |
| 620 PP_CdmExceptionCode exception_code, | 588 PP_CdmExceptionCode exception_code, |
| 621 uint32 system_code, | 589 uint32 system_code, |
| 622 PP_Var error_description_var) { | 590 PP_Var error_description_var) { |
| 623 dispatcher()->Send(new PpapiHostMsg_PPBInstance_PromiseRejected( | 591 dispatcher()->Send(new PpapiHostMsg_PPBInstance_PromiseRejected( |
| 624 API_ID_PPB_INSTANCE, | 592 API_ID_PPB_INSTANCE, |
| 625 instance, | 593 instance, |
| 626 promise_id, | 594 promise_id, |
| 627 exception_code, | 595 exception_code, |
| 628 system_code, | 596 system_code, |
| 629 SerializedVarSendInput(dispatcher(), error_description_var))); | 597 SerializedVarSendInput(dispatcher(), error_description_var))); |
| 630 } | 598 } |
| 631 | 599 |
| 632 void PPB_Instance_Proxy::SessionMessage(PP_Instance instance, | 600 void PPB_Instance_Proxy::SessionMessage(PP_Instance instance, |
| 633 PP_Var web_session_id_var, | 601 PP_Var web_session_id_var, |
| 634 PP_Var message_var, | 602 PP_CdmMessageType message_type, |
| 635 PP_Var destination_url_var) { | 603 PP_Var message_var) { |
| 636 dispatcher()->Send(new PpapiHostMsg_PPBInstance_SessionMessage( | 604 dispatcher()->Send(new PpapiHostMsg_PPBInstance_SessionMessage( |
| 637 API_ID_PPB_INSTANCE, | 605 API_ID_PPB_INSTANCE, instance, |
| 638 instance, | 606 SerializedVarSendInput(dispatcher(), web_session_id_var), message_type, |
| 639 SerializedVarSendInput(dispatcher(), web_session_id_var), | 607 SerializedVarSendInput(dispatcher(), message_var))); |
| 640 SerializedVarSendInput(dispatcher(), message_var), | |
| 641 SerializedVarSendInput(dispatcher(), destination_url_var))); | |
| 642 } | 608 } |
| 643 | 609 |
| 644 void PPB_Instance_Proxy::SessionKeysChange(PP_Instance instance, | 610 void PPB_Instance_Proxy::SessionKeysChange( |
| 645 PP_Var web_session_id_var, | 611 PP_Instance instance, |
| 646 PP_Bool has_additional_usable_key) { | 612 PP_Var web_session_id_var, |
| 613 PP_Bool has_additional_usable_key, |
| 614 uint32_t key_count, |
| 615 const struct PP_KeyInformation key_information[]) { |
| 647 StringVar* session_id = StringVar::FromPPVar(web_session_id_var); | 616 StringVar* session_id = StringVar::FromPPVar(web_session_id_var); |
| 648 if (!session_id || | 617 if (!session_id || |
| 649 session_id->value().length() > media::limits::kMaxWebSessionIdLength) { | 618 session_id->value().length() > media::limits::kMaxWebSessionIdLength) { |
| 650 NOTREACHED(); | 619 NOTREACHED(); |
| 651 return; | 620 return; |
| 652 } | 621 } |
| 653 | 622 |
| 623 if (key_count > media::limits::kMaxKeyIds) { |
| 624 NOTREACHED(); |
| 625 return; |
| 626 } |
| 627 |
| 654 dispatcher()->Send(new PpapiHostMsg_PPBInstance_SessionKeysChange( | 628 dispatcher()->Send(new PpapiHostMsg_PPBInstance_SessionKeysChange( |
| 655 API_ID_PPB_INSTANCE, | 629 API_ID_PPB_INSTANCE, instance, session_id->value(), |
| 656 instance, | 630 has_additional_usable_key, |
| 657 session_id->value(), | 631 std::vector<PP_KeyInformation>(key_information, |
| 658 has_additional_usable_key)); | 632 key_information + key_count))); |
| 659 } | 633 } |
| 660 | 634 |
| 661 void PPB_Instance_Proxy::SessionExpirationChange(PP_Instance instance, | 635 void PPB_Instance_Proxy::SessionExpirationChange(PP_Instance instance, |
| 662 PP_Var web_session_id_var, | 636 PP_Var web_session_id_var, |
| 663 PP_Time new_expiry_time) { | 637 PP_Time new_expiry_time) { |
| 664 StringVar* session_id = StringVar::FromPPVar(web_session_id_var); | 638 StringVar* session_id = StringVar::FromPPVar(web_session_id_var); |
| 665 if (!session_id || | 639 if (!session_id || |
| 666 session_id->value().length() > media::limits::kMaxWebSessionIdLength) { | 640 session_id->value().length() > media::limits::kMaxWebSessionIdLength) { |
| 667 NOTREACHED(); | 641 NOTREACHED(); |
| 668 return; | 642 return; |
| 669 } | 643 } |
| 670 | 644 |
| 671 dispatcher()->Send(new PpapiHostMsg_PPBInstance_SessionExpirationChange( | 645 dispatcher()->Send(new PpapiHostMsg_PPBInstance_SessionExpirationChange( |
| 672 API_ID_PPB_INSTANCE, instance, session_id->value(), new_expiry_time)); | 646 API_ID_PPB_INSTANCE, instance, session_id->value(), new_expiry_time)); |
| 673 } | 647 } |
| 674 | 648 |
| 675 void PPB_Instance_Proxy::SessionReady(PP_Instance instance, | |
| 676 PP_Var web_session_id_var) { | |
| 677 dispatcher()->Send(new PpapiHostMsg_PPBInstance_SessionReady( | |
| 678 API_ID_PPB_INSTANCE, | |
| 679 instance, | |
| 680 SerializedVarSendInput(dispatcher(), web_session_id_var))); | |
| 681 } | |
| 682 | |
| 683 void PPB_Instance_Proxy::SessionClosed(PP_Instance instance, | 649 void PPB_Instance_Proxy::SessionClosed(PP_Instance instance, |
| 684 PP_Var web_session_id_var) { | 650 PP_Var web_session_id_var) { |
| 685 dispatcher()->Send(new PpapiHostMsg_PPBInstance_SessionClosed( | 651 dispatcher()->Send(new PpapiHostMsg_PPBInstance_SessionClosed( |
| 686 API_ID_PPB_INSTANCE, | 652 API_ID_PPB_INSTANCE, |
| 687 instance, | 653 instance, |
| 688 SerializedVarSendInput(dispatcher(), web_session_id_var))); | 654 SerializedVarSendInput(dispatcher(), web_session_id_var))); |
| 689 } | 655 } |
| 690 | 656 |
| 691 void PPB_Instance_Proxy::SessionError(PP_Instance instance, | 657 void PPB_Instance_Proxy::SessionError(PP_Instance instance, |
| 692 PP_Var web_session_id_var, | 658 PP_Var web_session_id_var, |
| (...skipping 586 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1279 SerializedVarReceiveInput web_session_id) { | 1245 SerializedVarReceiveInput web_session_id) { |
| 1280 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) | 1246 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) |
| 1281 return; | 1247 return; |
| 1282 EnterInstanceNoLock enter(instance); | 1248 EnterInstanceNoLock enter(instance); |
| 1283 if (enter.succeeded()) { | 1249 if (enter.succeeded()) { |
| 1284 enter.functions()->PromiseResolvedWithSession( | 1250 enter.functions()->PromiseResolvedWithSession( |
| 1285 instance, promise_id, web_session_id.Get(dispatcher())); | 1251 instance, promise_id, web_session_id.Get(dispatcher())); |
| 1286 } | 1252 } |
| 1287 } | 1253 } |
| 1288 | 1254 |
| 1289 void PPB_Instance_Proxy::OnHostMsgPromiseResolvedWithKeyIds( | |
| 1290 PP_Instance instance, | |
| 1291 uint32_t promise_id, | |
| 1292 const std::vector<std::vector<uint8_t> >& key_ids) { | |
| 1293 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) | |
| 1294 return; | |
| 1295 if (key_ids.size() > media::limits::kMaxKeyIds) { | |
| 1296 NOTREACHED(); | |
| 1297 return; | |
| 1298 } | |
| 1299 | |
| 1300 scoped_refptr<ArrayVar> key_ids_array = new ArrayVar(); | |
| 1301 key_ids_array->SetLength(key_ids.size()); | |
| 1302 for (size_t i = 0; i < key_ids.size(); ++i) { | |
| 1303 const std::vector<uint8_t>& entry = key_ids[i]; | |
| 1304 if (entry.size() < media::limits::kMinKeyIdLength || | |
| 1305 entry.size() > media::limits::kMaxKeyIdLength) { | |
| 1306 NOTREACHED(); | |
| 1307 continue; | |
| 1308 } | |
| 1309 key_ids_array->Set( | |
| 1310 i, | |
| 1311 PpapiGlobals::Get()->GetVarTracker()->MakeArrayBufferPPVar(entry.size(), | |
| 1312 &entry[0])); | |
| 1313 } | |
| 1314 | |
| 1315 EnterInstanceNoLock enter(instance); | |
| 1316 if (enter.succeeded()) { | |
| 1317 ScopedPPVar key_ids_var(ScopedPPVar::PassRef(), key_ids_array->GetPPVar()); | |
| 1318 enter.functions()->PromiseResolvedWithKeyIds( | |
| 1319 instance, promise_id, key_ids_var.get()); | |
| 1320 } | |
| 1321 } | |
| 1322 | |
| 1323 void PPB_Instance_Proxy::OnHostMsgPromiseRejected( | 1255 void PPB_Instance_Proxy::OnHostMsgPromiseRejected( |
| 1324 PP_Instance instance, | 1256 PP_Instance instance, |
| 1325 uint32_t promise_id, | 1257 uint32_t promise_id, |
| 1326 PP_CdmExceptionCode exception_code, | 1258 PP_CdmExceptionCode exception_code, |
| 1327 uint32_t system_code, | 1259 uint32_t system_code, |
| 1328 SerializedVarReceiveInput error_description) { | 1260 SerializedVarReceiveInput error_description) { |
| 1329 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) | 1261 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) |
| 1330 return; | 1262 return; |
| 1331 EnterInstanceNoLock enter(instance); | 1263 EnterInstanceNoLock enter(instance); |
| 1332 if (enter.succeeded()) { | 1264 if (enter.succeeded()) { |
| 1333 enter.functions()->PromiseRejected(instance, | 1265 enter.functions()->PromiseRejected(instance, |
| 1334 promise_id, | 1266 promise_id, |
| 1335 exception_code, | 1267 exception_code, |
| 1336 system_code, | 1268 system_code, |
| 1337 error_description.Get(dispatcher())); | 1269 error_description.Get(dispatcher())); |
| 1338 } | 1270 } |
| 1339 } | 1271 } |
| 1340 | 1272 |
| 1341 void PPB_Instance_Proxy::OnHostMsgSessionMessage( | 1273 void PPB_Instance_Proxy::OnHostMsgSessionMessage( |
| 1342 PP_Instance instance, | 1274 PP_Instance instance, |
| 1343 SerializedVarReceiveInput web_session_id, | 1275 SerializedVarReceiveInput web_session_id, |
| 1344 SerializedVarReceiveInput message, | 1276 PP_CdmMessageType message_type, |
| 1345 SerializedVarReceiveInput destination_url) { | 1277 SerializedVarReceiveInput message) { |
| 1346 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) | 1278 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) |
| 1347 return; | 1279 return; |
| 1348 EnterInstanceNoLock enter(instance); | 1280 EnterInstanceNoLock enter(instance); |
| 1349 if (enter.succeeded()) { | 1281 if (enter.succeeded()) { |
| 1350 enter.functions()->SessionMessage(instance, | 1282 enter.functions()->SessionMessage(instance, |
| 1351 web_session_id.Get(dispatcher()), | 1283 web_session_id.Get(dispatcher()), |
| 1352 message.Get(dispatcher()), | 1284 message_type, message.Get(dispatcher())); |
| 1353 destination_url.Get(dispatcher())); | |
| 1354 } | 1285 } |
| 1355 } | 1286 } |
| 1356 | 1287 |
| 1357 void PPB_Instance_Proxy::OnHostMsgSessionKeysChange( | 1288 void PPB_Instance_Proxy::OnHostMsgSessionKeysChange( |
| 1358 PP_Instance instance, | 1289 PP_Instance instance, |
| 1359 const std::string& web_session_id, | 1290 const std::string& web_session_id, |
| 1360 PP_Bool has_additional_usable_key) { | 1291 PP_Bool has_additional_usable_key, |
| 1292 const std::vector<PP_KeyInformation>& key_information) { |
| 1361 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) | 1293 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) |
| 1362 return; | 1294 return; |
| 1295 |
| 1296 if (key_information.size() > media::limits::kMaxKeyIds) { |
| 1297 NOTREACHED(); |
| 1298 return; |
| 1299 } |
| 1300 |
| 1363 EnterInstanceNoLock enter(instance); | 1301 EnterInstanceNoLock enter(instance); |
| 1364 if (enter.succeeded()) { | 1302 if (enter.succeeded()) { |
| 1365 ScopedPPVar web_session_id_var(ScopedPPVar::PassRef(), | 1303 ScopedPPVar web_session_id_var(ScopedPPVar::PassRef(), |
| 1366 StringVar::StringToPPVar(web_session_id)); | 1304 StringVar::StringToPPVar(web_session_id)); |
| 1367 enter.functions()->SessionKeysChange( | 1305 enter.functions()->SessionKeysChange( |
| 1368 instance, web_session_id_var.get(), has_additional_usable_key); | 1306 instance, web_session_id_var.get(), has_additional_usable_key, |
| 1307 key_information.size(), vector_as_array(&key_information)); |
| 1369 } | 1308 } |
| 1370 } | 1309 } |
| 1371 | 1310 |
| 1372 void PPB_Instance_Proxy::OnHostMsgSessionExpirationChange( | 1311 void PPB_Instance_Proxy::OnHostMsgSessionExpirationChange( |
| 1373 PP_Instance instance, | 1312 PP_Instance instance, |
| 1374 const std::string& web_session_id, | 1313 const std::string& web_session_id, |
| 1375 PP_Time new_expiry_time) { | 1314 PP_Time new_expiry_time) { |
| 1376 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) | 1315 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) |
| 1377 return; | 1316 return; |
| 1378 EnterInstanceNoLock enter(instance); | 1317 EnterInstanceNoLock enter(instance); |
| 1379 if (enter.succeeded()) { | 1318 if (enter.succeeded()) { |
| 1380 ScopedPPVar web_session_id_var(ScopedPPVar::PassRef(), | 1319 ScopedPPVar web_session_id_var(ScopedPPVar::PassRef(), |
| 1381 StringVar::StringToPPVar(web_session_id)); | 1320 StringVar::StringToPPVar(web_session_id)); |
| 1382 enter.functions()->SessionExpirationChange( | 1321 enter.functions()->SessionExpirationChange( |
| 1383 instance, web_session_id_var.get(), new_expiry_time); | 1322 instance, web_session_id_var.get(), new_expiry_time); |
| 1384 } | 1323 } |
| 1385 } | 1324 } |
| 1386 | 1325 |
| 1387 void PPB_Instance_Proxy::OnHostMsgSessionReady( | |
| 1388 PP_Instance instance, | |
| 1389 SerializedVarReceiveInput web_session_id) { | |
| 1390 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) | |
| 1391 return; | |
| 1392 EnterInstanceNoLock enter(instance); | |
| 1393 if (enter.succeeded()) { | |
| 1394 enter.functions()->SessionReady(instance, web_session_id.Get(dispatcher())); | |
| 1395 } | |
| 1396 } | |
| 1397 | |
| 1398 void PPB_Instance_Proxy::OnHostMsgSessionClosed( | 1326 void PPB_Instance_Proxy::OnHostMsgSessionClosed( |
| 1399 PP_Instance instance, | 1327 PP_Instance instance, |
| 1400 SerializedVarReceiveInput web_session_id) { | 1328 SerializedVarReceiveInput web_session_id) { |
| 1401 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) | 1329 if (!dispatcher()->permissions().HasPermission(PERMISSION_PRIVATE)) |
| 1402 return; | 1330 return; |
| 1403 EnterInstanceNoLock enter(instance); | 1331 EnterInstanceNoLock enter(instance); |
| 1404 if (enter.succeeded()) { | 1332 if (enter.succeeded()) { |
| 1405 enter.functions()->SessionClosed(instance, | 1333 enter.functions()->SessionClosed(instance, |
| 1406 web_session_id.Get(dispatcher())); | 1334 web_session_id.Get(dispatcher())); |
| 1407 } | 1335 } |
| (...skipping 180 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1588 PP_Instance instance) { | 1516 PP_Instance instance) { |
| 1589 InstanceData* data = static_cast<PluginDispatcher*>(dispatcher())-> | 1517 InstanceData* data = static_cast<PluginDispatcher*>(dispatcher())-> |
| 1590 GetInstanceData(instance); | 1518 GetInstanceData(instance); |
| 1591 if (!data) | 1519 if (!data) |
| 1592 return; // Instance was probably deleted. | 1520 return; // Instance was probably deleted. |
| 1593 data->should_do_request_surrounding_text = false; | 1521 data->should_do_request_surrounding_text = false; |
| 1594 } | 1522 } |
| 1595 | 1523 |
| 1596 } // namespace proxy | 1524 } // namespace proxy |
| 1597 } // namespace ppapi | 1525 } // namespace ppapi |
| OLD | NEW |