| 
									
										
										
										
											2010-03-02 23:24:50 -05:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @file CAS/PGTStorage/pgt-file.php | 
					
						
							|  |  |  |  * Basic class for PGT file storage | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @class PGTStorageFile | 
					
						
							|  |  |  |  * The PGTStorageFile class is a class for PGT file storage. An instance of  | 
					
						
							|  |  |  |  * this class is returned by CASClient::SetPGTStorageFile(). | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @author Pascal Aubry <pascal.aubry at univ-rennes1.fr> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @ingroup internalPGTStorageFile | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class PGTStorageFile extends PGTStorage | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   /**  | 
					
						
							|  |  |  |    * @addtogroup internalPGTStorageFile  | 
					
						
							|  |  |  |    * @{  | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * a string telling where PGT's should be stored on the filesystem. Written by | 
					
						
							|  |  |  |    * PGTStorageFile::PGTStorageFile(), read by getPath(). | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @private | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   var $_path; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * This method returns the name of the directory where PGT's should be stored  | 
					
						
							|  |  |  |    * on the filesystem. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @return the name of a directory (with leading and trailing '/') | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @private | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   function getPath() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       return $this->_path; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * a string telling the format to use to store PGT's (plain or xml). Written by | 
					
						
							|  |  |  |    * PGTStorageFile::PGTStorageFile(), read by getFormat(). | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @private | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   var $_format; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * This method returns the format to use when storing PGT's on the filesystem. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @return a string corresponding to the format used (plain or xml). | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @private | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   function getFormat() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       return $this->_format; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // ########################################################################
 | 
					
						
							|  |  |  |   //  DEBUGGING
 | 
					
						
							|  |  |  |   // ########################################################################
 | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * This method returns an informational string giving the type of storage | 
					
						
							|  |  |  |    * used by the object (used for debugging purposes). | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @return an informational string. | 
					
						
							|  |  |  |    * @public | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   function getStorageType() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       return "file"; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * This method returns an informational string giving informations on the | 
					
						
							|  |  |  |    * parameters of the storage.(used for debugging purposes). | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @return an informational string. | 
					
						
							|  |  |  |    * @public | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   function getStorageInfo() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       return 'path=`'.$this->getPath().'\', format=`'.$this->getFormat().'\''; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // ########################################################################
 | 
					
						
							|  |  |  |   //  CONSTRUCTOR
 | 
					
						
							|  |  |  |   // ########################################################################
 | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * The class constructor, called by CASClient::SetPGTStorageFile(). | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @param $cas_parent the CASClient instance that creates the object. | 
					
						
							|  |  |  |    * @param $format the format used to store the PGT's (`plain' and `xml' allowed). | 
					
						
							|  |  |  |    * @param $path the path where the PGT's should be stored | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @public | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   function PGTStorageFile($cas_parent,$format,$path) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       phpCAS::traceBegin(); | 
					
						
							|  |  |  |       // call the ancestor's constructor
 | 
					
						
							|  |  |  |       $this->PGTStorage($cas_parent); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (empty($format) ) $format = CAS_PGT_STORAGE_FILE_DEFAULT_FORMAT; | 
					
						
							|  |  |  |       if (empty($path) ) $path = CAS_PGT_STORAGE_FILE_DEFAULT_PATH; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // check that the path is an absolute path
 | 
					
						
							|  |  |  |       if (getenv("OS")=="Windows_NT"){ | 
					
						
							|  |  |  |       	 | 
					
						
							|  |  |  |       	 if (!preg_match('`^[a-zA-Z]:`', $path)) { | 
					
						
							|  |  |  | 	     	phpCAS::error('an absolute path is needed for PGT storage to file'); | 
					
						
							|  |  |  |       	} | 
					
						
							|  |  |  |       	 | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       	if ( $path[0] != '/' ) { | 
					
						
							|  |  |  | 			phpCAS::error('an absolute path is needed for PGT storage to file'); | 
					
						
							|  |  |  |       	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       	// store the path (with a leading and trailing '/')      
 | 
					
						
							|  |  |  |       	$path = preg_replace('|[/]*$|','/',$path); | 
					
						
							|  |  |  |       	$path = preg_replace('|^[/]*|','/',$path); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       $this->_path = $path; | 
					
						
							|  |  |  |       // check the format and store it
 | 
					
						
							|  |  |  |       switch ($format) { | 
					
						
							|  |  |  |       case CAS_PGT_STORAGE_FILE_FORMAT_PLAIN: | 
					
						
							|  |  |  |       case CAS_PGT_STORAGE_FILE_FORMAT_XML: | 
					
						
							|  |  |  | 	$this->_format = $format; | 
					
						
							|  |  |  | 	break; | 
					
						
							|  |  |  |       default: | 
					
						
							|  |  |  | 	phpCAS::error('unknown PGT file storage format (`'.CAS_PGT_STORAGE_FILE_FORMAT_PLAIN.'\' and `'.CAS_PGT_STORAGE_FILE_FORMAT_XML.'\' allowed)'); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       phpCAS::traceEnd();       | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // ########################################################################
 | 
					
						
							|  |  |  |   //  INITIALIZATION
 | 
					
						
							|  |  |  |   // ########################################################################
 | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * This method is used to initialize the storage. Halts on error. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @public | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   function init() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       phpCAS::traceBegin(); | 
					
						
							|  |  |  |       // if the storage has already been initialized, return immediatly
 | 
					
						
							|  |  |  |       if ( $this->isInitialized() ) | 
					
						
							|  |  |  | 	return; | 
					
						
							|  |  |  |       // call the ancestor's method (mark as initialized)
 | 
					
						
							|  |  |  |       parent::init(); | 
					
						
							|  |  |  |       phpCAS::traceEnd();       | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // ########################################################################
 | 
					
						
							|  |  |  |   //  PGT I/O
 | 
					
						
							|  |  |  |   // ########################################################################
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * This method returns the filename corresponding to a PGT Iou. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @param $pgt_iou the PGT iou. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @return a filename | 
					
						
							|  |  |  |    * @private | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   function getPGTIouFilename($pgt_iou) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       phpCAS::traceBegin(); | 
					
						
							|  |  |  |       $filename = $this->getPath().$pgt_iou.'.'.$this->getFormat(); | 
					
						
							|  |  |  |       phpCAS::traceEnd($filename); | 
					
						
							|  |  |  |       return $filename; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * This method stores a PGT and its corresponding PGT Iou into a file. Echoes a | 
					
						
							|  |  |  |    * warning on error. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @param $pgt the PGT | 
					
						
							|  |  |  |    * @param $pgt_iou the PGT iou | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @public | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   function write($pgt,$pgt_iou) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       phpCAS::traceBegin(); | 
					
						
							|  |  |  |       $fname = $this->getPGTIouFilename($pgt_iou); | 
					
						
							|  |  |  |       if ( $f=fopen($fname,"w") ) { | 
					
						
							|  |  |  | 	if ( fputs($f,$pgt) === FALSE ) { | 
					
						
							|  |  |  | 	  phpCAS::error('could not write PGT to `'.$fname.'\''); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	fclose($f); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  | 	phpCAS::error('could not open `'.$fname.'\''); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       phpCAS::traceEnd();       | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** | 
					
						
							|  |  |  |    * This method reads a PGT corresponding to a PGT Iou and deletes the  | 
					
						
							|  |  |  |    * corresponding file. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @param $pgt_iou the PGT iou | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @return the corresponding PGT, or FALSE on error | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * @public | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   function read($pgt_iou) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       phpCAS::traceBegin(); | 
					
						
							|  |  |  |       $pgt = FALSE; | 
					
						
							|  |  |  |       $fname = $this->getPGTIouFilename($pgt_iou); | 
					
						
							|  |  |  |       if ( !($f=fopen($fname,"r")) ) { | 
					
						
							|  |  |  | 	phpCAS::trace('could not open `'.$fname.'\''); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  | 	if ( ($pgt=fgets($f)) === FALSE ) { | 
					
						
							|  |  |  | 	  phpCAS::trace('could not read PGT from `'.$fname.'\''); | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	fclose($f); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // delete the PGT file
 | 
					
						
							|  |  |  |       @unlink($fname); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       phpCAS::traceEnd($pgt); | 
					
						
							|  |  |  |       return $pgt; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   /** @} */ | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2009-12-22 17:53:24 -05:00
										 |  |  | ?>
 |