fileSystemRoot/lib/foldermanagement/Folder.inc");
if (checkSession()) {
require_once("$default->fileSystemRoot/lib/visualpatterns/PatternCustom.inc");
$oPatternCustom = & new PatternCustom();
if (isset($fFolderID)) {
//initialse a folder object
$oFolder = Folder::get($fFolderID);
require_once("$default->fileSystemRoot/lib/visualpatterns/PatternTableSqlQuery.inc");
require_once("$default->fileSystemRoot/lib/visualpatterns/PatternListBox.inc");
require_once("$default->fileSystemRoot/lib/foldermanagement/Folder.inc");
require_once("$default->fileSystemRoot/lib/foldermanagement/FolderDocTypeLink.inc");
require_once("$default->fileSystemRoot/lib/foldermanagement/PhysicalFolderManagement.inc");
require_once("$default->fileSystemRoot/lib/subscriptions/SubscriptionEngine.inc");
require_once("$default->fileSystemRoot/presentation/lookAndFeel/knowledgeTree/foldermanagement/folderUI.inc");
require_once("$default->fileSystemRoot/presentation/Html.inc");
require_once("addFolderUI.inc");
if (!isset($fFolderName)) {
require_once("$default->fileSystemRoot/presentation/webpageTemplate.inc");
//we're still browsing
if (Permission::userHasFolderWritePermission($oFolder)) {
//if the user is allowed to add folders, then display the add button
$oPatternCustom->setHtml(renderBrowseAddPage($fFolderID));
} else {
//otherwise just let the user browse
$oPatternCustom->setHtml(renderBrowsePage($fFolderID));
$main->setErrorMessage("You do not have permission to create new folders in this folder
rootUrl/control.php?action=browse&fFolderID=$fFolderID\"> graphicsUrl/widgets/cancel.gif\" border=\"0\">");
}
$main->setCentralPayload($oPatternCustom);
$main->setFormAction($_SERVER["PHP_SELF"] . "?fFolderID=$fFolderID");
$main->setHasRequiredFields(true);
$main->render();
} else {
// a document type has been specified
if (isset($fDocumentTypeID)) {
//have a folder name to store
if (Permission::userHasFolderWritePermission($oFolder)) {
//check for illegal characters in the folder name
// strip slashes from the already EPGCS escaped form input
$sCheckFolderName = stripslashes($fFolderName);
if (strpos($sCheckFolderName, "\\") === false && strpos($sCheckFolderName, ">") === false &&
strpos($sCheckFolderName, "<") === false && strpos($sCheckFolderName, ":") === false &&
strpos($sCheckFolderName, "*") === false && strpos($sCheckFolderName, "?") === false &&
strpos($sCheckFolderName, "|") === false && strpos($sCheckFolderName, "/") === false &&
strpos($sCheckFolderName, "\"") === false) {
if (Folder::folderExistsName($fFolderName, $fFolderID)) {
require_once("$default->fileSystemRoot/presentation/webpageTemplate.inc");
$oPatternCustom->setHtml(renderBrowseAddPage($fFolderID));
$main->setCentralPayload($oPatternCustom);
$main->setErrorMessage("There is another folder named $fFolderName in this folder already");
$main->setHasRequiredFields(true);
$main->setFormAction($_SERVER["PHP_SELF"] . "?fFolderID=$fFolderID");
$main->render();
} else {
$oParentFolder = Folder::get($fFolderID);
//create the folder in the db, giving it the properties of it's parent folder
$oFolder = & new Folder($fFolderName, "", $fFolderID, $_SESSION["userID"], $oParentFolder->getUnitID());
if ($oFolder->create()) {
$oFolderDocTypeLink = & new FolderDocTypeLink($oFolder->getID(), $fDocumentTypeID);
if ($oFolderDocTypeLink->create()) {
//create the folder on the file system
if (PhysicalFolderManagement::createFolder(Folder::getFolderPath($oFolder->getID()))) {
$default->log->info("addFolderBL.php successfully added folder $fFolderName to parent folder " . Folder::getFolderPath($fFolderID) . " id=$fFolderID");
// fire subscription alerts for the new folder
$count = SubscriptionEngine::fireSubscription($oParentFolder->getID(), SubscriptionConstants::subscriptionAlertType("AddFolder"),
SubscriptionConstants::subscriptionType("FolderSubscription"),
array( "newFolderName" => $fFolderName,
"parentFolderName" => $oParentFolder->getName()) );
$default->log->info("addFolderBL.php fired $count subscription alerts for new folder $fFolderName");
redirect("$default->rootUrl/control.php?action=editFolder&fFolderID=" . $oFolder->getID());
} else {
//if we couldn't do that
$default->log->error("addFolderBL.php Filesystem error attempting to store folder name=$fFolderName in parent folder '" . Folder::getFolderPath($fFolderID) . "' id=$fFolderID");
// remove the folder and its doc type link from the db and report and error
$oFolderDocTypeLink->delete();
$oFolder->delete();
require_once("$default->fileSystemRoot/presentation/webpageTemplate.inc");
$oPatternCustom->setHtml(renderBrowsePage($fFolderID));
$main->setCentralPayload($oPatternCustom);
$main->setErrorMessage("There was an error creating the folder $fFolderName on the filesystem");
$main->setFormAction($_SERVER["PHP_SELF"] . "?fFolderID=$fFolderID");
$main->setHasRequiredFields(true);
$main->render();
}
} else {
//couldn't associate the chosen document type with this folder
$default->log->error("addFolderBL.php DB error storing folder-document type link for folder name=$fFolderName in parent folder '" . Folder::getFolderPath($fFolderID) . "' folderID=$fFolderID; docTypeID=$fDocumentTypeID");
//remove the folder from the database
$oFolder->delete();
require_once("$default->fileSystemRoot/presentation/webpageTemplate.inc");
$oPatternCustom->setHtml(renderBrowsePage($fFolderID));
$main->setCentralPayload($oPatternCustom);
$main->setErrorMessage("There was an error creating the folder $fFolderName on the filesystem");
$main->setFormAction($_SERVER["PHP_SELF"] . "?fFolderID=$fFolderID");
$main->setHasRequiredFields(true);
$main->render();
}
} else {
//if we couldn't create the folder in the db, report an error
$default->log->error("addFolderBL.php DB error attempting to store folder name=$fFolderName in parent folder '" . Folder::getFolderPath($fFolderID) . "' id=$fFolderID");
require_once("$default->fileSystemRoot/presentation/webpageTemplate.inc");
$oPatternCustom->setHtml(renderBrowsePage($fFolderID));
$main->setCentralPayload($oPatternCustom);
$main->setErrorMessage("There was an error creating the folder $fFolderName in the database");
$main->setFormAction($_SERVER["PHP_SELF"] . "?fFolderID=$fFolderID");
$main->render();
}
}
} else {
//the user entered an illegal character in the folder name
require_once("$default->fileSystemRoot/presentation/webpageTemplate.inc");
$oPatternCustom->setHtml(renderBrowseAddPage($fFolderID));
$main->setCentralPayload($oPatternCustom);
$main->setErrorMessage("Folder not created. Folder names may not contain: '<', '>', '*', '/', '\', '|', '?' or '\"' ");
$main->setHasRequiredFields(true);
$main->setFormAction($_SERVER["PHP_SELF"] . "?fFolderID=$fFolderID");
$main->render();
}
} else {
//if the user doesn't have write permission for this folder,
//give them only browse facilities
require_once("$default->fileSystemRoot/presentation/webpageTemplate.inc");
$oPatternCustom->setHtml(renderBrowsePage($fFolderID));
$main->setCentralPayload($oPatternCustom);
$main->setErrorMessage("You do not have permission to create new folders in this folder");
$main->setFormAction($_SERVER["PHP_SELF"] . "?fFolderID=$fFolderID");
$main->render();
}
} else {
//there are no document type assigned to this folder
require_once("$default->fileSystemRoot/presentation/webpageTemplate.inc");
$oPatternCustom->setHtml(renderBrowseAddPage($fFolderID));
$main->setCentralPayload($oPatternCustom);
$main->setErrorMessage("You did not specify a document type. If there are no system document types, please contact a System Administrator.");
$main->setFormAction($_SERVER["PHP_SELF"] . "?fFolderID=$fFolderID");
$main->render();
}
}
} else {
require_once("$default->fileSystemRoot/presentation/webpageTemplate.inc");
$oPatternCustom->setHtml("");
$main->setCentralPayload($oPatternCustom);
$main->setErrorMessage("No folder currently selected");
$main->render();
}
}
?>
|