. * */ namespace SP\Import; use SP\DataModel\AccountExtData; use SP\DataModel\CategoryData; use SP\DataModel\CustomerData; use SP\Mgmt\Customers\Customer; use SP\Log\Log; use SP\Mgmt\Categories\Category; use SP\Core\Exceptions\SPException; defined('APP_ROOT') || die(_('No es posible acceder directamente a este archivo')); /** * Clase CsvImportBase para base de clases de importación desde archivos CSV * * @package SP */ abstract class CsvImportBase extends ImportBase { /** * @var int */ protected $numFields = 7; /** * @var array */ protected $mapFields = []; /** * @param int $numFields */ public function setNumFields($numFields) { $this->numFields = $numFields; } /** * @param array $mapFields */ public function setMapFields($mapFields) { $this->mapFields = $mapFields; } /** * Obtener los datos de las entradas de sysPass y crearlas * * @throws SPException * @throws \SP\Core\Exceptions\InvalidClassException */ protected function processAccounts() { $line = 0; $Log = new Log(_('Importar Cuentas')); foreach ($this->file->getFileContent() as $data) { $line++; $fields = str_getcsv($data, $this->ImportParams->getCsvDelimiter()); $numfields = count($fields); // Comprobar el número de campos de la línea if ($numfields !== $this->numFields) { throw new SPException( SPException::SP_CRITICAL, sprintf(_('El número de campos es incorrecto (%d)'), $numfields), sprintf(_('Compruebe el formato del archivo CSV en línea %s'), $line) ); } // Eliminar las " del principio/fin de los campos // array_walk($fields, // function (&$value, $key) { // $value = trim($value, '"'); // } // ); // Asignar los valores del array a variables list($accountName, $customerName, $categoryName, $url, $login, $password, $notes) = $fields; // Obtener los ids de cliente y categoría $CustomerData = new CustomerData(null, $customerName); Customer::getItem($CustomerData)->add(); $CategoryData = new CategoryData(null, $categoryName); Category::getItem($CategoryData)->add(); // Crear la nueva cuenta $AccountData = new AccountExtData(); $AccountData->setAccountName($accountName); $AccountData->setAccountLogin($login); $AccountData->setAccountCategoryId($CategoryData->getCategoryId()); $AccountData->setAccountCustomerId($CustomerData->getCustomerId()); $AccountData->setAccountNotes($notes); $AccountData->setAccountUrl($url); $AccountData->setAccountPass($password); try { $this->addAccount($AccountData); $Log->addDescription(sprintf(_('Cuenta importada: %s'), $accountName)); } catch (SPException $e) { // Escribir los mensajes pendientes $Log->writeLog(true); $Log->addDescription(_('Error importando cuenta')); $Log->addDescription(sprintf(_('Error procesando línea %s'), $line)); $Log->addDescription($e->getMessage()); // Flush y reset $Log->writeLog(true); } } $Log->writeLog(); } }