/** * Returns a field name used in the database. This is the property name converted * to lowercase underscore (mySpecialProperty -> my_special_property). * * @return string the field name in lowercase underscore */ public function getFieldName() { $fieldName = t3lib_div::camelCaseToLowerCaseUnderscored($this->name); if (Tx_ExtensionBuilder_Domain_Validator_ExtensionValidator::isReservedMYSQLWord($fieldName)) { $fieldName = $this->domainObject->getExtension()->getShortExtensionKey() . '_' . $fieldName; } return $fieldName; }
/** * Generate the code files according to the transferred JSON configuration * * @throws Exception * @return array (status => message) */ protected function rpcAction_save() { try { $extensionBuildConfiguration = $this->configurationManager->getConfigurationFromModeler(); t3lib_div::devlog('Modeler Configuration', 'extension_builder', 0, $extensionBuildConfiguration); $validationConfigurationResult = $this->extensionValidator->validateConfigurationFormat($extensionBuildConfiguration); if (!empty($validationConfigurationResult['warnings'])) { $confirmationRequired = $this->handleValidationWarnings($validationConfigurationResult['warnings']); if (!empty($confirmationRequired)) { return $confirmationRequired; } } $extension = $this->extensionSchemaBuilder->build($extensionBuildConfiguration); } catch (Exception $e) { throw $e; } // Validate the extension $validationResult = $this->extensionValidator->isValid($extension); if (!empty($validationResult['errors'])) { $errorMessage = ''; foreach ($validationResult['errors'] as $exception) { $errorMessage .= '<br />' . $exception->getMessage(); } throw new Exception($errorMessage); } if (!empty($validationResult['warnings'])) { $confirmationRequired = $this->handleValidationWarnings($validationResult['warnings']); if (!empty($confirmationRequired)) { return $confirmationRequired; } } $extensionDirectory = $extension->getExtensionDir(); if (!is_dir($extensionDirectory)) { t3lib_div::mkdir($extensionDirectory); } else { if ($this->settings['extConf']['backupExtension'] == 1) { try { Tx_ExtensionBuilder_Service_RoundTrip::backupExtension($extension, $this->settings['extConf']['backupDir']); } catch (Exception $e) { throw $e; } } $extensionSettings = $this->configurationManager->getExtensionSettings($extension->getExtensionKey()); if ($this->settings['extConf']['enableRoundtrip'] == 1) { if (empty($extensionSettings)) { // no config file in an existing extension! // this would result in a total overwrite so we create one and give a warning $this->configurationManager->createInitialSettingsFile($extension, $this->settings['codeTemplateRootPath']); return array('warning' => "<span class='error'>Roundtrip is enabled but no configuration file was found.</span><br />This might happen if you use the extension builder the first time for this extension. <br />A settings file was generated in <br /><b>typo3conf/ext/" . $extension->getExtensionKey() . "/Configuration/ExtensionBuilder/settings.yaml.</b><br />Configure the overwrite settings, then save again."); } try { Tx_ExtensionBuilder_Service_RoundTrip::prepareExtensionForRoundtrip($extension); } catch (Exception $e) { throw $e; } } } try { $this->codeGenerator->build($extension); $this->extensionInstallationStatus->setExtension($extension); $message = '<p>The Extension was saved</p>' . $this->extensionInstallationStatus->getStatusMessage(); if ($extension->getNeedsUploadFolder()) { $message .= '<br />Notice: File upload is not yet implemented.'; } $result = array('success' => $message); } catch (Exception $e) { throw $e; } $this->extensionRepository->saveExtensionConfiguration($extension); return $result; }