mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-14 22:13:31 +00:00
bug 311892: Add some (awful, gross) checks. r=brendan
This commit is contained in:
parent
15edb5c281
commit
44834d9757
@ -1064,6 +1064,31 @@ CheckEvalAccess(JSContext *cx, JSObject *scopeobj, JSPrincipals *principals)
|
||||
return JS_TRUE;
|
||||
}
|
||||
|
||||
JSBool
|
||||
js_CheckScopeChainValidity(JSContext *cx, JSObject *scopeobj, const char *caller)
|
||||
{
|
||||
JSClass *clasp;
|
||||
JSExtendedClass *xclasp;
|
||||
|
||||
/* XXX This is an awful gross hack. */
|
||||
while (scopeobj) {
|
||||
clasp = OBJ_GET_CLASS(cx, scopeobj);
|
||||
if (clasp->flags & JSCLASS_IS_EXTENDED) {
|
||||
xclasp = (JSExtendedClass*)clasp;
|
||||
if (xclasp->innerObject &&
|
||||
xclasp->innerObject(cx, scopeobj) != scopeobj) {
|
||||
JS_ReportErrorNumber(cx, js_GetErrorMessage, NULL,
|
||||
JSMSG_BAD_INDIRECT_CALL, caller);
|
||||
return JS_FALSE;
|
||||
}
|
||||
}
|
||||
|
||||
scopeobj = OBJ_GET_PARENT(cx, scopeobj);
|
||||
}
|
||||
|
||||
return JS_TRUE;
|
||||
}
|
||||
|
||||
static JSBool
|
||||
obj_eval(JSContext *cx, JSObject *obj, uintN argc, jsval *argv, jsval *rval)
|
||||
{
|
||||
@ -1157,6 +1182,9 @@ obj_eval(JSContext *cx, JSObject *obj, uintN argc, jsval *argv, jsval *rval)
|
||||
if (!scopeobj)
|
||||
return JS_FALSE;
|
||||
|
||||
if (!js_CheckScopeChainValidity(cx, scopeobj, js_eval_str))
|
||||
return JS_FALSE;
|
||||
|
||||
str = JSVAL_TO_STRING(argv[0]);
|
||||
if (caller) {
|
||||
file = caller->script->filename;
|
||||
|
@ -488,6 +488,9 @@ js_GetRequiredSlot(JSContext *cx, JSObject *obj, uint32 slot);
|
||||
extern JSBool
|
||||
js_SetRequiredSlot(JSContext *cx, JSObject *obj, uint32 slot, jsval v);
|
||||
|
||||
extern JSBool
|
||||
js_CheckScopeChainValidity(JSContext *cx, JSObject *scopeobj, const char *caller);
|
||||
|
||||
JS_END_EXTERN_C
|
||||
|
||||
#endif /* jsobj_h___ */
|
||||
|
@ -64,6 +64,8 @@
|
||||
|
||||
#if JS_HAS_SCRIPT_OBJECT
|
||||
|
||||
static const char js_script_exec[] = "Script.prototype.exec";
|
||||
|
||||
#if JS_HAS_TOSOURCE
|
||||
static JSBool
|
||||
script_toSource(JSContext *cx, JSObject *obj, uintN argc, jsval *argv,
|
||||
@ -310,6 +312,9 @@ script_exec(JSContext *cx, JSObject *obj, uintN argc, jsval *argv, jsval *rval)
|
||||
if (!scopeobj)
|
||||
return JS_FALSE;
|
||||
|
||||
if (!js_CheckScopeChainValidity(cx, scopeobj, js_script_exec))
|
||||
return JS_FALSE;
|
||||
|
||||
/* Belt-and-braces: check that this script object has access to scopeobj. */
|
||||
principals = script->principals;
|
||||
rt = cx->runtime;
|
||||
@ -319,7 +324,7 @@ script_exec(JSContext *cx, JSObject *obj, uintN argc, jsval *argv, jsval *rval)
|
||||
!principals->subsume(principals, scopePrincipals)) {
|
||||
JS_ReportErrorNumber(cx, js_GetErrorMessage, NULL,
|
||||
JSMSG_BAD_INDIRECT_CALL,
|
||||
"Script.prototype.exec");
|
||||
js_script_exec);
|
||||
return JS_FALSE;
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user