/** * Imports translations from a csv file * The CSV file has to have the same format as an Pimcore translation-export-file * * @static * @param $file - path to the csv file * @param bool $replaceExistingTranslations * @throws \Exception */ public static function importTranslationsFromFile($file, $replaceExistingTranslations = true, $languages = null) { $delta = []; if (is_readable($file)) { if (!$languages || empty($languages) || !is_array($languages)) { $languages = Tool::getValidLanguages(); } //read import data $tmpData = file_get_contents($file); //replace magic excel bytes $tmpData = str_replace("", "", $tmpData); //convert to utf-8 if needed $tmpData = Tool\Text::convertToUTF8($tmpData); //store data for further usage $importFile = PIMCORE_SYSTEM_TEMP_DIRECTORY . "/import_translations"; File::put($importFile, $tmpData); $importFileOriginal = PIMCORE_SYSTEM_TEMP_DIRECTORY . "/import_translations_original"; File::put($importFileOriginal, $tmpData); // determine csv type $dialect = Tool\Admin::determineCsvDialect(PIMCORE_SYSTEM_TEMP_DIRECTORY . "/import_translations_original"); //read data if (($handle = fopen(PIMCORE_SYSTEM_TEMP_DIRECTORY . "/import_translations", "r")) !== false) { while (($rowData = fgetcsv($handle, 0, $dialect->delimiter, $dialect->quotechar, $dialect->escapechar)) !== false) { $data[] = $rowData; } fclose($handle); } //process translations if (is_array($data) and count($data) > 1) { $keys = $data[0]; // remove wrong quotes in some export/import constellations $keys = array_map(function ($value) { return trim($value, '""'); }, $keys); $data = array_slice($data, 1); foreach ($data as $row) { $keyValueArray = []; for ($counter = 0; $counter < count($row); $counter++) { $rd = str_replace(""", '"', $row[$counter]); $keyValueArray[$keys[$counter]] = $rd; } $textKey = $keyValueArray["key"]; if ($textKey) { $t = static::getByKey($textKey, true); $dirty = false; foreach ($keyValueArray as $key => $value) { if (in_array($key, $languages)) { $currentTranslation = $t->getTranslation($key); if ($replaceExistingTranslations) { $t->addTranslation($key, $value); if ($currentTranslation != $value) { $dirty = true; } } else { if (!$t->getTranslation($key)) { $t->addTranslation($key, $value); if ($currentTranslation != $value) { $dirty = true; } } elseif ($t->getTranslation($key) != $value && $value) { $delta[] = ["lg" => $key, "key" => $textKey, "text" => $t->getTranslation($key), "csv" => $value]; } } } } if ($dirty) { if ($keyValueArray['creationDate']) { $t->setCreationDate($keyValueArray['creationDate']); } $t->setModificationDate(time()); //ignore modificationDate from file $t->save(); } } } Model\Translation\AbstractTranslation::clearDependentCache(); } else { throw new \Exception("less than 2 rows of data - nothing to import"); } } else { throw new \Exception("{$file} is not readable"); } return $delta; }
/** * IMPORTER */ public function importUploadAction() { $data = file_get_contents($_FILES["Filedata"]["tmp_name"]); $data = Tool\Text::convertToUTF8($data); $importFile = PIMCORE_SYSTEM_TEMP_DIRECTORY . "/import_" . $this->getParam("id"); File::put($importFile, $data); $importFileOriginal = PIMCORE_SYSTEM_TEMP_DIRECTORY . "/import_" . $this->getParam("id") . "_original"; File::put($importFileOriginal, $data); $this->_helper->json(array("success" => true), false); // set content-type to text/html, otherwise (when application/json is sent) chrome will complain in // Ext.form.Action.Submit and mark the submission as failed $this->getResponse()->setHeader("Content-Type", "text/html"); }
/** * @param null $page * @param null $path * @return bool|string * @throws \Exception */ public function getText($page = null, $path = null) { $path = $path ? $this->preparePath($path) : $this->path; if ($page || parent::isFileTypeSupported($path)) { // for per page extraction we have to convert the document to PDF and extract the text via ghostscript return parent::getText($page, $this->getPdf($path)); } elseif (File::getFileExtension($path)) { // if we want to get the text of the whole document, we can use libreoffices text export feature $cmd = self::getLibreOfficeCli() . " --headless --nologo --nofirststartwizard --norestore --convert-to txt:Text --outdir " . escapeshellarg(PIMCORE_TEMPORARY_DIRECTORY) . " " . escapeshellarg($path); $out = Console::exec($cmd, null, 240); Logger::debug("LibreOffice Output was: " . $out); $tmpName = PIMCORE_TEMPORARY_DIRECTORY . "/" . preg_replace("/\\." . File::getFileExtension($path) . "\$/", ".txt", basename($path)); if (file_exists($tmpName)) { $text = file_get_contents($tmpName); $text = \Pimcore\Tool\Text::convertToUTF8($text); unlink($tmpName); return $text; } else { $message = "Couldn't convert document to PDF: " . $path . " with the command: '" . $cmd . "' - now trying to get the text out of the PDF ..."; Logger::error($message); return parent::getText(null, $this->getPdf($path)); } } return ""; // default empty string }