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

com.anrisoftware.sscontrol.httpd.gitit.fromsource.HsenvFromSource.groovy Maven / Gradle / Ivy

There is a newer version: 1.0-alpha-4
Show newest version
/*
 * Copyright 2014 Erwin Müller 
 *
 * This file is part of sscontrol-httpd-gitit.
 *
 * sscontrol-httpd-gitit is free software: you can redistribute it and/or modify it
 * under the terms of the GNU Affero General Public License as published by the
 * Free Software Foundation, either version 3 of the License, or (at your
 * option) any later version.
 *
 * sscontrol-httpd-gitit is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License
 * for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with sscontrol-httpd-gitit. If not, see .
 */
package com.anrisoftware.sscontrol.httpd.gitit.fromsource

import static org.apache.commons.io.FileUtils.*
import groovy.util.logging.Slf4j

import javax.inject.Inject

import org.apache.commons.io.FileUtils
import org.apache.commons.lang3.builder.ToStringBuilder
import org.stringtemplate.v4.ST

import com.anrisoftware.globalpom.version.Version;
import com.anrisoftware.globalpom.version.VersionFormatFactory;
import com.anrisoftware.propertiesutils.ContextProperties
import com.anrisoftware.resources.templates.api.TemplateResource
import com.anrisoftware.resources.templates.api.Templates
import com.anrisoftware.resources.templates.api.TemplatesFactory
import com.anrisoftware.sscontrol.httpd.domain.Domain
import com.anrisoftware.sscontrol.httpd.gitit.GititService
import com.anrisoftware.sscontrol.httpd.webservice.WebService
import com.anrisoftware.sscontrol.scripts.unix.ScriptExecFactory
import com.anrisoftware.sscontrol.scripts.unpack.UnpackFactory

/**
 * Installs and configures Gitit with the help of hsenv
 * from source.
 *
 * @author Erwin Mueller, [email protected]
 * @since 1.0
 */
@Slf4j
abstract class HsenvFromSource {

    @Inject
    private HsenvFromSourceLogger logg

    @Inject
    UnpackFactory unpackFactory

    @Inject
    ScriptExecFactory scriptExecFactory

    @Inject
    VersionFormatFactory versionFormatFactory

    Version currentGititVersion

    Object script

    Templates hsenvTemplates

    TemplateResource hsenvCommandTemplate

    /**
     * @see ServiceConfig#deployDomain(Domain, Domain, WebService, List)
     */
    void deployDomain(Domain domain, Domain refDomain, WebService service, List config) {
    }

    /**
     * @see ServiceConfig#deployService(Domain, WebService, List)
     */
    void deployService(Domain domain, WebService service, List config) {
        this.currentGititVersion = gititVersion domain, service
        unpackGititArchive domain, service
        installHsenv()
        installHsenvCabalPackages domain, service
        installGitit domain, service
    }

    /**
     * Downloads and unpacks the Gitit source archive.
     *
     * @param domain
     *            the {@link Domain} domain of the service.
     *
     * @param service
     *            the {@link GititService} service.
     *
     * @see #getGititArchive()
     * @see LinuxScript#getTmpDirectory()
     */
    void unpackGititArchive(Domain domain, GititService service) {
        if (!needRecompile) {
            if (!checkGititVersion(domain, service)) {
                return
            }
        }
        def name = new File(gititArchive.path).name
        def dest = new File(tmpDirectory, "gitit-$name")
        copyURLToFile gititArchive.toURL(), dest
        unpackArchive domain, service, dest
    }

    /**
     * Unpacks the Gitit archive.
     *
     * @param domain
     *            the {@link Domain} domain of the service.
     *
     * @param service
     *            the {@link WebService} service.
     *
     * @param archive
     *            the archive {@link File} file.
     */
    void unpackArchive(Domain domain, WebService service, File archive) {
        def dir = gititSourceDir domain, service
        forceRemoveOldArchiveDirectory ? FileUtils.forceDelete(dir) : false
        dir.isDirectory() ? false : dir.mkdirs()
        unpackFactory.create(
                log: log,
                file: archive,
                output: dir,
                override: true,
                strip: true,
                commands: unpackCommands,
                this, threads)()
        logg.unpackArchiveDone this, gititArchive
    }

    /**
     * Installs hsenv.
     */
    void installHsenv() {
        installCabalPackages hsenvCabalPackages, hsenvCabalExtras
        logg.installHsenvDone this, hsenvCabalPackages
    }

    /**
     * Installs the cabal packages inside the hsenv environment.
     *
     * @param domain
     *            the {@link Domain} domain of the service.
     *
     * @param service
     *            the {@link GititService} service.
     *
     * @see #getHsenvCommand()
     * @see #getHsenvGititPackages()
     * @see #getHsenvCabalInstallTimeout()
     */
    void installHsenvCabalPackages(Domain domain, GititService service) {
        if (!needRecompile) {
            if (!checkGititVersion(domain, service)) {
                return
            }
        }
        def gititDir = gititDir domain, service
        def hsenvCommand = hsenvCommand
        def cabalCommand = hsenvCabalCommand domain, service
        def activateCommand = hsenvActivateCommand domain, service
        def packages = hsenvGititPackages
        def task = scriptExecFactory.create(
                log: log,
                gititDir: gititDir,
                bashCommand: bashCommand,
                hsenvCommand: hsenvCommand,
                activateCommand: activateCommand,
                cabalCommand: cabalCommand,
                deactivateCommand: hsenvDeactivateCommand,
                packages: packages,
                timeout: cabalInstallTimeout,
                this, threads,
                hsenvCommandTemplate, "hsenvInstallCommand")()
        logg.installHsenvCabalPackagesDone this, task, packages
    }

    /**
     * Installs gitit inside the hsenv environment.
     *
     * @param domain
     *            the {@link Domain} domain of the service.
     *
     * @param service
     *            the {@link GititService} service.
     *
     */
    void installGitit(Domain domain, GititService service) {
        if (!needRecompile) {
            if (!checkGititVersion(domain, service)) {
                return
            }
        }
        def gititDir = gititDir domain, service
        def hsenvCommand = hsenvCommand
        def cabalCommand = hsenvCabalCommand domain, service
        def activateCommand = hsenvActivateCommand domain, service
        def gititSourceDir = gititSourceDir domain, service
        def task = scriptExecFactory.create(
                log: log,
                gititDir: gititDir,
                bashCommand: bashCommand,
                hsenvCommand: hsenvCommand,
                activateCommand: activateCommand,
                cabalCommand: cabalCommand,
                deactivateCommand: hsenvDeactivateCommand,
                gititSourceDir: gititSourceDir,
                timeout: cabalInstallTimeout,
                this, threads,
                hsenvCommandTemplate, "hsenvCompileCommand")()
        logg.installGititDone this, task
    }

    /**
     * Checks that the installed gitit service version is smaller then
     * the archive version, and that the archive version is in bounds the
     * version limit.
     *
     * @param domain
     *            the {@link Domain} domain of the service.
     *
     * @param service
     *            the {@link GititService} service.
     *
     * @return {@code true} if all of those conditions are true.
     */
    boolean checkGititVersion(Domain domain, GititService service) {
        def archiveVersion = gititArchiveVersion
        def versionLimit = gititVersionLimit
        logg.checkGititVersion this, currentGititVersion, archiveVersion, versionLimit
        boolean different = currentGititVersion == null ? true : currentGititVersion.compareTo(archiveVersion) > 0
        boolean bounds = archiveVersion.compareTo(versionLimit) <= 0
        return different && bounds
    }

    /**
     * Returns the Gitit archive.
     *
     * 
    *
  • profile property {@code "hsenv_gitit_archive"}
  • *
* * @see #getHsenvProperties() */ URI getGititArchive() { profileURIProperty "hsenv_gitit_archive", hsenvProperties } /** * Returns the cabal packages to install hsenv, for example * {@code "hsenv".} * *
    *
  • profile property {@code hsenv_cabal_packages}
  • *
* * @return the {@link List} of packages. * * @see #getHsenvProperties() */ List getHsenvCabalPackages() { profileListProperty "hsenv_cabal_packages", hsenvProperties } /** * Returns the extra parameters for the cabal command to * install hsenv, for * example {@code "--constraint=io-streams==1.2.0.0"}. * *
    *
  • profile property {@code hsenv_cabal_extra}
  • *
* * @return the {@link List} of packages. * * @see #getHsenvProperties() */ List getHsenvCabalExtras() { profileListProperty "hsenv_cabal_extra", hsenvProperties } /** * Returns the cabal packages to install Gitit inside * the hsenv environment, for * example {@code "pandoc -fhighlighting".} * *
    *
  • profile property {@code hsenv_gitit_packages}
  • *
* * @return the {@link List} of packages. * * @see #getHsenvProperties() */ List getHsenvGititPackages() { profileListProperty "hsenv_gitit_packages", hsenvProperties } /** * Returns the hsenv command, for * example {@code "/root/.cabal/bin/hsenv".} * *
    *
  • profile property {@code "hsenv_command"}
  • *
* * @see #getHsenvProperties() */ String getHsenvCommand() { profileProperty "hsenv_command", hsenvProperties } /** * Returns the deactivate command, for * example {@code "deactivate_hsenv".} * *
    *
  • profile property {@code "hsenv_deactivate_command"}
  • *
* * @see #getHsenvProperties() */ String getHsenvDeactivateCommand() { profileProperty "hsenv_deactivate_command", hsenvProperties } /** * Returns the if need to recompile gitit even if the version of * the installed service match, for example {@code "true".} * *
    *
  • profile property {@code "hsenv_need_recompile"}
  • *
* * @see #getHsenvProperties() */ boolean getNeedRecompile() { profileBooleanProperty "hsenv_need_recompile", hsenvProperties } /** * Returns the if need to remove the old gitit archive directory, * for example {@code "true".} * *
    *
  • profile property {@code "force_remove_old_archive_directory"}
  • *
* * @see #getHsenvProperties() */ boolean getForceRemoveOldArchiveDirectory() { profileBooleanProperty "force_remove_old_archive_directory", hsenvProperties } /** * Returns the cabal command inside the hsenv * environment, for example {@code "/.hsenv/bin/cabal".} * The placeholder {@code ""} is replaced by the Gitit * service domain directory. * *
    *
  • profile property {@code "hsenv_cabal_command"}
  • *
* * @param domain * the {@link Domain} domain of the service. * * @param service * the {@link GititService} service. * * @see #getHsenvProperties() */ String hsenvCabalCommand(Domain domain, GititService service) { def dir = gititDir domain, service def p = profileProperty "hsenv_cabal_command", hsenvProperties new ST(p).add("gititDir", dir).render() } /** * Returns the activate command inside the hsenv * environment, for example {@code "/.hsenv/bin/activate".} * The placeholder {@code ""} is replaced by the Gitit * service domain directory. * *
    *
  • profile property {@code "hsenv_activate_command"}
  • *
* * @param domain * the {@link Domain} domain of the service. * * @param service * the {@link GititService} service. * * @see #getHsenvProperties() */ String hsenvActivateCommand(Domain domain, GititService service) { def dir = gititDir domain, service def p = profileProperty "hsenv_activate_command", hsenvProperties new ST(p).add("gititDir", dir).render() } /** * Returns the gitit command inside the hsenv * environment, for example {@code "/.hsenv/cabal/bin/gitit".} * The placeholder {@code ""} is replaced by the Gitit * service domain directory. * *
    *
  • profile property {@code "hsenv_gitit_command"}
  • *
* * @param domain * the {@link Domain} domain of the service. * * @param service * the {@link GititService} service. * * @see #getHsenvProperties() */ String hsenvGititCommand(Domain domain, GititService service) { def dir = gititDir domain, service def p = profileProperty "hsenv_gitit_command", hsenvProperties new ST(p).add("gititDir", dir).render() } /** * Returns if the gitit command exist, i.e. the Gitit * web service is already installed. * * @return {@code true} if the command exist. * * @see #hsenvGititCommand(Domain, GititService) */ boolean gititCommandExist(Domain domain, GititService service) { new File(hsenvGititCommand(domain, service)).isFile() } /** * Returns the Gitit source directory inside the hsenv * environment, for example {@code "/gitit-0.10"} * The placeholder {@code ""} is replaced by the Gitit * service domain directory. * *
    *
  • profile property {@code "hsenv_gitit_source_directory"}
  • *
* * @param domain * the {@link Domain} domain of the service. * * @param service * the {@link GititService} service. * * @return the installation {@link File} directory. * * @see #gititDir(Domain, GititService) * @see #getGititArchive() */ File gititSourceDir(Domain domain, GititService service) { def dir = gititDir domain, service def p = profileProperty "hsenv_gitit_source_directory", hsenvProperties new File(new ST(p).add("gititDir", dir).render()) } /** * Returns if the Gitit version limit, for example * {@code "0.10.5"} * *
    *
  • profile property {@code "hsenv_gitit_version_limit"}
  • *
* * @see #getHsenvProperties() */ Version getGititVersionLimit() { def p = profileProperty "hsenv_gitit_version_limit", hsenvProperties versionFormatFactory.create().parse p } /** * Returns if the Gitit version of the archive, for example * {@code "0.10.5"} * *
    *
  • profile property {@code "hsenv_gitit_archive_version"}
  • *
* * @see #getHsenvProperties() */ Version getGititArchiveVersion() { def p = profileProperty "hsenv_gitit_archive_version", hsenvProperties versionFormatFactory.create().parse p } @Inject final void setTemplatesFactory(TemplatesFactory factory) { def templates = factory.create "HsenvFromSource" this.hsenvCommandTemplate = templates.getResource "hsenvcommands" } /** * Returns the default hsenv Gitit properties. * * @return the {@link ContextProperties} properties. */ abstract ContextProperties getHsenvProperties() /** * @see ServiceConfig#setScript(LinuxScript) */ void setScript(Object script) { this.script = script } /** * @see ServiceConfig#getName() */ String getName() { script.getName() } /** * Delegates missing properties to {@link LinuxScript}. */ def propertyMissing(String name) { script.getProperty name } /** * Delegates missing methods to {@link LinuxScript}. */ def methodMissing(String name, def args) { script.invokeMethod name, args } @Override String toString() { new ToStringBuilder(this) .append("service name", getServiceName()) .append("profile name", getProfile()).toString(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy