All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.intershop.gradle.icm.docker.tasks.GenICMProperties.kt Maven / Gradle / Ivy

/*
 * Copyright 2020 Intershop Communications AG.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 */
package com.intershop.gradle.icm.docker.tasks

import com.intershop.gradle.icm.docker.extension.IntershopDockerExtension
import com.intershop.gradle.icm.docker.utils.Configuration
import com.intershop.gradle.icm.docker.utils.IPFinder
import org.gradle.api.DefaultTask
import org.gradle.api.file.DirectoryProperty
import org.gradle.api.file.ProjectLayout
import org.gradle.api.model.ObjectFactory
import org.gradle.api.provider.Property
import org.gradle.api.tasks.Input
import org.gradle.api.tasks.Internal
import org.gradle.api.tasks.OutputDirectory
import org.gradle.api.tasks.TaskAction
import org.gradle.api.tasks.options.Option
import org.gradle.kotlin.dsl.getByType
import java.io.File
import java.net.UnknownHostException
import javax.inject.Inject
import com.intershop.gradle.icm.docker.utils.mail.TaskPreparer as MailTaskPreparer
import com.intershop.gradle.icm.docker.utils.mssql.TaskPreparer as MSSQLTaskPreparer
import com.intershop.gradle.icm.docker.utils.oracle.TaskPreparer as OracleTaskPreparer

open class GenICMProperties @Inject constructor(
        objectFactory: ObjectFactory,
        projectLayout: ProjectLayout,
) : DefaultTask() {

    companion object {
        const val standardDevProps =
                """
                      # development properties
                      # switch auto reload on for all Intershop artifacts
                      intershop.extensions.CheckSource=true
                      intershop.queries.CheckSource=true
                      intershop.pipelines.CheckSource=true
                      intershop.pagelets.CheckSource=true
                      intershop.webforms.CheckSource=true
                      intershop.template.CheckSource=true
                      intershop.template.CheckSourceModified=true
                      intershop.template.isfilebundle.CheckSource=true
                      intershop.urlrewrite.CheckSource=true
                    
                      # switch all preload functionality off
                      intershop.pipelines.PreloadFromCartridges=
                      intershop.pipelines.PreloadFromSites=
                      intershop.pipelets.PreloadFromCartridges=
                      intershop.template.CompileOnStartup=false
                      intershop.webforms.Preload=false
                      intershop.queries.Preload=false
                    
                      # use strict modes in pipeline engine
                      intershop.pipelines.strict.CheckParameterTypes=true
                      intershop.pipelets.OnLoadError=Exception
                    
                      # switch all runtime sensors on
                      intershop.monitoring.requests=true
                      intershop.monitoring.pipelines=true
                      intershop.monitoring.pipelets=true
                      intershop.monitoring.pipelinenodes=true
                      intershop.monitoring.templates=true
                      intershop.monitoring.queries=true
                      intershop.monitoring.sql=true
                      intershop.monitoring.class=true
                      intershop.monitoring.maxSensors=100000
                    
                      # developer's helpers
                      intershop.template.PrintTemplateName=true
                      intershop.template.PrintTemplateMarker=true
                      intershop.session.TimeOut=300
                      intershop.CSRFGuard.allowRecovery=true
            """

        const val databaseTypeProp = Configuration.DB_TYPE
        const val databaseJDBCUrlProp = Configuration.DB_JDBC_URL

        const val webserverUrlProp = "intershop.WebServerURL"
        const val webserverSecureUrlProp = "intershop.WebServerSecureURL"

        const val asConnectorAdressProp = Configuration.AS_CONNECTOR_ADDRESS

        const val asSolrZKListProp = Configuration.SOLR_CLOUD_HOSTLIST
        const val asSolrPrefixProp = Configuration.SOLR_CLOUD_INDEXPREFIX

        const val asMailHostProp = "mail.smtp.host"
        const val asMailPortProp = "mail.smtp.port"

        const val asMailSMTPHostProp = "intershop.SMTPServer"
        const val asMailMessageIDProp = "intershop.mail.messageID.domain"

        const val ICM_PROPERTIES_DIR = "icmproperties"
        const val fileName = "icm.properties"
    }

    @Internal
    protected val extension = project.extensions.getByType()

    @get:OutputDirectory
    val outputDirectory: DirectoryProperty = objectFactory.directoryProperty()

    @get:Option(option = "icmenvops", description =
    """A comma-separated list of options for the icm.properties files.
            dev - General development properties for the application server
            mail - MailHog container is used as test mail server
            solr - Single node solr cluster with containers is used
        """)
    @get:Input
    val contentOptions: Property = project.objects.property(String::class.java)

    @get:Option(option = "db", description =
    """Option for the used database. The following values are possible:
            oracle-container - Oracle configuration for database provided by a container 
            oracle - Oracle configuration for an external database
            mssql-container - MSSQL configuration for database provided by a container
            mssql - MSSQL configuration for an external database
        """)
    @get:Input
    val dbOption: Property = project.objects.property(String::class.java)

    @get:Option(option = "icmas", description = "If this parameter specified, the properties file " +
                                                "will be generated for app server development.")
    @get:Input
    val icmasOption: Property = project.objects.property(Boolean::class.java)

    init {
        outputDirectory.convention(projectLayout.buildDirectory.dir(ICM_PROPERTIES_DIR))
        contentOptions.convention("")
        icmasOption.convention(false)
        dbOption.convention("")
    }

    @TaskAction
    fun createFile() {
        val outputFile = outputDirectory.file(fileName).get().asFile
        if (outputFile.exists()) {
            outputFile.delete()
        } else {
            outputFile.createNewFile()
        }
        val optList = contentOptions.get().split(",")

        if (optList.contains("dev")) {
            writeDevProps(outputFile)
        }

        val db = dbOption.get()
        when {
            db.startsWith("oracle-c") -> writeOracleProps(outputFile, true)
            db == "oracle" -> writeOracleProps(outputFile, false)
            db.startsWith("mssql-c") -> writeMSSQLProps(outputFile, true)
            db == "mssql" -> writeMSSQLProps(outputFile, false)
            else -> project.logger.quiet("No database option is specified!")
        }

        writeServerProps(outputFile)

        writeMailProps(outputFile, optList.contains("mail"))
        writeSolrProps(outputFile, optList.contains("solr"))

        writeGebTestProps(outputFile)

        val envListTasks = mutableListOf()

        addTo(envListTasks, "mail", optList.contains("mail"))
        addTo(envListTasks, "solr", optList.contains("solr"))
        addTo(envListTasks, "oracle", db.startsWith("oracle-c"))
        addTo(envListTasks, "mssql", db.startsWith("mssql-c"))
        addTo(envListTasks, "webserver", true)

        val text =
                """
            # The following containers will be started / stopped with
            # startEnv / stopEnv. The container can be configured in 
            # the docker image extension.
            ${Configuration.CONTAINER_ENV_PROP} = ${envListTasks.joinToString(",")}
            """.trimIndent()

        outputFile.appendText(text, Charsets.UTF_8)
        outputFile.appendText("\n\n", Charsets.UTF_8)
    }

    private fun addTo(list: MutableList, value: String, check: Boolean) {
        if (check) {
            list.add(value)
        }
    }

    private fun writeDevProps(file: File) {
        file.appendText(standardDevProps.trimIndent(), Charsets.UTF_8)
        file.appendText("\n\n", Charsets.UTF_8)
    }

    private fun writeDBUserConfig(file: File, container: Boolean) {
        val user = if (container) {
            Configuration.DB_USER_NAME_VALUE
        } else {
            ""
        }
        val password = if (container) {
            Configuration.DB_USER_PASSWORD_VALUE
        } else {
            ""
        }

        val text =
                """
            ${Configuration.DB_USER_NAME} = $user
            ${Configuration.DB_USER_PASSWORD} = $password
            """.trimIndent()
        file.appendText(text, Charsets.UTF_8)
        file.appendText("\n\n", Charsets.UTF_8)
    }

    private fun writeOracleProps(file: File, container: Boolean) {
        val icmas = icmasOption.get()

        val host = if (icmas) {
            if (container) {
                "localhost"
            } else {
                ""
            }
        } else {
            if (container) {
                "${extension.containerPrefix}-${OracleTaskPreparer.extName.lowercase()}"
            } else {
                ""
            }
        }
        val port = if (icmas) {
            if (container) {
                Configuration.DB_ORACLE_LISTENERPORT_VALUE
            } else {
                ""
            }
        } else {
            if (container) {
                Configuration.DB_ORACLE_CONTAINER_LISTENERPORT_VALUE
            } else {
                ""
            }
        }

        val sid = if (container) {
            "XE"
        } else {
            ""
        }

        val text =
                """
            # oracle base configuration
            $databaseTypeProp = oracle
            $databaseJDBCUrlProp = jdbc:oracle:thin:@$host:$port:$sid
            """.trimIndent()

        file.appendText(text, Charsets.UTF_8)
        file.appendText("\n", Charsets.UTF_8)
        writeDBUserConfig(file, container)

        if (container) {
            val ctext =
                    """
            # mssql container configuration - do not change this value if the default images is used 
            ${Configuration.DB_ORACLE_LISTENERPORT} = ${Configuration.DB_ORACLE_LISTENERPORT_VALUE}
            ${Configuration.DB_ORACLE_CONTAINER_LISTENERPORT} = ${Configuration.DB_ORACLE_CONTAINER_LISTENERPORT_VALUE}
            ${Configuration.DB_ORACLE_PORT} = ${Configuration.DB_ORACLE_PORT_VALUE}
            ${Configuration.DB_ORACLE_CONTAINER_PORT} = ${Configuration.DB_ORACLE_CONTAINER_PORT_VALUE}
            """.trimIndent()
            file.appendText(ctext, Charsets.UTF_8)
            file.appendText("\n\n", Charsets.UTF_8)
        }
    }

    private fun writeMSSQLProps(file: File, container: Boolean) {
        val icmas = icmasOption.get()

        val host = if (icmas) {
            if (container) {
                "localhost"
            } else {
                ""
            }
        } else {
            if (container) {
                "${extension.containerPrefix}-${MSSQLTaskPreparer.extName.lowercase()}"
            } else {
                ""
            }
        }
        val port = if (icmas) {
            if (container) {
                Configuration.DB_MSSQL_PORT_VALUE
            } else {
                ""
            }
        } else {
            if (container) {
                Configuration.DB_MSSQL_CONTAINER_PORT_VALUE
            } else {
                ""
            }
        }

        val dbname = if (container) {
            Configuration.DB_MSSQL_DBNAME_VALUE
        } else {
            ""
        }

        val text =
                """
            # mssql base configuration
            $databaseTypeProp = mssql
            $databaseJDBCUrlProp = jdbc:sqlserver://$host:$port;databaseName=$dbname
            """.trimIndent()

        file.appendText(text, Charsets.UTF_8)
        file.appendText("\n", Charsets.UTF_8)
        writeDBUserConfig(file, container)

        with(Configuration) {
            if (container) {
                val ctext =
                        """
                    $DATA_FOLDER_PATH =
                    $BACKUP_FOLDER_PATH =
                        
                    # mssql container configuration - do not change this value if the default images is used 
                    $DB_MSSQL_PORT = $DB_MSSQL_PORT_VALUE
                    $DB_MSSQL_CONTAINER_PORT = $DB_MSSQL_CONTAINER_PORT_VALUE
                    $DB_MSSQL_SA_PASSWORD = $DB_MSSQL_SA_PASSWORD_VALUE
                    $DB_MSSQL_RECREATE_DB = $DB_MSSQL_RECREATE_DB_VALUE
                    $DB_MSSQL_RECREATE_USER = $DB_MSSQL_RECREATE_USER_VALUE
                    $DB_MSSQL_DBNAME = $DB_MSSQL_DBNAME_VALUE
                    """.trimIndent()
                file.appendText(ctext, Charsets.UTF_8)
                file.appendText("\n\n", Charsets.UTF_8)
            }
        }
    }

    private fun writeServerProps(file: File) {
        with(Configuration) {
            val confDir = File(extension.developmentConfig.configDirectory)
            val systemIP = IPFinder.getSystemIP()

            val hostname = if (systemIP.second != null) {
                try {
                    systemIP.second
                } catch (e: UnknownHostException) {
                    e.printStackTrace()
                }
            } else {
                "localhost"
            }

            val text =
                    """
                # webserver configuration
                # if youn want change the ports of the webserver, it is necessary to change the ports 
                # in $webserverUrlProp and $webserverSecureUrlProp 
                # according to the settings $WS_HTTP_PORT and $WS_HTTPS_PORT
                #
                $webserverUrlProp = http://$hostname:$WS_HTTP_PORT_VALUE
                $webserverSecureUrlProp = https://$hostname:$WS_HTTPS_PORT_VALUE
              
                # If you want add your own certs
                $WS_CERT_PATH = ${File(confDir, "certs")}
                # if the server certificate is not server.crt, add the name
                $WS_SERVER_CERT =
                # if the private key is not server.key, add the name
                $WS_SERVER_PRIVAT =
                
                # This ports will be exposed to the host.
                $WS_HTTP_PORT = $WS_HTTP_PORT_VALUE
                $WS_HTTPS_PORT = $WS_HTTPS_PORT_VALUE
                
                # Webserver container configuration - do not change this value if the default images is used
                $WS_CONTAINER_HTTP_PORT = $WS_CONTAINER_HTTP_PORT_VALUE
                $WS_CONTAINER_HTTPS_PORT = $WS_CONTAINER_HTTPS_PORT_VALUE
                """.trimIndent()

            file.appendText(text, Charsets.UTF_8)
            file.appendText("\n\n", Charsets.UTF_8)

            if (icmasOption.get()) {
                val wstext =
                        """
                # port number to be used for service connector inside of the servlet engine
                $AS_SERVICE_CONNECTOR_PORT = $AS_SERVICE_CONNECTOR_PORT_VALUE
                # port number to be used for management connector inside of the servlet engine
                $AS_MANAGEMENT_CONNECTOR_PORT = $AS_MANAGEMENT_CONNECTOR_PORT_VALUE
            
                # Host name / IP of the ICM Server (local installation)
                # both values must match    
                $LOCAL_CONNECTOR_HOST = ${systemIP.first}
                # WebAdapapter container configuration
                $asConnectorAdressProp = ${systemIP.first}
         
                """.trimIndent()
                file.appendText(wstext, Charsets.UTF_8)

            } else {
                val astext =
                        """
                    # do not change this configuration, if you use the standard
                    # both ports must match
                    # port number to be used for service connector inside of the servlet engine
                    $AS_SERVICE_CONNECTOR_PORT = $AS_SERVICE_CONNECTOR_PORT_VALUE
                    # port number to be used for management connector inside of the servlet engine
                    $AS_MANAGEMENT_CONNECTOR_PORT = $AS_MANAGEMENT_CONNECTOR_PORT_VALUE
                    
                    # port number of the exposed port for the service connector
                    $AS_SERVICE_CONNECTOR_HOST_PORT = $AS_SERVICE_CONNECTOR_HOST_PORT_VALUE
                    # port number of the exposed port for the management connector
                    $AS_MANAGEMENT_CONNECTOR_HOST_PORT = $AS_MANAGEMENT_CONNECTOR_HOST_PORT_VALUE
                    
                    # jmx configuration
                    $AS_JMX_CONNECTOR_PORT = $AS_JMX_CONNECTOR_PORT_VALUE
                    
                    # Host name / IP of the ICM Server (local installation)
                    # both values must match    
                    $LOCAL_CONNECTOR_HOST = ${systemIP.first}
                    """.trimIndent()
                file.appendText(astext, Charsets.UTF_8)
            }
        }
        file.appendText("\n\n", Charsets.UTF_8)
    }

    private fun writeMailProps(file: File, container: Boolean) {
        val icmAs = icmasOption.get()
        val host = if (icmAs) {
            if (container) {
                "localhost"
            } else {
                ""
            }
        } else {
            if (container) {
                "${extension.containerPrefix}-${MailTaskPreparer.extName.lowercase()}"
            } else {
                ""
            }
        }
        val port = if (container) {
            "25"
        } else {
            ""
        }

        val text =
                """
            ${asMailHostProp}=${host}
            ${asMailPortProp}=${port}
    
            ${asMailSMTPHostProp}=${host}
            ${asMailMessageIDProp}=${extension.containerPrefix}
            """.trimIndent()

        file.appendText(text, Charsets.UTF_8)
        file.appendText("\n\n", Charsets.UTF_8)
    }

    private fun writeSolrProps(file: File, container: Boolean) {

        val host = if (container) {
            IPFinder.getSystemIP()
        } else {
            ""
        }
        val port = if (container) {
            "2181"
        } else {
            ""
        }
        val solrpath = if (container) {
            ""
        } else {
            "/"
        }

        val text =
                """
            $asSolrZKListProp = $host:${port}${solrpath}
            $asSolrPrefixProp = ${extension.containerPrefix}
            """.trimIndent()

        file.appendText(text, Charsets.UTF_8)
        file.appendText("\n\n", Charsets.UTF_8)
    }

    private fun writeGebTestProps(file: File) {
        val text =
                """
            # necessary for automatic Solr resest
            intershop.smc.admin.user.name = admin
            intershop.smc.admin.user.password = 
            disable.ssl.verification = true

            geb.local.environment = chromePC
            geb.local.driver = chromeDriver
            """.trimIndent()

        file.appendText(text, Charsets.UTF_8)
        file.appendText("\n\n", Charsets.UTF_8)
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy