The attached patch changes open_basedir from PHP_INI_SYSTEM to PHP_INI_ALL.
Wait now... let me finish. It introduces a custom INI modification handler for open_basedir which allows the option to be set during Startup and Shutdown (PHP_INI_SYSTEM contexts) normally, then for other contexts (Activate/Deactivate {PERDIR} and Runtime) it checks the inbound settings against the current value and applies some logic: If open_basedir hasn't been set yet: It allows any new setting to be applied (unrestrictive to restrictive) If open_basedir is set, then it checks to see if each component of the new setting would be allowable under the rules of the old setting, if they're all good, it allows it. If any component makes the basedir check less restrictive, it fails (diallows) the change. (less-restrictive to more-restrictive). The advantage of doing this is that package authors and/or users of shared hosting who may not have access to making their settings more restrictive can avoid most simple FS inspection attacks caused by buggy script code by adding a single ini_set(basedir(__FILE__)); to the top of their script or setting it with an .htaccess directive. Note that it doesn't do a thing to avoid code inejction attacks as such an attacker could issue ini_restore("open_basedir"); and have the same access to the FS as they would without this patch. I'll grant you it's not a panacea, and it may be more harmful than good by making people think that tightening up open_basedir is enough, but it's something. Talk amongst y'selves.... -Sara begin 666 open_basedir.txt [EMAIL PROTECTED](&UA:6XO;6%I;BYC"CT]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T] M/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T*4D-3 M(&9I;&4Z("]R97!O<VET;W)Y+W!H<"US<F,O;6%I;B]M86EN+F,[EMAIL PROTECTED] M:65V:6YG(')E=FES:6]N(#$N-S T"[EMAIL PROTECTED]@+7 @+7(Q+C<P-"!M86EN M+F,*+2TM(&UA:6XO;6%I;BYC"3,@3V-T(#(P,#8@,38Z,[EMAIL PROTECTED],#(@+3 P,# ) M,2XW,#0**RLK(&UA:6XO;6%I;BYC"3$R($]C=" R,# V(#$Y.C(Y.C4Q("TP M,# P"D! ("TS,SDL-B K,S,Y+#<@0$ @<W1A=&EC(%!(4%])[EMAIL PROTECTED] M<&1A=&5$969A=6QT36EM971Y< H@(V5L<V4*(",)9&5F:6YE($1%1D%53%1? M4T5.1$U!24Q?4$%42"!.54Q,"B C96YD:[EMAIL PROTECTED]@>WM[(%!(4%])3DD* M(" [EMAIL PROTECTED]"14=)[EMAIL PROTECTED]"D! ("TS.3(L-R K,SDS+#<@0$ @4$A0 M7TE.25]"14=)[EMAIL PROTECTED]"B )4U1$7U!(4%])3DE?14Y44EDH(F5X=&5N<VEO;E]D M:7(B+ D)"5!(4%]%6%1%3E-)3TY?1$E2+ D)4$A07TE.25]365-414TL"0E/ M;E5P9&%T95-T<FEN9U5N96UP='DL"65X=&5N<VEO;E]D:7(L"0D)<&AP7V-O M<F5?9VQO8F%L<RP)8V]R95]G;&]B86QS*0H@"5-41%]02%!?24Y)7T5.5%)9 M*")I;F-L=61E7W!A=&@B+ D)"5!(4%])3D-,[EMAIL PROTECTED]"0E02%!?24Y) M7T%,3"P)"4]N57!D871E4W1R:6YG56YE;7!T>2P):6YC;'5D95]P871H+ D) M"7!H<%]C;W)E7V=L;V)A;',L"6-O<F5?9VQO8F%L<RD*( E02%!?24Y)7T5. M5%)9*")M87A?97AE8W5T:6]N7W1I;64B+ D)"2(S,"(L"0E02%!?24Y)7T%, M3"P)"0E/;E5P9&%T951I;65O=70I"BT)4U1$7U!(4%])3DE?14Y44EDH(F]P M96Y?8F%S961I<B(L"0D)3E5,3"P)"5!(4%])3DE?4UE35$5-+ D)3VY5<&1A M=&53=')I;F<L"0D);W!E;E]B87-E9&ER+ D)"7!H<%]C;W)E7V=L;V)A;',L M"6-O<F5?9VQO8F%L<[EMAIL PROTECTED];W!E;E]B87-E M9&ER(BP)"0E.54Q,+ D)4$A07TE.25]!3$PL"0E/;E5P9&%T94)A<V5$:7(L M"0D);W!E;E]B87-E9&ER+ D)"7!H<%]C;W)E7V=L;V)A;',L"6-O<F5?9VQO M8F%L<RD*( H@"5-41%]02%!?24Y)7T)/3TQ%04XH(F9I;&5?=7!L;V%D<R(L M"0D)(C$B+ D)4$A07TE.25]365-414TL"0E/;E5P9&%T94)O;VPL"0D)9FEL M95]U<&QO861S+ D)"7!H<%]C;W)E7V=L;V)A;',L"6-O<F5?9VQO8F%L<RD* M( [EMAIL PROTECTED];V%D7VUA>%]F:6QE<VEZ92(L"2(R M32(L"0E02%!?24Y)7U-94U1%37Q02%!?24Y)7U!%4D1)4BP)"4]N57!D871E M3&]N9RP)"0EU<&QO861?;6%X7V9I;&5S:7IE+ EP:'!?8V]R95]G;&]B86QS M+ EC;W)E7V=L;V)A;',I"DEN9&5X.B!M86EN+V9O<&5N7W=R87!P97)S+F,* M/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T] M/3T]/3T]/3T]/3T]/3T]/3T]/3T]/0I20U,@[EMAIL PROTECTED])E<&]S:71O<GDO M<&AP+7-R8R]M86EN+V9O<&5N7W=R87!P97)S+F,[EMAIL PROTECTED]:65V:6YG(')E M=FES:6]N(#$N,[EMAIL PROTECTED]"[EMAIL PROTECTED]@+7 @+7(Q+C$X,R!F;W!E;E]W<F%P<&5R M<RYC"BTM+2!M86EN+V9O<&5N7W=R87!P97)S+F,),2!*=6P@,C P-B Q,3HU M,#HU,B M,# P, DQ+C$X,PHK*RL@;6%I;B]F;W!E;E]W<F%P<&5R<RYC"3$R M($]C=" R,# V(#$Y.C(Y.C4Q("TP,# P"D! ("TX,BPV("LX,BPV-"! 0 H@ M(V5N9&EF"B [EMAIL PROTECTED]( HK+RH@>WM[($]N57!D871E0F%S941I<@HK M06QL;W=S(&%N>2!C:&[EMAIL PROTECTED]&\@;W!E;E]B87-E9&ER('-E='1I;F<@:6X@ M9'5R:6YG(%-T87)T=7 @86YD(%-H=71D;W=N(&5V96YT<RP**V]R(&[EMAIL PROTECTED]&EG M:'1E;FEN9R!D=7)I;F<@86-T:79A=&EO;B]R=6YT:6UE+V1E86-T:79A=&EO M;B J+PHK4$A005!)(%I%3D1?24Y)7TU(*$]N57!D871E0F%S941I<BD**WL* M*PEC:&%R("HJ<"[EMAIL PROTECTED]&AB=68L("IP='(L("IE;F0["BLC:69N9&5F(%I4 M4PHK"6-H87(@*F)A<V4@/2 H8VAA<B J*2!M:%]A<F<R.PHK(V5L<V4**PEC M:&%R("IB87-E([EMAIL PROTECTED]&-H87(@[EMAIL PROTECTED]'-?<F5S;[EMAIL PROTECTED]:6YT("HI(&UH M7V%R9S(I*3L**R-E;[EMAIL PROTECTED]"BL)<" ]("AC:&%R("HJ*2 H8F%S92LH<VEZ M95]T*2!M:%]A<F<Q*3L**PHK"6EF("AS=&%G92 ]/2!02%!?24Y)7U-404=% M7U-405)455 @?'P@<W1A9V4@/[EMAIL PROTECTED]'15]32%541$]73BD@ M>PHK"0DO*B!792=R92!I;B!A(%!(4%])3DE?4UE35$5-(&-O;G1E>'0L(&YO M(')E<W1R:6-T:6]N<R J+PHK"0DJ<" ](&YE=U]V86QU93L**PD)<F5T=7)N M(%-50T-%4U,["BL)?0HK"BL@(" @(" @( HK"2\J($5L<V5W:7-E+"!W92=R M92!I;B!R=6YT:6UE("HO"BL):[EMAIL PROTECTED]"$J<"!\?" A*BIP*2!["BL)"2\J(&]P M96Y?8F%S961I<B!N;W0@<V5T('EE="[EMAIL PROTECTED]@[EMAIL PROTECTED](&=I=F4@:70@ M82!V86QU92 J+PHK"0DJ<" ](&YE=U]V86QU93L**PD)<F5T=7)N(%-50T-% M4U,["BL)?0HK"BL)[EMAIL PROTECTED]<G1C=70Z([EMAIL PROTECTED]@:&%V92!A(&]P96Y? M8F%S961I<B!A;F0@<V]M96]N92!T<FEE<R!T;R!U;G-E="[EMAIL PROTECTED]@:VYO=R!I M="=L;"!F86EL("HO"BL):[EMAIL PROTECTED]"[EMAIL PROTECTED]'P@(2IN97=?=F%L=64I M('L**PD)<F5T=7)N($9!24Q54D4["BL)?0HK"BL)[EMAIL PROTECTED],@=&AE('!R;W!O M<V5D(&]P96Y?8F%S961I<B!A="!L96%S="!A<R!R97-T<FEC=&EV92!A<R!T M:&[EMAIL PROTECTED]<F5N="!S971T:6YG/R J+PHK"7!T<B ]('!A=&AB=68@/2!E<W1R M9'5P*&YE=U]V86QU92D["BL)=VAI;&[EMAIL PROTECTED]'!T<B F)B J<'1R*2"6EF M("AE;F0@([EMAIL PROTECTED],3"D@>PHK"0D)*F5N9" ]("=<,"<["BL)"0EE;F0K*SL* M*PD)?0HK"0EI9B H<&AP7V-H96-K7V]P96Y?8F%S961I<E]E>"AP='(L(# @ M5%-234Q37T-#*2 A/2 P*2!["BL)"0DO*B!!="!L96%S="!O;F4@<&]R=&EO M;B!O9B!T:&ES(&]P96Y?8F%S961I<B!I<R!L97-S(')E<W1R:6-T:79E('1H [EMAIL PROTECTED]&AE('!R:6]R(&[EMAIL PROTECTED])3" J+PHK"0D)969R964H<&%T:&)U9BD[ M"BL)"0ER971U<[EMAIL PROTECTED])3%5213L**PD)?0HK"0EP='(@/2!E;F0["BL)?0HK M"65F<F5E*'!A=&AB=68I.PHK"BL)[EMAIL PROTECTED]<GET:&EN9R!C:&5C:W,@;W5T M+"!S970@:[EMAIL PROTECTED]<" ](&YE=U]V86QU93L**PHK"7)E='5R;B!354-# [EMAIL PROTECTED]("HO"[EMAIL PROTECTED]@>WM[('!H<%]C:&5C:U]S<&5C M:69I8U]O<&5N7V)A<V5D:7(*( E7:&5N(&]P96Y?8F%S961I<B!I<R!N;W0@ M3E5,3"[EMAIL PROTECTED]@:[EMAIL PROTECTED]&AE(&=I=F5N(&9I;&5N86UE(&ES(&QO8V%T960@ M:6X*( EO<&5N7V)A<V5D:7(N(%)E='5R;G,@+3$@:[EMAIL PROTECTED])R;W(@;W(@;F]T M(&EN('1H92!O<&5N7V)A<V5D:7(L(&5L<V4@, I);F1E>#H@;6%I;B]F;W!E M;E]W<F%P<&5R<RYH"CT]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T] M/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T]/3T*4D-3(&9I;&4Z M("]R97!O<VET;W)Y+W!H<"US<F,O;6%I;B]F;W!E;E]W<F%P<&5R<RYH+'8* M<F5T<FEE=FEN9R!R979I<VEO;B Q+C0W"[EMAIL PROTECTED]@+7 @+7(Q+C0W(&9O M<&5N7W=R87!P97)[EMAIL PROTECTED](&UA:6XO9F]P96Y?=W)A<'!E<G,N: DQ($IU M;" R,# V(#$Q.C4P.C4R("TP,# P"3$N-#<**RLK(&UA:6XO9F]P96Y?=W)A M<'!E<G,N: DQ,B!/8W0@,C P-B Q.3HR.3HU,2 M,# P, I 0" M,C,L-B K M,C,L-R! 0 H@"B!"14=)[EMAIL PROTECTED]"B C:6YC;'5D92 B<&AP7V=L M;V)A;',N:"(**R-I;F-L=61E(")P:'!?:[EMAIL PROTECTED]"B *(%!(4$%022!I;G0@ M<&AP7V9O<&5N7W!R:6UA<GE?<V-R:7!T*'IE;F1?9FEL95]H86YD;&[EMAIL PROTECTED] M;&5?:&%N9&QE(%134DU,4U]$0RD["[EMAIL PROTECTED]<B J97AP86YD7V9I M;&5P871H*&-O;G-T(&-H87(@*F9I;&5P871H+"!C:&%R("IR96%L7W!A=&@@ M5%-234Q37T1#*3L*0$ @+3,[EMAIL PROTECTED],V+#@@0$ @4$A005!)($9)[EMAIL PROTECTED] M<%]F;W!E;E]W:71H7W!A=&@H8V]N<[EMAIL PROTECTED]@"B!02%!!4$D@:6YT('!H<%]I M<U]U<FPH8VAA<B J<&%T:"D["[EMAIL PROTECTED]<B J<&AP7W-T<FEP7W5R M;%]P87-S=V0H8VAA<B J<&%T:"D["BL**U!(4$%022!:14Y$7TE.25]-2"A/ K;E5P9&%T94)A<V5$:7([EMAIL PROTECTED]"D*( H@(V5N9&EF"@`` ` end -- PHP Internals - PHP Runtime Development Mailing List To unsubscribe, visit: http://www.php.net/unsub.php