. * * 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/fsimportstorage.inc.php"); require_once(KT_LIB_DIR . "/import/bulkimport.inc.php"); require_once(KT_LIB_DIR . "/documentmanagement/observers.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"); class InetBulkImportFolderMultiSelectAction extends KTFolderAction { var $sName = 'inet.actions.folder.bulkImport.multiselect'; var $_sShowPermission = "ktcore.permissions.write"; var $bAutomaticTransaction = false; /** * hide existing url and return name to new url | iNET Process * @Return string. * @param. */ function getDisplayName() { if(!KTPluginUtil::pluginIsActive('inet.foldermetadata.plugin')) { $js .= ""; $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); } return $js._kt('Import from Server Location'); } else { return null; } } /** * check for permissions | iNET Process * @Return unknown. * @param. */ function getInfo() { global $default; if($default->disableBulkImport){ return null; } if (!Permission::userIsSystemAdministrator($this->oUser->getId())) { return null; } return parent::getInfo(); } /** * Returns the main Bulk Upload Form * @return KTForm * */ function getBulkImportForm() { $this->oPage->setBreadcrumbDetails(_kt("bulk import")); //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); $oForm = new KTForm; $oForm->setOptions(array( 'identifier' => 'ktcore.folder.bulkUpload', 'label' => _kt('Import from Server Location'), 'submit_label' => _kt('Import'), 'action' => 'import', 'fail_action' => 'main', 'encoding' => 'multipart/form-data', // 'cancel_url' => KTBrowseUtil::getUrlForDocument($this->oDocument), 'context' => &$this, 'extraargs' => $this->meldPersistQuery("","",true), 'description' => _kt('The bulk import facility allows for a number of documents to be added to the document management system easily. Provide a path on the server, and all documents and folders within that path 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.string', array( 'label' => _kt('Path'), 'required' => true, 'name' => 'path', 'id' => 'path', 'value' => '', 'description' => _kt('The path containing the documents to be added 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; } /** * This is Default function to be called load template for import action. | iNET Process * @Return template. * @param. */ function do_main() { return $this->getBulkImportForm()->render(); } /** * Performs actual import action. | iNET Process * @Return. * @param. */ function do_import() { set_time_limit(0); $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); $aErrorOptions['message'] = _kt('Invalid path provided'); $tmpPath = $_REQUEST['path']; //Backwards compatibility if ($tmpPath == '') { $tmpPath = $_REQUEST['data']; $tmpPath = $tmpPath['path']; } $sPath = $this->oValidator->validateString($tmpPath, $aErrorOptions); /* $matches = array(); $aFields = array(); 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 } } $aOptions = array( 'documenttype' => $oDocumentType, 'metadata' => $aFields, 'copy_upload' => 'true', ); */ // Newer metadata form field catcher that works with ktcore form array type fields named like // name='metadata[fieldset][metadata_9]' $aData = $_REQUEST['data']; $data = $aData; /* $oForm = $this->getBulkImportForm(); $res = $oForm->validate(); if (!empty($res['errors'])) { return $oForm->handleError(); } $data = $res['results']; */ $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()); foreach ($fields as $oField) { $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, 'copy_upload' => 'true', ); $po =& new JavascriptObserver($this); $po->start(); $oUploadChannel =& KTUploadChannel::getSingleton(); $oUploadChannel->addObserver($po); $fs =& new KTFSImportStorage($sPath); $bm =& new KTBulkImportManager($this->oFolder, $fs, $this->oUser, $aOptions); 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); } DBUtil::startTransaction(); $res = $bm->import(); if (PEAR::isError($res)) { DBUtil::rollback(); $_SESSION["KTErrorMessage"][] = _kt("Bulk import failed") . ": " . $res->getMessage(); } else { DBUtil::commit(); $this->addInfoMessage(_kt("Bulk import succeeded")); } $po->redirectToFolder($this->oFolder->getId()); exit(0); } }