Skip to content

Commit

Permalink
Update TYPO3 settings file logic.
Browse files Browse the repository at this point in the history
  • Loading branch information
andrewfrench committed Sep 29, 2018
1 parent ef6e2ab commit 88b498a
Showing 1 changed file with 19 additions and 11 deletions.
30 changes: 19 additions & 11 deletions pkg/ddevapp/typo3.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,31 +40,39 @@ $GLOBALS['TYPO3_CONF_VARS']['SYS']['displayErrors'] = 1;
// AdditionalConfiguration.php, adding things like database host, name, and
// password. Returns the fullpath to settings file and error
func createTypo3SettingsFile(app *DdevApp) (string, error) {

if !fileutil.FileExists(app.SiteSettingsPath) {
util.Warning("TYPO3 does not seem to have been set up yet, missing LocalConfiguration.php (%s)", app.SiteLocalSettingsPath)
util.Warning("TYPO3 does not seem to have been set up yet, missing %s (%s)", filepath.Base(app.SiteSettingsPath), app.SiteSettingsPath)
}

settingsFilePath, err := app.DetermineSettingsPathLocation()
if err != nil {
return "", fmt.Errorf("Failed to get TYPO3 AdditionalConfiguration.php file path: %v", err.Error())
// TYPO3 ddev settings file will be AdditionalConfiguration.php (app.SiteLocalSettingsPath).
// Check if the file already exists.
if fileutil.FileExists(app.SiteLocalSettingsPath) {
// Check if the file is managed by ddev.
signatureFound, err := fileutil.FgrepStringInFile(app.SiteLocalSettingsPath, DdevFileSignature)
if err != nil {
return "", err
}

// If the signature wasn't found, warn the user and return.
if !signatureFound {
util.Warning("%s already exists and is managed by the user.", filepath.Base(app.SiteLocalSettingsPath))
return app.SiteLocalSettingsPath, nil
}
}
output.UserOut.Printf("Generating %s file for database connection.", filepath.Base(settingsFilePath))

err = writeTypo3SettingsFile(app)
if err != nil {
return settingsFilePath, fmt.Errorf("Failed to write TYPO3 AdditionalConfiguration.php file: %v", err.Error())
output.UserOut.Printf("Generating %s file for database connection.", filepath.Base(app.SiteLocalSettingsPath))
if err := writeTypo3SettingsFile(app); err != nil {
return "", fmt.Errorf("failed to write TYPO3 AdditionalConfiguration.php file: %v", err.Error())
}

return settingsFilePath, nil
return app.SiteLocalSettingsPath, nil
}

// writeTypo3SettingsFile produces AdditionalConfiguration.php file
// It's assumed that the LocalConfiguration.php already exists, and we're
// overriding the db config values in it. The typo3conf/ directory will
// be created if it does not yet exist.
func writeTypo3SettingsFile(app *DdevApp) error {

filePath := app.SiteLocalSettingsPath

// Ensure target directory is writable.
Expand Down

0 comments on commit 88b498a

Please sign in to comment.