/** * Añadir una categoría y devolver el Id * @return int */ protected function addCategory() { return Category::addCategoryReturnId($this->getCategoryName(), $this->getCategoryDescription()); }
/** * Obtener los datos de las entradas de sysPass y crearlas * * @throws SPException */ protected function processAccounts() { $line = 0; $lines = $this->_file->getFileContent(); foreach ($lines as $data) { $line++; $fields = explode($this->_fieldDelimiter, $data); $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, categoría y la clave encriptada $customerId = Customer::addCustomerReturnId($customerName); $categoryId = Category::addCategoryReturnId($categoryName); $pass = Crypt::encryptData($password); // Crear la nueva cuenta $this->setAccountName($accountName); $this->setAccountLogin($login); $this->setCategoryId($categoryId); $this->setCustomerId($customerId); $this->setAccountNotes($notes); $this->setAccountUrl($url); $this->setAccountPass($pass['data']); $this->setAccountPassIV($pass['iv']); if (!$this->addAccount()) { $log = new Log(_('Importar Cuentas')); $log->addDescription(_('Error importando cuenta')); $log->addDescription(sprintf(_('Error procesando línea %s'), $line)); $log->writeLog(); } else { Log::writeNewLog(_('Importar Cuentas'), sprintf(_('Cuenta importada: %s'), $accountName)); } } }