This repository has been archived on 2024-11-28. You can view files and clone it, but cannot push or open issues or pull requests.
Incam_SGD/plugins/multiselect/BulkUpload.php

421 lines
15 KiB
PHP
Raw Permalink Normal View History

<?php
/**
* $Id$
*
* KnowledgeTree Community Edition
* Document Management Made Simple
* Copyright (C) 2008, 2009 KnowledgeTree Inc.
*
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU General Public License version 3 as published by the
* Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* You can contact KnowledgeTree Inc., PO Box 7775 #87847, San Francisco,
* California 94120-7775, or email info@knowledgetree.com.
*
* The interactive user interfaces in modified source and object code versions
* of this program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU General Public License version 3.
*
* In accordance with Section 7(b) of the GNU General Public License version 3,
* these Appropriate Legal Notices must retain the display of the "Powered by
* KnowledgeTree" logo and retain the original copyright notice. If the display of the
* logo is not reasonably feasible for technical reasons, the Appropriate Legal Notices
* must display the words "Powered by KnowledgeTree" and retain the original
* copyright notice.
* Contributor( s): ______________________________________
*
*/
require_once(KT_LIB_DIR . "/actions/folderaction.inc.php");
require_once(KT_LIB_DIR . "/import/zipimportstorage.inc.php");
require_once(KT_LIB_DIR . "/import/bulkimport.inc.php");
require_once(KT_LIB_DIR . "/widgets/FieldsetDisplayRegistry.inc.php");
require_once(KT_LIB_DIR . "/widgets/fieldWidgets.php");
require_once(KT_LIB_DIR . "/widgets/fieldsetDisplay.inc.php");
require_once(KT_LIB_DIR . "/validation/dispatchervalidation.inc.php");
require_once(KT_LIB_DIR . "/metadata/fieldsetregistry.inc.php");
require_once(KT_LIB_DIR . "/widgets/widgetfactory.inc.php");
require_once(KT_LIB_DIR . "/validation/validatorfactory.inc.php");
class InetBulkUploadFolderAction extends KTFolderAction {
var $sName = 'inet.actions.folder.bulkUpload';
var $_sShowPermission = "ktcore.permissions.write";
var $bAutomaticTransaction = false;
/**
* returns the string
* @return
* loads the necessary javascripts too.
*
* iNET Process
*/
function getDisplayName() {
if(!KTPluginUtil::pluginIsActive('inet.foldermetadata.plugin'))
{
$aJavascript[] = 'thirdpartyjs/jquery/jquery-1.3.2.js';
$aJavascript[] = 'thirdpartyjs/jquery/jquery_noconflict.js';
$oPage =& $GLOBALS['main'];
if (method_exists($oPage, 'requireJSResources')) {
$oPage->requireJSResources($aJavascript);
}
$js = "<script src='resources/js/kt_hidelink.js' type='text/javascript'></script>";
return $js._kt('Bulk Upload');
}
else
{
return null;
}
}
/**
* Checks for bulk uploads
* @return
*
* iNET Process
*/
function check() {
$res = parent::check();
if (empty($res)) {
return $res;
}
$postExpected = KTUtil::arrayGet($_REQUEST, "postExpected");
$postReceived = KTUtil::arrayGet($_REQUEST, "postReceived");
if (!empty($postExpected)) {
$aErrorOptions = array(
'redirect_to' => array('main', sprintf('fFolderId=%d', $this->oFolder->getId())),
'message' => _kt('Upload larger than maximum POST size (post_max_size variable in .htaccess or php.ini)'),
);
$this->oValidator->notEmpty($postReceived, $aErrorOptions);
}
return true;
}
/**
* default and basic function
* @return template
* @param.
* iNET Process
*
*/
function do_main() {
$bulkUploadForm = $this->getBulkUploadForm();
return $bulkUploadForm->render();
}
/**
* Returns the main Bulk Upload Form
* @return KTForm
*
*/
function getBulkUploadForm() {
$this->oPage->setBreadcrumbDetails(_kt("bulk upload"));
//Adding the required Bulk Upload javascript includes
$aJavascript[] = 'resources/js/taillog.js';
$aJavascript[] = 'resources/js/conditional_usage.js';
$aJavascript[] = 'resources/js/kt_bulkupload.js';
//Loading the widget js libraries to support dynamic "Ajax Loaded" widget rendering
//FIXME: The widgets can support this via dynamic call to place libs in the head if they aren't loaded
// jQuery can do this but need time to implement/test.
$aJavascript[] = 'thirdpartyjs/jquery/jquery-1.3.2.js';
$aJavascript[] = 'thirdpartyjs/tinymce/jscripts/tiny_mce/tiny_mce.js';
$aJavascript[] = 'resources/js/kt_tinymce_init.js';
$aJavascript[] = 'thirdpartyjs/tinymce/jscripts/tiny_mce/jquery.tinymce.js';
$this->oPage->requireJSResources($aJavascript);
//FIXME: Might really not need to load these styles, will check l8r
//$this->oPage->requireCSSResource('resources/css/kt-treewidget.css')}
//Creating the form
$oForm = new KTForm;
$oForm->setOptions(array(
'identifier' => 'ktcore.folder.bulkUpload',
'label' => _kt('Bulk Upload'),
'submit_label' => _kt('Upload'),
'action' => 'upload',
'fail_action' => 'main',
'encoding' => 'multipart/form-data',
'file_upload' => true,
// 'cancel_url' => KTBrowseUtil::getUrlForDocument($this->oDocument),
'context' => &$this,
'extraargs' => $this->meldPersistQuery("","",true),
'description' => _kt('The bulk upload facility allows for a number of documents to be added to the document management system. Provide an archive (ZIP) file from your local computer, and all documents and folders within that archive will be added to the document management system.')
));
$oWF =& KTWidgetFactory::getSingleton();
$widgets = array();
$validators = array();
// Adding the File Upload Widget
//Legacy kt3 widgets don't conform to ktcore type widgets by virtue of the 'name' attribute.
//$widgets[] = new KTFileUploadWidget(_kt('Archive file'), , 'file', "", $this->oPage, true, "file");
$widgets[] = $oWF->get('ktcore.widgets.file', array(
'label' => _kt('Archive file'),
'required' => true,
'name' => 'file',
'id' => 'file',
'value' => '',
'description' => _kt('The archive file containing the documents you wish to add to the document management system.'),
));
$aVocab = array('' => _kt('- Please select a document type -'));
foreach (DocumentType::getListForUserAndFolder($this->oUser, $this->oFolder) as $oDocumentType) {
if(!$oDocumentType->getDisabled()) {
$aVocab[$oDocumentType->getId()] = $oDocumentType->getName();
}
}
//Adding document type lookup widget
$widgets[] = $oWF->get('ktcore.widgets.selection',array(
'label' => _kt('Document Type'),
'id' => 'add-document-type',
'description' => _kt('Document Types, defined by the administrator, are used to categorise documents. Please select a Document Type from the list below.'),
'name' => 'fDocumentTypeId',
'required' => true,
'vocab' => $aVocab,
'id_method' => 'getId',
'label_method' => 'getName',
'simple_select' => false,
));
//Adding the quick "add" button for when no meta data needs to be added.
//FIXME: This widget should only display if there are any "required" fields for the given document type
// Default/general document field type must also be taken into consideration
$widgets[] = $oWF->get('ktcore.widgets.button',array(
'value' => _kt('Add'),
'id' => 'quick_add',
'description' => _kt('If you do not need to modify any the metadata for this document (see below), then you can simply click "Add" here to finish the process and add the document.'),
'name' => 'btn_quick_submit',
));
$oFReg =& KTFieldsetRegistry::getSingleton();
$activesets = KTFieldset::getGenericFieldsets();
foreach ($activesets as $oFieldset) {
$widgets = kt_array_merge($widgets, $oFReg->widgetsForFieldset($oFieldset, 'fieldset_' . $oFieldset->getId(), $this->oDocument));
$validators = kt_array_merge($validators, $oFReg->validatorsForFieldset($oFieldset, 'fieldset_' . $oFieldset->getId(), $this->oDocument));
}
//Adding the type_metadata_fields layer to be updated via ajax for non generic metadata fieldsets
$widgets[] = $oWF->get('ktcore.widgets.layer',array(
'value' => '',
'id' => 'type_metadata_fields',
));
$oForm->setWidgets($widgets);
$oForm->setValidators($validators);
// Implement an electronic signature for accessing the admin section, it will appear every 10 minutes
global $default;
$iFolderId = $this->oFolder->getId();
if($default->enableESignatures){
$sUrl = KTPluginUtil::getPluginPath('electronic.signatures.plugin', true);
$heading = _kt('You are attempting to perform a bulk upload');
$submit['type'] = 'button';
$submit['onclick'] = "javascript: showSignatureForm('{$sUrl}', '{$heading}', 'ktcore.transactions.bulk_upload', 'bulk', 'bulk_upload_form', 'submit', {$iFolderId});";
}else{
$submit['type'] = 'submit';
$submit['onclick'] = '';
}
return $oForm;
}
/**
* make uploads
* @return
*
* iNET Process
*/
function do_upload() {
set_time_limit(0);
global $default;
$aErrorOptions = array(
'redirect_to' => array('main', sprintf('fFolderId=%d', $this->oFolder->getId())),
);
$aErrorOptions['message'] = _kt('Invalid document type provided');
$requestDocumentType = $_REQUEST['fDocumentTypeId']; //Backwards compatibility
if ($requestDocumentType == '' || $requestDocumentType == NULL) {
$requestDocumentType = $_REQUEST['data'];
$requestDocumentType = $requestDocumentType['fDocumentTypeId']; //New elements come through as arrays
}
$oDocumentType = $this->oValidator->validateDocumentType($requestDocumentType, $aErrorOptions);
unset($aErrorOptions['message']);
$fileData = $_FILES['file'];
$fileName = 'file';
if ($fileData == '' || $fileData == NULL){
$fileData = $_FILES['_kt_attempt_unique_file'];//$_FILES['_kt_attempt_unique_file'];
$fileName = '_kt_attempt_unique_file';
}
$aFile = $this->oValidator->validateFile($fileData, $aErrorOptions);
// Lets move the file from the windows temp directory into our own directory
$oKTConfig =& KTConfig::getSingleton();
$sBasedir = $oKTConfig->get("urls/tmpDirectory");
$tmpFilename = tempnam($sBasedir, 'kt_storebulk');
$oStorage =& KTStorageManagerUtil::getSingleton();
$res = $oStorage->uploadTmpFile($fileData['tmp_name'], $tmpFilename, array('copy_upload' => 'true'));
// Save the new temp filename in the file data array
$fileData['tmp_name'] = $tmpFilename;
if($res === false){
$default->log->error('File could not be copied from the system temp directory.');
exit('File could not be copied from the system temp directory.');
}
$matches = array();
$aFields = array();
// author: Charl Mert
// Older kt3 form field submission used name='metadata_9 etc and the aFields array contained them.'
// Should keep open here for backwards compatibility but will close it to "discover" the other
// old interfaces.
/*
foreach ($_REQUEST as $k => $v) {
if (preg_match('/^metadata_(\d+)$/', $k, $matches)) {
// multiselect change start
$oDocField = DocumentField::get($matches[1]);
if(KTPluginUtil::pluginIsActive('inet.multiselect.lookupvalue.plugin') && $oDocField->getHasInetLookup() && is_array($v))
{
$v = join(", ", $v);
}
$aFields[] = array($oDocField, $v);
// previously it was just one line which is commented, just above line
// multiselect change end
}
}
*/
//Newer metadata form field catcher that works with ktcore form array type fields named like
//name='metadata[fieldset][metadata_9]'
$aData = $_REQUEST['data'];
/* //This validation breaks with ajax loaded form items e.g. a non generic fieldset that submits
* //values doesn't pass the check below.
$oForm = $this->getBulkUploadForm();
$res = $oForm->validate();
if (!empty($res['errors'])) {
return $oForm->handleError();
}
$data = $res['results'];
var_dump($data);
*/
$data = $aData;
$doctypeid = $requestDocumentType;
$aGenericFieldsetIds = KTFieldset::getGenericFieldsets(array('ids' => false));
$aSpecificFieldsetIds = KTFieldset::getForDocumentType($doctypeid, array('ids' => false));
$fieldsets = kt_array_merge($aGenericFieldsetIds, $aSpecificFieldsetIds);
$MDPack = array();
foreach ($fieldsets as $oFieldset) {
$fields = $oFieldset->getFields();
$values = (array) KTUtil::arrayGet($data, 'fieldset_' . $oFieldset->getId());
//var_dump($values);
foreach ($fields as $oField) {
//var_dump($oField->getId());
$val = KTUtil::arrayGet($values, 'metadata_' . $oField->getId());
//Fix for multiselect not submitting data due to the value not being flat.
$sVal = '';
if (is_array($val)) {
foreach ($val as $v) {
$sVal .= $v . ", ";
}
$sVal = substr($sVal, 0, strlen($sVal) - 2);
$val = $sVal;
}
if ($oFieldset->getIsConditional())
{
if ($val == _kt('No selection.'))
{
$val = null;
}
}
if (!is_null($val)) {
$MDPack[] = array(
$oField,
$val
);
}
}
}
$aOptions = array(
'documenttype' => $oDocumentType,
'metadata' => $MDPack,
);
$fs =& new KTZipImportStorage($fileName, $fileData);
if(!$fs->CheckFormat()){
$sFormats = $fs->getFormats();
$this->addErrorMessage(sprintf(_kt("Bulk Upload failed. Archive is not an accepted format. Accepted formats are: .%s") , $sFormats));
controllerRedirect("browse", 'fFolderId=' . $this->oFolder->getID());
exit;
}
if(KTPluginUtil::pluginIsActive('inet.foldermetadata.plugin'))
{
require_once(KT_DIR . "/plugins/foldermetadata/import/bulkimport.inc.php");
$bm =& new KTINETBulkImportManager($this->oFolder, $fs, $this->oUser, $aOptions);
}
else
{
$bm =& new KTBulkImportManager($this->oFolder, $fs, $this->oUser, $aOptions);
}
$this->startTransaction();
$res = $bm->import();
$aErrorOptions['message'] = _kt("Bulk Upload failed");
$this->oValidator->notError($res, $aErrorOptions);
$this->addInfoMessage(_kt("Bulk Upload successful"));
$this->commitTransaction();
controllerRedirect("browse", 'fFolderId=' . $this->oFolder->getID());
exit(0);
}
}
?>