| 1 | <?php
 | 
  
    | 2 | 
 | 
  
    | 3 | /**
 | 
  
    | 4 |  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 | 
  
    | 5 |  *
 | 
  
    | 6 |  * This program is free software: you can redistribute it and/or modify
 | 
  
    | 7 |  * it under the terms of the GNU General Public License as published by
 | 
  
    | 8 |  * the Free Software Foundation, either version 3 of the License, or
 | 
  
    | 9 |  * (at your option) any later version.
 | 
  
    | 10 |  *
 | 
  
    | 11 |  * This program is distributed in the hope that it will be useful,
 | 
  
    | 12 |  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
  
    | 13 |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
  
    | 14 |  * GNU General Public License for more details.
 | 
  
    | 15 |  *
 | 
  
    | 16 |  * You should have received a copy of the GNU General Public License
 | 
  
    | 17 |  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
  
    | 18 |  */
 | 
  
    | 19 | 
 | 
  
    | 20 | /**
 | 
  
    | 21 |  * AccessFile.php
 | 
  
    | 22 |  *
 | 
  
    | 23 |  * @category     Core
 | 
  
    | 24 |  * @package      Core_Routing
 | 
  
    | 25 |  * @subpackage   Accessfiles
 | 
  
    | 26 |  * @copyright    Manuela v.d.Decken <manuela@isteam.de>
 | 
  
    | 27 |  * @author       Manuela v.d.Decken <manuela@isteam.de>
 | 
  
    | 28 |  * @license      http://www.gnu.org/licenses/gpl.html   GPL License
 | 
  
    | 29 |  * @version      0.0.1
 | 
  
    | 30 |  * @revision     $Revision: 2070 $
 | 
  
    | 31 |  * @lastmodified $Date: 2014-01-03 02:21:42 +0100 (Fri, 03 Jan 2014) $
 | 
  
    | 32 |  * @since        File available since 17.01.2013
 | 
  
    | 33 |  * @description  Single standard accessfile with additional var-entries
 | 
  
    | 34 |  */
 | 
  
    | 35 | class AccessFile {
 | 
  
    | 36 | 
 | 
  
    | 37 | 	/** int first private property */
 | 
  
    | 38 | 	protected $oReg             = null;
 | 
  
    | 39 | 	protected $sAccessFilesRoot = '';      // basedir of the current AccessFile structure
 | 
  
    | 40 | 	protected $sFileName        = '';      // filename and path from AccessFilesRoot (without extension)
 | 
  
    | 41 | 	protected $sFullFileName    = '';      // full path and filename (without extension)
 | 
  
    | 42 | 	protected $sFileExtension   = '.php';  // extension for all accessfiles (default: '.php')
 | 
  
    | 43 | 	protected $aVars            = array(); // variables in accessfile
 | 
  
    | 44 | 	protected $aConsts          = array(); // constants in accessfile
 | 
  
    | 45 | 	protected $iErrorNo         = 0;
 | 
  
    | 46 | 
 | 
  
    | 47 | 	const VAR_STRING  = 'string';
 | 
  
    | 48 | 	const VAR_BOOL    = 'bool';
 | 
  
    | 49 | 	const VAR_BOOLEAN = 'bool';
 | 
  
    | 50 | 	const VAR_INT     = 'int';
 | 
  
    | 51 | 	const VAR_INTEGER = 'int';
 | 
  
    | 52 | 	const VAR_FLOAT   = 'float';
 | 
  
    | 53 | 
 | 
  
    | 54 | 	const FORCE_DELETE = true;
 | 
  
    | 55 | 
 | 
  
    | 56 | 	/**
 | 
  
    | 57 | 	 * Constructor
 | 
  
    | 58 | 	 * @param string  $sAccessFilesRoot  full path to the base directory of accessfiles-tree
 | 
  
    | 59 | 	 * @param string  $sFileName         subdirectory and filename of the new access file from AccessFilesRoot<br />
 | 
  
    | 60 | 	 *                                   (indirect addressing (./ | ../) is not allowed here!!)
 | 
  
    | 61 | 	 * @param integer $iPageId           (default: 0) Id of the page or 0 for dummy files
 | 
  
    | 62 | 	 * @throws AccessFileInvalidFilePathException
 | 
  
    | 63 | 	 */
 | 
  
    | 64 | 	public function __construct($sAccessFilesRoot, $sFileName, $iPageId = 0)
 | 
  
    | 65 | 	{
 | 
  
    | 66 | 		$this->oReg = WbAdaptor::getInstance();
 | 
  
    | 67 | 		$this->sFileExtension = $this->oReg->PageExtension;
 | 
  
    | 68 | 	// sanitize AccessFilesRoot
 | 
  
    | 69 | 		if (($sX = realpath($sAccessFilesRoot)) == false) {
 | 
  
    | 70 | 			throw new AccessFileInvalidFilePathException('invalid path for AccessFilesRoot given [ '.$sAccessFilesRoot.' ]');
 | 
  
    | 71 | 		}
 | 
  
    | 72 | 		$sAccessFilesRoot = rtrim(str_replace('\\', '/', $sX), '/').'/';
 | 
  
    | 73 | 	// check location of AccessFilesRoot
 | 
  
    | 74 | 		if (!preg_match('/^' . preg_quote($this->oReg->AppPath, '/') . '/siU', $sAccessFilesRoot)) {
 | 
  
    | 75 | 			throw new AccessFileInvalidFilePathException('tried to place AccessFilesRoot out of application path [ '.$sAccessFilesRoot.' ]');
 | 
  
    | 76 | 		}
 | 
  
    | 77 | 		$this->sAccessFilesRoot = $sAccessFilesRoot;
 | 
  
    | 78 | 	// sanitize Filename
 | 
  
    | 79 | 		$sFileName = preg_replace('/'.preg_quote($this->sFileExtension, '/').'$/', '', $sFileName);
 | 
  
    | 80 | 		$this->sFileName = ltrim(rtrim(trim(str_replace('\\', '/', $sFileName)), '/'), './');
 | 
  
    | 81 | 		if (preg_match('/\.\.+\//', $this->sFileName)) {
 | 
  
    | 82 | 			throw new AccessFileInvalidFilePathException('relative path (./ or ../) is not allowed in Filename!! [ '.$this->sFileName.' ]');
 | 
  
    | 83 | 		}
 | 
  
    | 84 | 		$this->sFullFileName = $this->sAccessFilesRoot . $this->sFileName;
 | 
  
    | 85 | 		$this->aVars['iPageId'] = intval($iPageId);
 | 
  
    | 86 | 
 | 
  
    | 87 | 	}
 | 
  
    | 88 | 	/**
 | 
  
    | 89 | 	 * Set Id of current page
 | 
  
    | 90 | 	 * @param integer PageId
 | 
  
    | 91 | 	 */
 | 
  
    | 92 | 	public function setPageId($iPageId)
 | 
  
    | 93 | 	{
 | 
  
    | 94 | 		$this->addVar('iPageId', $iPageId, $sType = self::VAR_INTEGER);
 | 
  
    | 95 | 	}
 | 
  
    | 96 | 
 | 
  
    | 97 | 	/**
 | 
  
    | 98 | 	 * Add new variable into the vars list
 | 
  
    | 99 | 	 * @param string name of the variable without leading '$'
 | 
  
    | 100 | 	 * @param mixed Value of the variable (Only scalar data (boolean, integer, float and string) are allowed)
 | 
  
    | 101 | 	 * @param string Type of the variable (use class constants to define)
 | 
  
    | 102 | 	 */
 | 
  
    | 103 | 	public function addVar($sName, $mValue, $sType = self::VAR_STRING)
 | 
  
    | 104 | 	{
 | 
  
    | 105 | 		$mValue = $this->sanitizeValue($mValue, $sType);
 | 
  
    | 106 | 		$this->aVars[$sName] = $mValue;
 | 
  
    | 107 | 	}
 | 
  
    | 108 | 
 | 
  
    | 109 | 	/**
 | 
  
    | 110 | 	 * Add new constant into the constants list
 | 
  
    | 111 | 	 * @param string name of the constant (upper case chars only)
 | 
  
    | 112 | 	 * @param mixed Value of the variable (Only scalar data (boolean, integer, float and string) are allowed)
 | 
  
    | 113 | 	 * @param string Type of the variable (use class constants to define)
 | 
  
    | 114 | 	 * @throws AccessFileConstForbiddenException
 | 
  
    | 115 | 	 * @deprecated constants are not allowed from WB-version 2.9 and up
 | 
  
    | 116 | 	 */
 | 
  
    | 117 | 	public function addConst($sName, $mValue, $sType = self::VAR_STRING)
 | 
  
    | 118 | 	{
 | 
  
    | 119 | 		if (version_compare($this->oReg->AppVersion, '2.9', '<'))
 | 
  
    | 120 | 		{
 | 
  
    | 121 | 			$mValue = $this->sanitizeValue($mValue, $sType);
 | 
  
    | 122 | 			$this->aConsts[strtoupper($sName)] = $mValue;
 | 
  
    | 123 | 		} else {
 | 
  
    | 124 | 			throw new AccessFileConstForbiddenException('define constants is not allowed from WB-version 2.9 and up');
 | 
  
    | 125 | 		}
 | 
  
    | 126 | 	}
 | 
  
    | 127 | 
 | 
  
    | 128 | /**
 | 
  
    | 129 |  * Write the accessfile
 | 
  
    | 130 |  * @throws AccessFileWriteableException
 | 
  
    | 131 |  */
 | 
  
    | 132 | 	public function write() 
 | 
  
    | 133 | 	{
 | 
  
    | 134 | 	// full path and filename
 | 
  
    | 135 | 		$sFileName = $this->sFullFileName.$this->sFileExtension;
 | 
  
    | 136 | 	// remove AppPath from File for use in error messages
 | 
  
    | 137 | 		$sDisplayFilename = str_replace($this->oReg->AppPath, '', $sFileName);
 | 
  
    | 138 | 	// do not allow writing if PageId is missing!
 | 
  
    | 139 | 		if (!$this->aVars['iPageId']) {
 | 
  
    | 140 | 			throw new AccessFileWriteableException('Missing PageId for file [' . $sDisplayFilename . ']');
 | 
  
    | 141 | 		}
 | 
  
    | 142 | 	// build the content for the access file
 | 
  
    | 143 | 		$sContent = $this->buildFileContent($this->buildPathToIndexFile($sFileName));
 | 
  
    | 144 | 	// create path if file does not already exists
 | 
  
    | 145 | 		if (!file_exists($sFileName)) {
 | 
  
    | 146 | 			$this->createPath($sFileName);
 | 
  
    | 147 | 		}
 | 
  
    | 148 | 	// create new file or overwrite existing one
 | 
  
    | 149 | 		if (!file_put_contents($sFileName, $sContent)) {
 | 
  
    | 150 | 			throw new AccessFileWriteableException('Unable to write file [' . $sDisplayFilename . ']');
 | 
  
    | 151 | 		}
 | 
  
    | 152 | 	// do chmod if os is not windows
 | 
  
    | 153 | 		if (strtoupper(substr(PHP_OS, 0, 3)) !== 'WIN') {
 | 
  
    | 154 | 			chmod($sFileName, $this->oReg->OctalFileMode);
 | 
  
    | 155 | 		}
 | 
  
    | 156 | 	}
 | 
  
    | 157 | 
 | 
  
    | 158 | /**
 | 
  
    | 159 |  * searchParentPageId
 | 
  
    | 160 |  * @param string $sAccessFilesRoot
 | 
  
    | 161 |  * @param string $sFullFilePath
 | 
  
    | 162 |  * @return int   found page-id
 | 
  
    | 163 |  * @description  find first valid accessfile backwards in the parent line<br />
 | 
  
    | 164 |  *               or the start page if no parent is found.
 | 
  
    | 165 |  */
 | 
  
    | 166 | 	protected function searchParentPageId($sAccessFilesRoot, $sFullFilePath)
 | 
  
    | 167 | 	{
 | 
  
    | 168 | 
 | 
  
    | 169 | 
 | 
  
    | 170 | 		return $iPageId;
 | 
  
    | 171 | 	}
 | 
  
    | 172 | 	/**
 | 
  
    | 173 | 	 * Rename an existing Accessfile
 | 
  
    | 174 | 	 * @param  string  $sNewName the new filename without path and without extension
 | 
  
    | 175 | 	 * @return boolean
 | 
  
    | 176 | 	 * @throws AccessFileRenameException
 | 
  
    | 177 | 	 */
 | 
  
    | 178 | 	public function rename($sNewName)
 | 
  
    | 179 | 	{
 | 
  
    | 180 | 		// validate and sanitize new filename
 | 
  
    | 181 | 		$sPattern = '/(^'.preg_quote($this->sAccessFilesRoot, '/').'|^'.preg_quote($this->oReg->AppPath, '/')
 | 
  
    | 182 | 		          . ')?([^\/]*?)(?:'.preg_quote($this->sFileExtension, '/').')?$/s';
 | 
  
    | 183 | 		if (!preg_match($sPattern, $sNewName, $aMatches)) {
 | 
  
    | 184 | 		// sorry, but the given filename is not valid!
 | 
  
    | 185 | 			throw new AccessFileRenameException('invalid filename [' . str_replace($this->oReg->AppPath, '', $sNewName) . ']');
 | 
  
    | 186 | 		}
 | 
  
    | 187 | 		$sOldFileName = $this->sFullFileName;
 | 
  
    | 188 | 		// $aMatches[sizeof($aMatches)-1] contains the new filename without extension only
 | 
  
    | 189 | 		$sNewFileName = preg_replace('/(^.*?)[^\/]*$/', '\1'.$aMatches[sizeof($aMatches)-1], $sOldFileName);
 | 
  
    | 190 | 		$sDisplayOldFileName = str_replace($this->oReg->AppPath, '', $sOldFileName);
 | 
  
    | 191 | 		$sDisplayNewFileName = str_replace($this->oReg->AppPath, '', $sNewFileName);
 | 
  
    | 192 | 
 | 
  
    | 193 | 		if (file_exists($sNewFileName.$this->sFileExtension) || file_exists($sNewFileName.'/')) {
 | 
  
    | 194 | 		// if new filename or directory already exists
 | 
  
    | 195 | 			throw new AccessFileRenameException('new file or new dirname already exists ['.$sDisplayNewFileName.'{'.$this->sFileExtension.'}]');
 | 
  
    | 196 | 		}
 | 
  
    | 197 | 		if (!is_writeable($sOldFileName.$this->sFileExtension)) {
 | 
  
    | 198 | 		// old file is not writable an can not be renamed
 | 
  
    | 199 | 			throw new AccessFileRenameException('file not exists or file is readonly ['.$sDisplayOldFileName.$this->sFileExtension.']');
 | 
  
    | 200 | 		}
 | 
  
    | 201 | 		$bSubdirRenamed = false; // set default value
 | 
  
    | 202 | 		if (file_exists($sOldFileName.'/')) { //
 | 
  
    | 203 | 			if (is_writeable($sOldFileName.'/')) {
 | 
  
    | 204 | 				if (!( $bSubdirRenamed = rename($sOldFileName.'/', $sOldFileName.'/'))) {
 | 
  
    | 205 | 					throw new AccessFileRenameException('unable to rename directory ['.$sDisplayOldFileName.'/] to ['.$sDisplayNewFileName.'/]');
 | 
  
    | 206 | 				}
 | 
  
    | 207 | 			} else {
 | 
  
    | 208 | 				throw new AccessFileRenameException('directory is not writeable ['.$sDisplayOldFileName.'/]');
 | 
  
    | 209 | 			}
 | 
  
    | 210 | 		}
 | 
  
    | 211 | 		// try to rename accessfile
 | 
  
    | 212 | 		if (!rename($sOldFileName.$this->sFileExtension, $sNewFileName.$this->sFileExtension)) {
 | 
  
    | 213 | 			if ($bSubdirRenamed) { rename($sNewFileName.'/', $sOldFileName.'/'); }
 | 
  
    | 214 | 			$sMsg = 'unable to rename file ['.$sDisplayOldFileName.$this->sFileExtension
 | 
  
    | 215 | 			      . '] to ['.$sDisplayOldFileName.$this->sFileExtension.']';
 | 
  
    | 216 | 			throw new AccessFileRenameException($sMsg);
 | 
  
    | 217 | 		}
 | 
  
    | 218 | 		return true;
 | 
  
    | 219 | 	}
 | 
  
    | 220 | 
 | 
  
    | 221 | 	/**
 | 
  
    | 222 | 	 * Delete the actual Accessfile
 | 
  
    | 223 | 	 * @return boolean true if successfull
 | 
  
    | 224 | 	 * @throws AccessFileIsNoAccessfileException
 | 
  
    | 225 | 	 * @throws AccessFileWriteableException
 | 
  
    | 226 | 	 */
 | 
  
    | 227 | 	public function delete($bForceDelete = true)
 | 
  
    | 228 | 	{
 | 
  
    | 229 | 		$sFileName = $this->sFullFileName.$this->sFileExtension;
 | 
  
    | 230 | 
 | 
  
    | 231 | 		if (!AccessFileHelper::isAccessFile($sFileName)) {
 | 
  
    | 232 | 			throw new AccessFileIsNoAccessfileException('requested file is NOT an accessfile');
 | 
  
    | 233 | 		}
 | 
  
    | 234 | 		if (file_exists($sFileName) && is_writeable($sFileName))
 | 
  
    | 235 | 		{
 | 
  
    | 236 | 			if (is_writeable($this->sFullFileName)) {
 | 
  
    | 237 | 				AccessFileHelper::delTree($this->sFullFileName, AccessFileHelper::DEL_ROOT_DELETE);
 | 
  
    | 238 | 			}
 | 
  
    | 239 | 			unlink($sFileName);
 | 
  
    | 240 | 			$sFileName = '';
 | 
  
    | 241 | 		} else {
 | 
  
    | 242 | 			throw new AccessFileWriteableException('requested file not exists or permissions missing');
 | 
  
    | 243 | 		}
 | 
  
    | 244 | 	}
 | 
  
    | 245 | 
 | 
  
    | 246 | 	/**
 | 
  
    | 247 | 	 * getFilename
 | 
  
    | 248 | 	 * @return string path+name of the current accessfile
 | 
  
    | 249 | 	 */
 | 
  
    | 250 | 	public function getFileName()
 | 
  
    | 251 | 	{
 | 
  
    | 252 | 		return $this->sFullFileName.$this->sFileExtension;
 | 
  
    | 253 | 	}
 | 
  
    | 254 | 
 | 
  
    | 255 | 	/**
 | 
  
    | 256 | 	 * getPageId
 | 
  
    | 257 | 	 * @return integer
 | 
  
    | 258 | 	 */
 | 
  
    | 259 | 	public function getPageId()
 | 
  
    | 260 | 	{
 | 
  
    | 261 | 		return (isset($this->aVars['iPageId']) ? $this->aVars['iPageId'] : 0);
 | 
  
    | 262 | 	}
 | 
  
    | 263 | 	/**
 | 
  
    | 264 | 	 * get number of the last occured error
 | 
  
    | 265 | 	 * @return int
 | 
  
    | 266 | 	 */
 | 
  
    | 267 | 	public function getError()
 | 
  
    | 268 | 	{
 | 
  
    | 269 | 		return $this->iErrorNo;
 | 
  
    | 270 | 	}
 | 
  
    | 271 | 	/**
 | 
  
    | 272 | 	 * set number of error
 | 
  
    | 273 | 	 * @param type $iErrNo
 | 
  
    | 274 | 	 */
 | 
  
    | 275 | 	protected function setError($iErrNo = self::ERR_NONE)
 | 
  
    | 276 | 	{
 | 
  
    | 277 | 		$this->iErrorNo = $iErrNo;
 | 
  
    | 278 | 	}
 | 
  
    | 279 | 	/**
 | 
  
    | 280 | 	 * Create Path to Accessfile
 | 
  
    | 281 | 	 * @param string full path/name to new access file
 | 
  
    | 282 | 	 * @throws AccessFileWriteableException
 | 
  
    | 283 | 	 * @throws AccessFileInvalidStructureException
 | 
  
    | 284 | 	 */
 | 
  
    | 285 | 	protected function createPath($sFilename)
 | 
  
    | 286 | 	{
 | 
  
    | 287 | 		$sFilename = str_replace($this->sAccessFilesRoot, '', $sFilename);
 | 
  
    | 288 | 		$sPagesDir = $this->sAccessFilesRoot;
 | 
  
    | 289 | 		if (($iSlashPosition = mb_strrpos($sFilename, '/')) !== false) {
 | 
  
    | 290 | 			// if subdirs exists, then procceed extended check
 | 
  
    | 291 | 			$sExtension = preg_replace('/.*?(\.[a-z][a-z0-9]+)$/siU', '\1', $sFilename);
 | 
  
    | 292 | 			$sParentDir = mb_substr($sFilename, 0, $iSlashPosition);
 | 
  
    | 293 | 			if (file_exists($sPagesDir . $sParentDir)) {
 | 
  
    | 294 | 				if (!is_writable($sPagesDir . $sParentDir)) {
 | 
  
    | 295 | 					throw new AccessFileWriteableException('No write permissions for ' . $sPagesDir . $sParentDir);
 | 
  
    | 296 | 				}
 | 
  
    | 297 | 			} else {
 | 
  
    | 298 | 				// if parentdir not exists
 | 
  
    | 299 | 				if (file_exists($sPagesDir . $sParentDir . $sExtension)) {
 | 
  
    | 300 | 					// but parentaccessfile exists, create parentdir and ok
 | 
  
    | 301 | 					$iOldUmask = umask(0);
 | 
  
    | 302 | 					$bRetval = mkdir($sPagesDir . $sParentDir, $this->oReg->OctalDirMode);
 | 
  
    | 303 | 					umask($iOldUmask);
 | 
  
    | 304 | 				} else {
 | 
  
    | 305 | 					throw new AccessFileInvalidStructureException('invalid structure - missing file: ' . $sFilename);
 | 
  
    | 306 | 				}
 | 
  
    | 307 | 				if (!$bRetval) {
 | 
  
    | 308 | 					throw new AccessFileWriteableException('Unable to create ' . $sPagesDir . $sParentDir);
 | 
  
    | 309 | 				}
 | 
  
    | 310 | 			}
 | 
  
    | 311 | 		}
 | 
  
    | 312 | 	}
 | 
  
    | 313 | 	/**
 | 
  
    | 314 | 	 * Sanitize value
 | 
  
    | 315 | 	 * @param mixed Value to sanitize
 | 
  
    | 316 | 	 * @param string Type of the variable (use class constants to define)
 | 
  
    | 317 | 	 * @return string printable value
 | 
  
    | 318 | 	 * @throws InvalidArgumentException
 | 
  
    | 319 | 	 */
 | 
  
    | 320 | 	protected function sanitizeValue($mValue, $sType)
 | 
  
    | 321 | 	{
 | 
  
    | 322 | 		$mRetval = '';
 | 
  
    | 323 | 		switch ($sType)
 | 
  
    | 324 | 		{
 | 
  
    | 325 | 			case self::VAR_BOOLEAN:
 | 
  
    | 326 | 			case self::VAR_BOOL:
 | 
  
    | 327 | 				$mRetval = (filter_var(strtolower($mValue), FILTER_VALIDATE_BOOLEAN) ? '1' : '0');
 | 
  
    | 328 | 				break;
 | 
  
    | 329 | 			case self::VAR_INTEGER:
 | 
  
    | 330 | 			case self::VAR_INT:
 | 
  
    | 331 | 				if (filter_var($mValue, FILTER_VALIDATE_INT) === false) {
 | 
  
    | 332 | 					throw new InvalidArgumentException('value is not an integer');
 | 
  
    | 333 | 				}
 | 
  
    | 334 | 				$mRetval = (string) $mValue;
 | 
  
    | 335 | 				break;
 | 
  
    | 336 | 			case self::VAR_FLOAT:
 | 
  
    | 337 | 				if (filter_var($mValue, FILTER_VALIDATE_FLOAT) === false) {
 | 
  
    | 338 | 					throw new InvalidArgumentException('value is not a float');
 | 
  
    | 339 | 				}
 | 
  
    | 340 | 				$mRetval = (string) $mValue;
 | 
  
    | 341 | 				break;
 | 
  
    | 342 | 			default: // VAR_STRING
 | 
  
    | 343 | 				$mRetval = '\'' . (string) $mValue . '\'';
 | 
  
    | 344 | 				break;
 | 
  
    | 345 | 		}
 | 
  
    | 346 | 		return $mRetval;
 | 
  
    | 347 | 	}
 | 
  
    | 348 | 
 | 
  
    | 349 | 	/**
 | 
  
    | 350 | 	 * Calculate backsteps in directory
 | 
  
    | 351 | 	 * @param string accessfile
 | 
  
    | 352 | 	 */
 | 
  
    | 353 | 	protected function buildPathToIndexFile($sFileName)
 | 
  
    | 354 | 	{
 | 
  
    | 355 | 		$iBackSteps = substr_count(str_replace($this->oReg->AppPath, '', $sFileName), '/');
 | 
  
    | 356 | 		return str_repeat('../', $iBackSteps) . 'index.php';
 | 
  
    | 357 | 	}
 | 
  
    | 358 | 
 | 
  
    | 359 | 	/**
 | 
  
    | 360 | 	 * Build the content of the new accessfile
 | 
  
    | 361 | 	 * @param string $sIndexFile name and path to the wb/index.php file
 | 
  
    | 362 | 	 * @return string
 | 
  
    | 363 | 	 */
 | 
  
    | 364 | 	protected function buildFileContent($sIndexFile)
 | 
  
    | 365 | 	{
 | 
  
    | 366 | 		$sFileContent
 | 
  
    | 367 | 				= '<?php' . "\n"
 | 
  
    | 368 | 				. '// *** This file was created automatically by ' ."\n"
 | 
  
    | 369 | 				. '// *** ' . $this->oReg->AppName	. ' Ver.' . $this->oReg->AppVersion
 | 
  
    | 370 | 				. ($this->oReg->AppServicePack != '' ? ' '.$this->oReg->AppServicePack : '')
 | 
  
    | 371 | 				. ' Rev.' . $this->oReg->AppRevision . "\n"
 | 
  
    | 372 | 				. '// *** on ' . date('c') . "\n"
 | 
  
    | 373 | 				. '//' . "\n"
 | 
  
    | 374 | 				. '// *** Warning *************************************' . "\n"
 | 
  
    | 375 | 				. '// *** Please do not manually change this file!' . "\n"
 | 
  
    | 376 | 				. '// *** It will be recreated from time to time and' . "\n"
 | 
  
    | 377 | 				. '// *** then all manual changes will get lost!!' . "\n"
 | 
  
    | 378 | 				. '// *************************************************' . "\n"
 | 
  
    | 379 | 				. '//' . "\n";
 | 
  
    | 380 | 		foreach ($this->aVars as $sKey => $sVar) {
 | 
  
    | 381 | 			$sFileContent .= "\t" . '$' . $sKey . ' = ' . $sVar . ';' . "\n";
 | 
  
    | 382 | 		}
 | 
  
    | 383 | 		foreach ($this->aConsts as $sKey => $sVar) {
 | 
  
    | 384 | 			$sFileContent .= "\t" . 'define(\'' . $sKey . '\', ' . $sVar . '); // ** deprecated command **' . "\n";
 | 
  
    | 385 | 		}
 | 
  
    | 386 | 		$sFileContent
 | 
  
    | 387 | 				.="\t" . 'require(\'' . $sIndexFile . '\');' . "\n"
 | 
  
    | 388 | 				. "\t" . 'exit();' . "\n"
 | 
  
    | 389 | 				. '// *************************************************' . "\n"
 | 
  
    | 390 | 				. '// end of file' . "\n";
 | 
  
    | 391 | 		return $sFileContent;
 | 
  
    | 392 | 	}
 | 
  
    | 393 | 
 | 
  
    | 394 | }
 | 
  
    | 395 | 
 | 
  
    | 396 | // end of class AccessFile
 | 
  
    | 397 | // //////////////////////////////////////////////////////////////////////////////////// //
 | 
  
    | 398 | /**
 | 
  
    | 399 |  * AccessFileException
 | 
  
    | 400 |  *
 | 
  
    | 401 |  * @category     WBCore
 | 
  
    | 402 |  * @package      WBCore_Accessfiles
 | 
  
    | 403 |  * @author       M.v.d.Decken <manuela@isteam.de>
 | 
  
    | 404 |  * @copyright    M.v.d.Decken <manuela@isteam.de>
 | 
  
    | 405 |  * @license      http://www.gnu.org/licenses/gpl.html   GPL License
 | 
  
    | 406 |  * @version      2.9.0
 | 
  
    | 407 |  * @revision     $Revision: 2070 $
 | 
  
    | 408 |  * @lastmodified $Date: 2014-01-03 02:21:42 +0100 (Fri, 03 Jan 2014) $
 | 
  
    | 409 |  * @description  Exceptionhandler for the Accessfiles and depending classes
 | 
  
    | 410 |  */
 | 
  
    | 411 | 
 | 
  
    | 412 | class AccessFileException extends AppException { }
 | 
  
    | 413 | class AccessFileInvalidStructureException extends AccessFileException { }
 | 
  
    | 414 | class AccessFileIsNoAccessfileException extends AccessFileException { }
 | 
  
    | 415 | class AccessFileConstForbiddenException extends AccessFileException { }
 | 
  
    | 416 | class AccessFileInvalidFilePathException extends AccessFileException { }
 | 
  
    | 417 | class AccessFileRenameException extends AccessFileException { }
 | 
  
    | 418 | class AccessFileWriteableException extends AccessFileException { }
 |