| 
									
										
										
										
											2003-05-08 20:21:16 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Smarty plugin | 
					
						
							|  |  |  |  * @package Smarty | 
					
						
							|  |  |  |  * @subpackage plugins | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * determines if a resource is trusted or not | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param string $resource_type | 
					
						
							|  |  |  |  * @param string $resource_name | 
					
						
							|  |  |  |  * @return boolean | 
					
						
							| 
									
										
										
										
											2003-10-11 08:55:53 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-05-08 20:21:16 +00:00
										 |  |  |  // $resource_type, $resource_name
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-06-22 03:13:25 +00:00
										 |  |  | function smarty_core_is_trusted($params, &$smarty) | 
					
						
							| 
									
										
										
										
											2003-05-08 20:21:16 +00:00
										 |  |  | { | 
					
						
							|  |  |  |     $_smarty_trusted = false; | 
					
						
							|  |  |  |     if ($params['resource_type'] == 'file') { | 
					
						
							| 
									
										
										
										
											2003-06-22 03:13:25 +00:00
										 |  |  |         if (!empty($smarty->trusted_dir)) { | 
					
						
							| 
									
										
										
										
											2003-08-09 08:47:10 +00:00
										 |  |  |             $_rp = realpath($params['resource_name']); | 
					
						
							|  |  |  |             foreach ((array)$smarty->trusted_dir as $curr_dir) { | 
					
						
							|  |  |  |                 if (!empty($curr_dir) && is_readable ($curr_dir)) { | 
					
						
							|  |  |  |                     $_cd = realpath($curr_dir); | 
					
						
							|  |  |  |                     if (strncmp($_rp, $_cd, strlen($_cd)) == 0 | 
					
						
							|  |  |  |                         && $_rp{strlen($_cd)} == DIRECTORY_SEPARATOR ) { | 
					
						
							|  |  |  |                         $_smarty_trusted = true; | 
					
						
							|  |  |  |                         break; | 
					
						
							| 
									
										
										
										
											2003-05-08 20:21:16 +00:00
										 |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2003-08-09 08:47:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-05-08 20:21:16 +00:00
										 |  |  |     } else { | 
					
						
							|  |  |  |         // resource is not on local file system
 | 
					
						
							| 
									
										
										
										
											2003-06-22 03:13:25 +00:00
										 |  |  |         $_smarty_trusted = call_user_func_array($smarty->_plugins['resource'][$params['resource_type']][0][3], | 
					
						
							|  |  |  |                                                 array($params['resource_name'], $smarty)); | 
					
						
							| 
									
										
										
										
											2003-05-08 20:21:16 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return $_smarty_trusted; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* vim: set expandtab: */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ?>
 |