2010-01-11 23:42:17 +00: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 22:53:24 +00:00
|
|
|
?>
|