| OLD | NEW | 
|---|
| 1 // Copyright 2007-2009 the V8 project authors. All rights reserved. | 1 // Copyright 2007-2009 the V8 project authors. All rights reserved. | 
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without | 
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are | 
| 4 // met: | 4 // met: | 
| 5 // | 5 // | 
| 6 //     * Redistributions of source code must retain the above copyright | 6 //     * Redistributions of source code must retain the above copyright | 
| 7 //       notice, this list of conditions and the following disclaimer. | 7 //       notice, this list of conditions and the following disclaimer. | 
| 8 //     * Redistributions in binary form must reproduce the above | 8 //     * Redistributions in binary form must reproduce the above | 
| 9 //       copyright notice, this list of conditions and the following | 9 //       copyright notice, this list of conditions and the following | 
| 10 //       disclaimer in the documentation and/or other materials provided | 10 //       disclaimer in the documentation and/or other materials provided | 
| (...skipping 5291 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 5302   // the global object for env2 which has the same security token as env1. | 5302   // the global object for env2 which has the same security token as env1. | 
| 5303   result = CompileRun("other.p"); | 5303   result = CompileRun("other.p"); | 
| 5304   CHECK(result->IsInt32()); | 5304   CHECK(result->IsInt32()); | 
| 5305   CHECK_EQ(42, result->Int32Value()); | 5305   CHECK_EQ(42, result->Int32Value()); | 
| 5306 | 5306 | 
| 5307   env2.Dispose(); | 5307   env2.Dispose(); | 
| 5308   env3.Dispose(); | 5308   env3.Dispose(); | 
| 5309 } | 5309 } | 
| 5310 | 5310 | 
| 5311 | 5311 | 
|  | 5312 static bool allowed_access_type[v8::ACCESS_KEYS + 1] = { false }; | 
| 5312 static bool NamedAccessBlocker(Local<v8::Object> global, | 5313 static bool NamedAccessBlocker(Local<v8::Object> global, | 
| 5313                                Local<Value> name, | 5314                                Local<Value> name, | 
| 5314                                v8::AccessType type, | 5315                                v8::AccessType type, | 
| 5315                                Local<Value> data) { | 5316                                Local<Value> data) { | 
| 5316   return Context::GetCurrent()->Global()->Equals(global); | 5317   return Context::GetCurrent()->Global()->Equals(global) || | 
|  | 5318       allowed_access_type[type]; | 
| 5317 } | 5319 } | 
| 5318 | 5320 | 
| 5319 | 5321 | 
| 5320 static bool IndexedAccessBlocker(Local<v8::Object> global, | 5322 static bool IndexedAccessBlocker(Local<v8::Object> global, | 
| 5321                                  uint32_t key, | 5323                                  uint32_t key, | 
| 5322                                  v8::AccessType type, | 5324                                  v8::AccessType type, | 
| 5323                                  Local<Value> data) { | 5325                                  Local<Value> data) { | 
| 5324   return Context::GetCurrent()->Global()->Equals(global); | 5326   return Context::GetCurrent()->Global()->Equals(global) || | 
|  | 5327       allowed_access_type[type]; | 
| 5325 } | 5328 } | 
| 5326 | 5329 | 
| 5327 | 5330 | 
| 5328 static int g_echo_value = -1; | 5331 static int g_echo_value = -1; | 
| 5329 static v8::Handle<Value> EchoGetter(Local<String> name, | 5332 static v8::Handle<Value> EchoGetter(Local<String> name, | 
| 5330                                     const AccessorInfo& info) { | 5333                                     const AccessorInfo& info) { | 
| 5331   return v8_num(g_echo_value); | 5334   return v8_num(g_echo_value); | 
| 5332 } | 5335 } | 
| 5333 | 5336 | 
| 5334 | 5337 | 
| (...skipping 11 matching lines...) Expand all  Loading... | 
| 5346   return v8::Undefined(); | 5349   return v8::Undefined(); | 
| 5347 } | 5350 } | 
| 5348 | 5351 | 
| 5349 | 5352 | 
| 5350 static void UnreachableSetter(Local<String>, Local<Value>, | 5353 static void UnreachableSetter(Local<String>, Local<Value>, | 
| 5351                               const AccessorInfo&) { | 5354                               const AccessorInfo&) { | 
| 5352   CHECK(false);  // This function should nto be called. | 5355   CHECK(false);  // This function should nto be called. | 
| 5353 } | 5356 } | 
| 5354 | 5357 | 
| 5355 | 5358 | 
| 5356 THREADED_TEST(AccessControl) { | 5359 TEST(AccessControl) { | 
| 5357   v8::HandleScope handle_scope; | 5360   v8::HandleScope handle_scope; | 
| 5358   v8::Handle<v8::ObjectTemplate> global_template = v8::ObjectTemplate::New(); | 5361   v8::Handle<v8::ObjectTemplate> global_template = v8::ObjectTemplate::New(); | 
| 5359 | 5362 | 
| 5360   global_template->SetAccessCheckCallbacks(NamedAccessBlocker, | 5363   global_template->SetAccessCheckCallbacks(NamedAccessBlocker, | 
| 5361                                            IndexedAccessBlocker); | 5364                                            IndexedAccessBlocker); | 
| 5362 | 5365 | 
| 5363   // Add an accessor accessible by cross-domain JS code. | 5366   // Add an accessor accessible by cross-domain JS code. | 
| 5364   global_template->SetAccessor( | 5367   global_template->SetAccessor( | 
| 5365       v8_str("accessible_prop"), | 5368       v8_str("accessible_prop"), | 
| 5366       EchoGetter, EchoSetter, | 5369       EchoGetter, EchoSetter, | 
| 5367       v8::Handle<Value>(), | 5370       v8::Handle<Value>(), | 
| 5368       v8::AccessControl(v8::ALL_CAN_READ | v8::ALL_CAN_WRITE)); | 5371       v8::AccessControl(v8::ALL_CAN_READ | v8::ALL_CAN_WRITE)); | 
| 5369 | 5372 | 
| 5370   // Add an accessor that is not accessible by cross-domain JS code. | 5373   // Add an accessor that is not accessible by cross-domain JS code. | 
| 5371   global_template->SetAccessor(v8_str("blocked_prop"), | 5374   global_template->SetAccessor(v8_str("blocked_prop"), | 
| 5372                                UnreachableGetter, UnreachableSetter, | 5375                                UnreachableGetter, UnreachableSetter, | 
| 5373                                v8::Handle<Value>(), | 5376                                v8::Handle<Value>(), | 
| 5374                                v8::DEFAULT); | 5377                                v8::DEFAULT); | 
| 5375 | 5378 | 
| 5376   // Create an environment | 5379   // Create an environment | 
| 5377   v8::Persistent<Context> context0 = Context::New(NULL, global_template); | 5380   v8::Persistent<Context> context0 = Context::New(NULL, global_template); | 
| 5378   context0->Enter(); | 5381   context0->Enter(); | 
| 5379 | 5382 | 
| 5380   v8::Handle<v8::Object> global0 = context0->Global(); | 5383   v8::Handle<v8::Object> global0 = context0->Global(); | 
| 5381 | 5384 | 
|  | 5385   // Define a property with JS getter and setter. | 
|  | 5386   CompileRun( | 
|  | 5387       "function getter() { return 'getter'; };\n" | 
|  | 5388       "function setter() { return 'setter'; }\n" | 
|  | 5389       "Object.defineProperty(this, 'js_accessor_p', {get:getter, set:setter})"); | 
|  | 5390 | 
|  | 5391   Local<Value> getter = global0->Get(v8_str("getter")); | 
|  | 5392   Local<Value> setter = global0->Get(v8_str("setter")); | 
|  | 5393 | 
|  | 5394   // And define normal element. | 
|  | 5395   global0->Set(239, v8_str("239")); | 
|  | 5396 | 
|  | 5397   // Define an element with JS getter and setter. | 
|  | 5398   CompileRun( | 
|  | 5399       "function el_getter() { return 'el_getter'; };\n" | 
|  | 5400       "function el_setter() { return 'el_setter'; };\n" | 
|  | 5401       "Object.defineProperty(this, '42', {get: el_getter, set: el_setter});"); | 
|  | 5402 | 
|  | 5403   Local<Value> el_getter = global0->Get(v8_str("el_getter")); | 
|  | 5404   Local<Value> el_setter = global0->Get(v8_str("el_setter")); | 
|  | 5405 | 
| 5382   v8::HandleScope scope1; | 5406   v8::HandleScope scope1; | 
| 5383 | 5407 | 
| 5384   v8::Persistent<Context> context1 = Context::New(); | 5408   v8::Persistent<Context> context1 = Context::New(); | 
| 5385   context1->Enter(); | 5409   context1->Enter(); | 
| 5386 | 5410 | 
| 5387   v8::Handle<v8::Object> global1 = context1->Global(); | 5411   v8::Handle<v8::Object> global1 = context1->Global(); | 
| 5388   global1->Set(v8_str("other"), global0); | 5412   global1->Set(v8_str("other"), global0); | 
| 5389 | 5413 | 
|  | 5414   // Access blocked property. | 
|  | 5415   CompileRun("other.blocked_prop = 1"); | 
|  | 5416 | 
|  | 5417   ExpectUndefined("other.blocked_prop"); | 
|  | 5418   ExpectUndefined( | 
|  | 5419       "Object.getOwnPropertyDescriptor(other, 'blocked_prop')"); | 
|  | 5420   ExpectFalse("propertyIsEnumerable.call(other, 'blocked_prop')"); | 
|  | 5421 | 
|  | 5422   // Enable ACCESS_HAS | 
|  | 5423   allowed_access_type[v8::ACCESS_HAS] = true; | 
|  | 5424   ExpectUndefined("other.blocked_prop"); | 
|  | 5425   // ... and now we can get the descriptor... | 
|  | 5426   ExpectUndefined( | 
|  | 5427       "Object.getOwnPropertyDescriptor(other, 'blocked_prop').value"); | 
|  | 5428   // ... and enumerate the property. | 
|  | 5429   ExpectTrue("propertyIsEnumerable.call(other, 'blocked_prop')"); | 
|  | 5430   allowed_access_type[v8::ACCESS_HAS] = false; | 
|  | 5431 | 
|  | 5432   // Access blocked element. | 
|  | 5433   CompileRun("other[239] = 1"); | 
|  | 5434 | 
|  | 5435   ExpectUndefined("other[239]"); | 
|  | 5436   ExpectUndefined("Object.getOwnPropertyDescriptor(other, '239')"); | 
|  | 5437   ExpectFalse("propertyIsEnumerable.call(other, '239')"); | 
|  | 5438 | 
|  | 5439   // Enable ACCESS_HAS | 
|  | 5440   allowed_access_type[v8::ACCESS_HAS] = true; | 
|  | 5441   ExpectUndefined("other[239]"); | 
|  | 5442   // ... and now we can get the descriptor... | 
|  | 5443   ExpectUndefined("Object.getOwnPropertyDescriptor(other, '239').value"); | 
|  | 5444   // ... and enumerate the property. | 
|  | 5445   ExpectTrue("propertyIsEnumerable.call(other, '239')"); | 
|  | 5446   allowed_access_type[v8::ACCESS_HAS] = false; | 
|  | 5447 | 
|  | 5448   // Access a property with JS accessor. | 
|  | 5449   CompileRun("other.js_accessor_p = 2"); | 
|  | 5450 | 
|  | 5451   ExpectUndefined("other.js_accessor_p"); | 
|  | 5452   ExpectUndefined( | 
|  | 5453       "Object.getOwnPropertyDescriptor(other, 'js_accessor_p')"); | 
|  | 5454 | 
|  | 5455   // Enable ACCESS_HAS. | 
|  | 5456   allowed_access_type[v8::ACCESS_HAS] = true; | 
|  | 5457   ExpectUndefined("other.js_accessor_p"); | 
|  | 5458   ExpectUndefined( | 
|  | 5459       "Object.getOwnPropertyDescriptor(other, 'js_accessor_p').get"); | 
|  | 5460   ExpectUndefined( | 
|  | 5461       "Object.getOwnPropertyDescriptor(other, 'js_accessor_p').set"); | 
|  | 5462   ExpectUndefined( | 
|  | 5463       "Object.getOwnPropertyDescriptor(other, 'js_accessor_p').value"); | 
|  | 5464   allowed_access_type[v8::ACCESS_HAS] = false; | 
|  | 5465 | 
|  | 5466   // Enable both ACCESS_HAS and ACCESS_GET. | 
|  | 5467   allowed_access_type[v8::ACCESS_HAS] = true; | 
|  | 5468   allowed_access_type[v8::ACCESS_GET] = true; | 
|  | 5469 | 
|  | 5470   ExpectString("other.js_accessor_p", "getter"); | 
|  | 5471   ExpectObject( | 
|  | 5472       "Object.getOwnPropertyDescriptor(other, 'js_accessor_p').get", getter); | 
|  | 5473   ExpectUndefined( | 
|  | 5474       "Object.getOwnPropertyDescriptor(other, 'js_accessor_p').set"); | 
|  | 5475   ExpectUndefined( | 
|  | 5476       "Object.getOwnPropertyDescriptor(other, 'js_accessor_p').value"); | 
|  | 5477 | 
|  | 5478   allowed_access_type[v8::ACCESS_GET] = false; | 
|  | 5479   allowed_access_type[v8::ACCESS_HAS] = false; | 
|  | 5480 | 
|  | 5481   // Enable both ACCESS_HAS and ACCESS_SET. | 
|  | 5482   allowed_access_type[v8::ACCESS_HAS] = true; | 
|  | 5483   allowed_access_type[v8::ACCESS_SET] = true; | 
|  | 5484 | 
|  | 5485   ExpectUndefined("other.js_accessor_p"); | 
|  | 5486   ExpectUndefined( | 
|  | 5487       "Object.getOwnPropertyDescriptor(other, 'js_accessor_p').get"); | 
|  | 5488   ExpectObject( | 
|  | 5489       "Object.getOwnPropertyDescriptor(other, 'js_accessor_p').set", setter); | 
|  | 5490   ExpectUndefined( | 
|  | 5491       "Object.getOwnPropertyDescriptor(other, 'js_accessor_p').value"); | 
|  | 5492 | 
|  | 5493   allowed_access_type[v8::ACCESS_SET] = false; | 
|  | 5494   allowed_access_type[v8::ACCESS_HAS] = false; | 
|  | 5495 | 
|  | 5496   // Enable both ACCESS_HAS, ACCESS_GET and ACCESS_SET. | 
|  | 5497   allowed_access_type[v8::ACCESS_HAS] = true; | 
|  | 5498   allowed_access_type[v8::ACCESS_GET] = true; | 
|  | 5499   allowed_access_type[v8::ACCESS_SET] = true; | 
|  | 5500 | 
|  | 5501   ExpectString("other.js_accessor_p", "getter"); | 
|  | 5502   ExpectObject( | 
|  | 5503       "Object.getOwnPropertyDescriptor(other, 'js_accessor_p').get", getter); | 
|  | 5504   ExpectObject( | 
|  | 5505       "Object.getOwnPropertyDescriptor(other, 'js_accessor_p').set", setter); | 
|  | 5506   ExpectUndefined( | 
|  | 5507       "Object.getOwnPropertyDescriptor(other, 'js_accessor_p').value"); | 
|  | 5508 | 
|  | 5509   allowed_access_type[v8::ACCESS_SET] = false; | 
|  | 5510   allowed_access_type[v8::ACCESS_GET] = false; | 
|  | 5511   allowed_access_type[v8::ACCESS_HAS] = false; | 
|  | 5512 | 
|  | 5513   // Access an element with JS accessor. | 
|  | 5514   CompileRun("other[42] = 2"); | 
|  | 5515 | 
|  | 5516   ExpectUndefined("other[42]"); | 
|  | 5517   ExpectUndefined("Object.getOwnPropertyDescriptor(other, '42')"); | 
|  | 5518 | 
|  | 5519   // Enable ACCESS_HAS. | 
|  | 5520   allowed_access_type[v8::ACCESS_HAS] = true; | 
|  | 5521   ExpectUndefined("other[42]"); | 
|  | 5522   ExpectUndefined("Object.getOwnPropertyDescriptor(other, '42').get"); | 
|  | 5523   ExpectUndefined("Object.getOwnPropertyDescriptor(other, '42').set"); | 
|  | 5524   ExpectUndefined("Object.getOwnPropertyDescriptor(other, '42').value"); | 
|  | 5525   allowed_access_type[v8::ACCESS_HAS] = false; | 
|  | 5526 | 
|  | 5527   // Enable both ACCESS_HAS and ACCESS_GET. | 
|  | 5528   allowed_access_type[v8::ACCESS_HAS] = true; | 
|  | 5529   allowed_access_type[v8::ACCESS_GET] = true; | 
|  | 5530 | 
|  | 5531   ExpectString("other[42]", "el_getter"); | 
|  | 5532   ExpectObject("Object.getOwnPropertyDescriptor(other, '42').get", el_getter); | 
|  | 5533   ExpectUndefined("Object.getOwnPropertyDescriptor(other, '42').set"); | 
|  | 5534   ExpectUndefined("Object.getOwnPropertyDescriptor(other, '42').value"); | 
|  | 5535 | 
|  | 5536   allowed_access_type[v8::ACCESS_GET] = false; | 
|  | 5537   allowed_access_type[v8::ACCESS_HAS] = false; | 
|  | 5538 | 
|  | 5539   // Enable both ACCESS_HAS and ACCESS_SET. | 
|  | 5540   allowed_access_type[v8::ACCESS_HAS] = true; | 
|  | 5541   allowed_access_type[v8::ACCESS_SET] = true; | 
|  | 5542 | 
|  | 5543   ExpectUndefined("other[42]"); | 
|  | 5544   ExpectUndefined("Object.getOwnPropertyDescriptor(other, '42').get"); | 
|  | 5545   ExpectObject("Object.getOwnPropertyDescriptor(other, '42').set", el_setter); | 
|  | 5546   ExpectUndefined("Object.getOwnPropertyDescriptor(other, '42').value"); | 
|  | 5547 | 
|  | 5548   allowed_access_type[v8::ACCESS_SET] = false; | 
|  | 5549   allowed_access_type[v8::ACCESS_HAS] = false; | 
|  | 5550 | 
|  | 5551   // Enable both ACCESS_HAS, ACCESS_GET and ACCESS_SET. | 
|  | 5552   allowed_access_type[v8::ACCESS_HAS] = true; | 
|  | 5553   allowed_access_type[v8::ACCESS_GET] = true; | 
|  | 5554   allowed_access_type[v8::ACCESS_SET] = true; | 
|  | 5555 | 
|  | 5556   ExpectString("other[42]", "el_getter"); | 
|  | 5557   ExpectObject("Object.getOwnPropertyDescriptor(other, '42').get", el_getter); | 
|  | 5558   ExpectObject("Object.getOwnPropertyDescriptor(other, '42').set", el_setter); | 
|  | 5559   ExpectUndefined("Object.getOwnPropertyDescriptor(other, '42').value"); | 
|  | 5560 | 
|  | 5561   allowed_access_type[v8::ACCESS_SET] = false; | 
|  | 5562   allowed_access_type[v8::ACCESS_GET] = false; | 
|  | 5563   allowed_access_type[v8::ACCESS_HAS] = false; | 
|  | 5564 | 
| 5390   v8::Handle<Value> value; | 5565   v8::Handle<Value> value; | 
| 5391 | 5566 | 
| 5392   // Access blocked property |  | 
| 5393   value = CompileRun("other.blocked_prop = 1"); |  | 
| 5394   value = CompileRun("other.blocked_prop"); |  | 
| 5395   CHECK(value->IsUndefined()); |  | 
| 5396 |  | 
| 5397   value = CompileRun( |  | 
| 5398       "Object.getOwnPropertyDescriptor(other, 'blocked_prop').value"); |  | 
| 5399   CHECK(value->IsUndefined()); |  | 
| 5400 |  | 
| 5401   value = CompileRun("propertyIsEnumerable.call(other, 'blocked_prop')"); |  | 
| 5402   CHECK(value->IsFalse()); |  | 
| 5403 |  | 
| 5404   // Access accessible property | 5567   // Access accessible property | 
| 5405   value = CompileRun("other.accessible_prop = 3"); | 5568   value = CompileRun("other.accessible_prop = 3"); | 
| 5406   CHECK(value->IsNumber()); | 5569   CHECK(value->IsNumber()); | 
| 5407   CHECK_EQ(3, value->Int32Value()); | 5570   CHECK_EQ(3, value->Int32Value()); | 
| 5408   CHECK_EQ(3, g_echo_value); | 5571   CHECK_EQ(3, g_echo_value); | 
| 5409 | 5572 | 
| 5410   value = CompileRun("other.accessible_prop"); | 5573   value = CompileRun("other.accessible_prop"); | 
| 5411   CHECK(value->IsNumber()); | 5574   CHECK(value->IsNumber()); | 
| 5412   CHECK_EQ(3, value->Int32Value()); | 5575   CHECK_EQ(3, value->Int32Value()); | 
| 5413 | 5576 | 
| (...skipping 6823 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 12237   v8::Context::Scope context_scope(context.local()); | 12400   v8::Context::Scope context_scope(context.local()); | 
| 12238 | 12401 | 
| 12239   v8::Handle<v8::ObjectTemplate> tmpl = v8::ObjectTemplate::New(); | 12402   v8::Handle<v8::ObjectTemplate> tmpl = v8::ObjectTemplate::New(); | 
| 12240   tmpl->SetNamedPropertyHandler(Getter, NULL, NULL, NULL, Enumerator); | 12403   tmpl->SetNamedPropertyHandler(Getter, NULL, NULL, NULL, Enumerator); | 
| 12241   context->Global()->Set(v8_str("o"), tmpl->NewInstance()); | 12404   context->Global()->Set(v8_str("o"), tmpl->NewInstance()); | 
| 12242   v8::Handle<v8::Array> result = v8::Handle<v8::Array>::Cast(CompileRun( | 12405   v8::Handle<v8::Array> result = v8::Handle<v8::Array>::Cast(CompileRun( | 
| 12243         "var result = []; for (var k in o) result.push(k); result")); | 12406         "var result = []; for (var k in o) result.push(k); result")); | 
| 12244   CHECK_EQ(1, result->Length()); | 12407   CHECK_EQ(1, result->Length()); | 
| 12245   CHECK_EQ(v8_str("universalAnswer"), result->Get(0)); | 12408   CHECK_EQ(v8_str("universalAnswer"), result->Get(0)); | 
| 12246 } | 12409 } | 
| OLD | NEW | 
|---|