array('inFile'=>true, 'value'=>''), 'content'=> array('inFile'=>true, 'value'=>''), 'description'=> array('inFile'=>false, 'value'=>''), 'username'=> array('inFile'=>false, 'value'=>''), 'tags'=> array('inFile'=>false, 'value'=>''), 'status'=> array('inFile'=>false, 'value'=>'draft'), 'unixTimeCreated'=> array('inFile'=>false, 'value'=>0), 'unixTimeModified'=>array('inFile'=>false, 'value'=>0), 'position'=> array('inFile'=>false, 'value'=>0) ); function __construct() { parent::__construct(PATH_DATABASES.'pages.php'); } public function add($args) { $dataForDb = array(); // This data will be saved in the database $dataForFile = array(); // This data will be saved in the file $key = $this->generateKey($args['slug'], $args['parent']); if($key===false) { return false; } // The user is always the one loggued. $args['username'] = Session::get('username'); if( Text::isEmpty($args['username']) ) { return false; } // The current unix time stamp. $args['unixTimeCreated'] = Date::unixTime(); // Verify arguments with the database fields. foreach($this->dbFields as $field=>$options) { if( isset($args[$field]) ) { // Sanitize if will be saved on database. if( !$options['inFile'] ) { $tmpValue = Sanitize::html($args[$field]); } else { $tmpValue = $args[$field]; } } // Default value for the field. else { $tmpValue = $options['value']; } // Check where the field will be written, in file or database. if($options['inFile']) { $dataForFile[$field] = Text::firstCharUp($field).': '.$tmpValue; } else { // Set type settype($tmpValue, gettype($options['value'])); // Save on database $dataForDb[$field] = $tmpValue; } } // Make the directory. Recursive. if( Filesystem::mkdir(PATH_PAGES.$key, true) === false ) { Log::set(__METHOD__.LOG_SEP.'Error occurred when trying to create the directory '.PATH_PAGES.$key); return false; } // Make the index.txt and save the file. $data = implode("\n", $dataForFile); if( file_put_contents(PATH_PAGES.$key.'/index.txt', $data) === false ) { Log::set(__METHOD__.LOG_SEP.'Error occurred when trying to put the content in the file index.txt'); return false; } // Save the database $this->db[$key] = $dataForDb; if( $this->save() === false ) { Log::set(__METHOD__.LOG_SEP.'Error occurred when trying to save the database file.'); return false; } return true; } public function edit($args) { $dataForDb = array(); $dataForFile = array(); $newKey = $this->generateKey($args['slug'], $args['parent'], false, $args['key']); // The user is always the one loggued. $args['username'] = Session::get('username'); if( Text::isEmpty($args['username']) ) { return false; } // Unix time created and modified. $args['unixTimeCreated'] = $this->db[$args['key']]['unixTimeCreated']; $args['unixTimeModified'] = Date::unixTime(); // Verify arguments with the database fields. foreach($this->dbFields as $field=>$options) { if( isset($args[$field]) ) { // Sanitize if will be saved on database. if( !$options['inFile'] ) { $tmpValue = Sanitize::html($args[$field]); } else { $tmpValue = $args[$field]; } } // Default value for the field. else { $tmpValue = $options['value']; } // Check where the field will be written, if in the file or in the database. if($options['inFile']) { $dataForFile[$field] = Text::firstCharUp($field).': '.$tmpValue; } else { // Set type settype($tmpValue, gettype($options['value'])); // Save on database $dataForDb[$field] = $tmpValue; } } // Move the directory from old key to new key. if($newKey!==$args['key']) { if( Filesystem::mv(PATH_PAGES.$args['key'], PATH_PAGES.$newKey) === false ) { Log::set(__METHOD__.LOG_SEP.'Error occurred when trying to move the directory to '.PATH_PAGES.$newKey); return false; } } // Make the index.txt and save the file. $data = implode("\n", $dataForFile); if( file_put_contents(PATH_PAGES.$newKey.DS.'index.txt', $data) === false ) { Log::set(__METHOD__.LOG_SEP.'Error occurred when trying to put the content in the file index.txt'); return false; } // Remove the old key. unset($this->db[$args['key']]); // Save the database $this->db[$newKey] = $dataForDb; if( $this->save() === false ) { Log::set(__METHOD__.LOG_SEP.'Error occurred when trying to save the database file.'); return false; } return true; } public function delete($key) { // Page doesn't exist in database. if(!$this->pageExists($key)) { Log::set(__METHOD__.LOG_SEP.'The page does not exist. Key: '.$key); } // Delete the index.txt file. if( Filesystem::rmfile(PATH_PAGES.$key.DS.'index.txt') === false ) { Log::set(__METHOD__.LOG_SEP.'Error occurred when trying to delete the file index.txt'); } // Delete the directory. if( Filesystem::rmdir(PATH_PAGES.$key) === false ) { Log::set(__METHOD__.LOG_SEP.'Error occurred when trying to delete the directory '.PATH_PAGES.$key); } // Remove from database. unset($this->db[$key]); // Save the database. if( $this->save() === false ) { Log::set(__METHOD__.LOG_SEP.'Error occurred when trying to save the database file.'); } return true; } // Return an array with the database for a page, FALSE otherwise. public function getDb($key) { if($this->pageExists($key)) { return $this->db[$key]; } return false; } // Return TRUE if the page exists, FALSE otherwise. public function pageExists($key) { return isset($this->db[$key]); } public function parentKeyList() { return $this->parentKeyList; } public function parentKeyExists($key) { return isset($this->parentKeyList[$key]); } public function addParentKey($key) { $this->parentKeyList[$key] = $key; } // Generate a valid Key/Slug. public function generateKey($text, $parent=NO_PARENT_CHAR, $returnSlug=false, $oldKey='') { if(Text::isEmpty($text)) { $text = 'empty'; } if( Text::isEmpty($parent) || ($parent==NO_PARENT_CHAR) ) { $newKey = Text::cleanUrl($text); } else { $newKey = Text::cleanUrl($parent).'/'.Text::cleanUrl($text); } if($newKey!==$oldKey) { // Verify if the key is already been used. if( isset($this->db[$newKey]) ) { if( !Text::endsWithNumeric($newKey) ) { $newKey = $newKey.'-0'; } while( isset($this->db[$newKey]) ) { $newKey++; } } } if($returnSlug) { $explode = explode('/', $newKey); if(isset($explode[1])) { return $explode[1]; } return $explode[0]; } return $newKey; } // Return an array with all page's databases. public function getAll() { return $this->db; } public function regenerate() { $db = $this->db; $paths = array(); $fields = array(); // Complete $fields with the default values. foreach($this->dbFields as $field=>$options) { if(!$options['inFile']) { $fields[$field] = $options['value']; } } // Foreach new page set the unix time stamp. $fields['unixTimeCreated'] = Date::unixTime(); // Foreach new page set the owner admin. $fields['username'] = 'admin'; // Foreach new page set the status. if(HANDMADE_PUBLISHED) { $fields['status']='published'; } // Get the pages from the first level of directories $tmpPaths = glob(PATH_PAGES.'*', GLOB_ONLYDIR); foreach($tmpPaths as $directory) { $key = basename($directory); if(file_exists($directory.DS.'index.txt')){ // The key is the directory name $paths[$key] = true; } // Recovery pages from subdirectories $subPaths = glob($directory.DS.'*', GLOB_ONLYDIR); foreach($subPaths as $subDirectory) { $subKey = basename($subDirectory); if(file_exists($subDirectory.DS.'index.txt')) { // The key is composed by the directory/subdirectory $paths[$key.'/'.$subKey] = true; } } } // Remove old posts from db foreach( array_diff_key($db, $paths) as $slug=>$data ) { unset($this->db[$slug]); } // Insert new posts to db foreach( array_diff_key($paths, $db) as $slug=>$data ) { $this->db[$slug] = $fields; } // Save the database. if( $this->save() === false ) { Log::set(__METHOD__.LOG_SEP.'Error occurred when trying to save the database file.'); return false; } return $this->db!=$db; } }