diff --git a/CHANGELOG.md b/CHANGELOG.md index 21ac1b9c6..2bab98e11 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -26,6 +26,16 @@ These are mostly all regressions. All of the little features I created need to b - Remove Client form on sites. - Ensure devshop_support widget & connection works. +## DevShop 1.8.0-beta2 +### August 30, 2023 + +- Fix deploy tasks when created by hosting git queue. +- Fix install script problems. +- Create script files with version numbers. +- Add testing for ubuntu 20 and 22. +- Default to PHP 8.1. +- Ensure drush alias is entered when "other drush alias" is selected as source. + ## DevShop 1.8.0-beta1 ### August 29, 2023 diff --git a/RoboFile.php b/RoboFile.php index 70e096896..f31254e86 100644 --- a/RoboFile.php +++ b/RoboFile.php @@ -865,7 +865,7 @@ public function login($user = 'aegir') { /** * Create a new release of DevShop. */ - public function release($version = NULL, $drupal_org_version = NULL) { + public function release($version = NULL) { if (empty($version)) { // @TODO Verify version string. @@ -876,23 +876,6 @@ public function release($version = NULL, $drupal_org_version = NULL) { $this->release(); return; } - - if (empty($drupal_org_version)) { - $drupal_org_version = $this->ask("What should the Drupal.org version be? (Do not include 7.x or the second dot of the semantic version. ie 1.00-rc1 for 1.0.0-rc1)"); - } - - if (empty($drupal_org_version)) { - $this->release($version); - return; - } - - if (!$this->confirm("Are you sure you want the Drupal.org tag to be 7.x-$drupal_org_version?")) { - $this->release(); - return; - } - - $drupal_org_tag = "7.x-$drupal_org_version"; - $this->yell("The new version shall be $version!!!"); $release_branch = "release-{$version}"; @@ -916,16 +899,9 @@ public function release($version = NULL, $drupal_org_version = NULL) { } if ($this->confirm("Create install script for version? ")) { - $this->_exec("cd install && LOAD_SCRIPT_DEVSHOP_VERSION_REF=$version make"); + $this->_exec("cd install && BRANCH=$version make"); $this->_exec("git add install/build"); } -// -// if ($this->confirm("Write '$drupal_org_version' to build-devmaster.make and remove development repos? ")) { -// $this->_exec("sed -i -e 's/projects\[devmaster\]\[version\] = 1.x-dev/projects[devmaster][version] = $drupal_org_version/' build-devmaster.make"); -// $this->_exec("sed -i -e 's/projects\[devmaster\]\[download\]\[branch\]/; projects[devmaster][download][branch]' build-devmaster.make"); -// $this->_exec("sed -i -e 's/projects\[devmaster\]\[download\]\[url\]/; projects[devmaster][download][url]' build-devmaster.make"); -// $this->_exec("sed -i -e '/###DEVELOPMENTSTART###/,/###DEVELOPMENTEND###/d' build-devmaster.make"); -// } if ($this->confirm("Show git diff before committing?")) { $this->_exec("git diff -U1"); @@ -942,7 +918,7 @@ public function release($version = NULL, $drupal_org_version = NULL) { ->run(); } - if ($this->confirm("Push the new release tags $version and $drupal_org_version?")) { + if ($this->confirm("Push the new release tags $version?")) { if (!$this->taskGitStack() ->push("origin", $version) ->run() @@ -959,11 +935,8 @@ public function release($version = NULL, $drupal_org_version = NULL) { $this->say(" - Copy CHANGELOG from https://raw.githubusercontent.com/opendevshop/devshop/1.x/CHANGELOG.md"); $this->say(" - Upload install.sh script to release files."); $this->say("2. Put the new version in gh-pages branch index.html"); - - if ($this->confirm("Checkout main branch and run `monorepo-builder split` to push current branch and latest tag to all sub-repos?")) { - $this->_exec("git checkout 1.x"); - $this->_exec("bin/monorepo-builder split"); - } + $this->say(""); + $this->say("That's it! Congrats."); } /** diff --git a/devmaster/VERSION.txt b/devmaster/VERSION.txt index 525a4bd0e..c69d0b1df 100644 --- a/devmaster/VERSION.txt +++ b/devmaster/VERSION.txt @@ -1 +1 @@ -1.x \ No newline at end of file +1.x diff --git a/install/build/install-1.8.0-beta2.sh b/install/build/install-1.8.0-beta2.sh new file mode 100644 index 000000000..e67bcbce3 --- /dev/null +++ b/install/build/install-1.8.0-beta2.sh @@ -0,0 +1,646 @@ +#!/bin/sh +set -e +# OpenDevShop for Linux installation script +# +# See https://opendevshop.com/install/ for the installation steps. +# +# This script is meant for quick & easy install via: +# $ curl -fsSL https://get.devshop.tech -o get-devshop.sh +# $ sh get-devshop.sh +# +# If you have not yet set a hostname, you can do so with the install script: +# +# $ sh get-devshop.sh --hostname=devshop.example.com +# +# To use an alternate git repository or version, set the LOAD_DEVSHOP_VERSION or LOAD_DEVSHOP_SOURCE environment variables: +# +# $ LOAD_SCRIPT_DEVSHOP_VERSION_REF=patch-123 LOAD_DEVSHOP_SOURCE=https://github.com/jonpugh/devshop.git bash install.sh +# +# NOTE: Make sure to verify the contents of the script +# you downloaded matches the contents of install.sh +# located at https://github.com/opendevshop/devshop/blob/1.x/install/install.sh +# before executing. +# + +# OPTIONS + +# Git commit from https://github.com/opendevshop/devshop/blob/1.x/install/install.sh when +# the script was uploaded (Should only be modified by upload job): +# Will be the SHA used to publish the install.sh file to get.devshop.tech. +SCRIPT_DEVSHOP_VERSION_SHA="3cdd4352255305d911a64712204dbe8fc60528c7" +SCRIPT_DEVSHOP_VERSION_REF="1.8.0-beta2" + +# Version to install (branch or tag). +# If testing a branch is needed, set the DEVSHOP_VERSION environment variable in +# the command line environment: +# +# $ export DEVSHOP_VERSION=bug/XXX/fix +# $ bash install.sh +# +# See the GitHub action ./.github/workflows/install.yml +# + +# The version and git repo to install. +# Default to 1.x if $SCRIPT_DEVSHOP_VERSION is empty. +# Used as the `devshop_version` ansible variable, which will change the checked out version. +DEVSHOP_VERSION="${SCRIPT_DEVSHOP_VERSION_REF}" +DEVSHOP_SOURCE="${LOAD_DEVSHOP_SOURCE:-http://github.com/opendevshop/devshop.git}" + +# Version of Ansible to install +ANSIBLE_VERSION=${ANSIBLE_VERSION:-"2.9"} +CRYPTOGRAPHY_VERSION=${CRYPTOGRAPHY_VERSION:-"3.3"} +pip_packages="cryptography==${CRYPTOGRAPHY_VERSION} ansible==${ANSIBLE_VERSION}" + +# Environment Options: +HOSTNAME_FQDN=${HOSTNAME_FQDN:-`hostname --fqdn`} +ANSIBLE_DEFAULT_HOST_LIST=${ANSIBLE_DEFAULT_HOST_LIST:-"/etc/ansible/hosts"} +DEVSHOP_INSTALL_PATH=${DEVSHOP_INSTALL_PATH:-"/usr/share/devshop"} +DEVSHOP_PLAYBOOK=${DEVSHOP_PLAYBOOK:-"roles/devshop.server/play.yml"} +SERVER_WEBSERVER=${SERVER_WEBSERVER:-"apache"} +AEGIR_USER_UID=${AEGIR_USER_UID:-12345} +ANSIBLE_VERBOSITY=${ANSIBLE_VERBOSITY:-0}; +DEVSHOP_SUPPORT_LICENSE_KEY=${DEVSHOP_SUPPORT_LICENSE_KEY:-""}; + +# Command line Options +while [ $# -gt 0 ]; do + case "$1" in + --hostname=*) + HOSTNAME_FQDN="${1#*=}" + ;; + --version=*) + DEVSHOP_VERSION="${1#*=}" + ;; + --install-path=*) + DEVSHOP_INSTALL_PATH="${1#*=}" + ;; + --email=*) + DEVMASTER_ADMIN_EMAIL="${1#*=}" + ;; + --aegir-uid=*) + AEGIR_USER_UID="${1#*=}" + ;; + -v|--verbose) + ANSIBLE_VERBOSITY="-v" + shift # past argument + ;; + -vvv|--very-verbose) + ANSIBLE_VERBOSITY="-vvv" + shift # past argument + ;; + -vvvv|--debug) + ANSIBLE_VERBOSITY="-vvvv" + shift # past argument + ;; + --license=*) + DEVSHOP_SUPPORT_LICENSE_KEY="${1#*=}" + ;; + --ansible-default-host-list=*) + ANSIBLE_DEFAULT_HOST_LIST="${1#*=}" + ;; + --playbook=*) + DEVSHOP_PLAYBOOK="${1#*=}" + ;; + --dry-run) + DRY_RUN=1 + ;; + --*) + echo "Illegal option $1" + ;; + esac + shift $(( $# > 0 ? 1 : 0 )) +done + +DEVSHOP_VERSION=${DEVSHOP_VERSION:-1.x} + +# Initial Ansible Variables +# Generate host specific vars to be injected into inventory. +# All command line options that are ansible variables should be saved here. +ANSIBLE_EXTRA_VARS=() +# This is to saved to local /etc/ansible/hosts file, so always use local connect. +ANSIBLE_EXTRA_VARS+=("ansible_host: ${HOSTNAME_FQDN}") +ANSIBLE_EXTRA_VARS+=("ansible_connection: local") +ANSIBLE_EXTRA_VARS+=("server_hostname: ${HOSTNAME_FQDN}") +ANSIBLE_EXTRA_VARS+=("devshop_cli_path: ${DEVSHOP_INSTALL_PATH}") +ANSIBLE_EXTRA_VARS+=("aegir_server_webserver: ${SERVER_WEBSERVER}") +ANSIBLE_EXTRA_VARS+=("aegir_user_uid: ${AEGIR_USER_UID}") +ANSIBLE_EXTRA_VARS+=("devshop_github_token: ${GITHUB_TOKEN}") +if [ -n "$DEVMASTER_ADMIN_EMAIL" ]; then + ANSIBLE_EXTRA_VARS+=("devshop_devmaster_email: ${DEVMASTER_ADMIN_EMAIL}") +fi +if [ -n "$DEVSHOP_SUPPORT_LICENSE_KEY" ]; then + ANSIBLE_EXTRA_VARS+=("devshop_support_license_key: ${DEVSHOP_SUPPORT_LICENSE_KEY}") +fi + +# FUNCTIONS + +command_exists() { + command -v "$@" > /dev/null 2>&1 +} + +is_dry_run() { + if [ -z "$DRY_RUN" ]; then + return 1 + else + return 0 + fi +} + +is_wsl() { + case "$(uname -r)" in + *microsoft* ) true ;; # WSL 2 + *Microsoft* ) true ;; # WSL 1 + * ) false;; + esac +} + +is_darwin() { + case "$(uname -s)" in + *darwin* ) true ;; + *Darwin* ) true ;; + * ) false;; + esac +} + +deprecation_notice() { + distro=$1 + date=$2 + echo + echo "DEPRECATION WARNING:" + echo " The distribution, $distro, will no longer be supported in this script as of $date." + echo " If you feel this is a mistake please submit an issue at https://github.com/docker/docker-install/issues/new" + echo + sleep 10 +} + +get_distribution() { + lsb_dist="" + # Every system that we officially support has /etc/os-release + if [ -r /etc/os-release ]; then + lsb_dist="$(. /etc/os-release && echo "$ID")" + fi + # Returning an empty string here should be alright since the + # case statements don't act unless you provide an actual value + echo "$lsb_dist" +} + +get_distribution_version() { + + case "$1" in + + ubuntu) + if command_exists lsb_release; then + dist_version="$(lsb_release --release | cut -f2)" + fi + if [ -z "$dist_version" ] && [ -r /etc/lsb-release ]; then + dist_version="$(. /etc/lsb-release && echo "$DISTRIB_RELEASE")" + fi + ;; + + debian|raspbian) + dist_version="$(sed 's/\/.*//' /etc/debian_version | sed 's/\..*//')" + case "$dist_version" in + 10) + dist_version_codename="buster" + ;; + 9) + dist_version_codename="stretch" + ;; + 8) + dist_version_codename="jessie" + ;; + esac + ;; + + centos|rhel) + if [ -z "$dist_version" ] && [ -r /etc/os-release ]; then + dist_version="$(. /etc/os-release && echo "$VERSION_ID")" + fi + ;; + + *) + if command_exists lsb_release; then + dist_version="$(lsb_release --release | cut -f2)" + fi + if [ -z "$dist_version" ] && [ -r /etc/os-release ]; then + dist_version="$(. /etc/os-release && echo "$VERSION_ID")" + fi + ;; + + esac + + echo "$dist_version" +} + +# From https://github.com/geerlingguy/docker-ubuntu2204-ansible/blob/master/Dockerfile +prepare_ubuntu2204() { + PYTHON_DEFAULT=/usr/bin/python3 + DEBIAN_FRONTEND=noninteractive + pip_packages="ansible" + + apt-get update \ + && apt-get install -y --no-install-recommends \ + apt-utils \ + build-essential \ + git \ + locales \ + libffi-dev \ + libssl-dev \ + libyaml-dev \ + python3-dev \ + python3-setuptools \ + python3-pip \ + python3-yaml \ + python-is-python3 \ + software-properties-common \ + rsyslog systemd systemd-cron sudo iproute2 \ + && apt-get clean \ + && rm -Rf /var/lib/apt/lists/* \ + && rm -Rf /usr/share/doc && rm -Rf /usr/share/man + + # Set Python3 to be the default (allow users to call "python" and "pip" instead of "python3" "pip3" + update-alternatives --install /usr/bin/python python /usr/bin/python3 1 + + pip3 install $pip_packages +} + +# From https://github.com/geerlingguy/docker-ubuntu2004-ansible/blob/master/Dockerfile +prepare_ubuntu2004() { + PYTHON_DEFAULT=/usr/bin/python3 + DEBIAN_FRONTEND=noninteractive + pip_packages="ansible" + + apt-get update \ + && apt-get install -y --no-install-recommends \ + apt-utils \ + build-essential \ + git \ + locales \ + libffi-dev \ + libssl-dev \ + libyaml-dev \ + python3-dev \ + python3-setuptools \ + python3-pip \ + python3-yaml \ + python-is-python3 \ + software-properties-common \ + rsyslog systemd systemd-cron sudo iproute2 \ + && apt-get clean \ + && rm -Rf /var/lib/apt/lists/* \ + && rm -Rf /usr/share/doc && rm -Rf /usr/share/man + + # Set Python3 to be the default (allow users to call "python" and "pip" instead of "python3" "pip3" + update-alternatives --install /usr/bin/python python /usr/bin/python3 1 + + pip3 install $pip_packages +} + +# From https://github.com/geerlingguy/docker-ubuntu1804-ansible/blob/master/Dockerfile +prepare_ubuntu1804() { + PYTHON_DEFAULT=/usr/bin/python3 + DEBIAN_FRONTEND=noninteractive + apt-get update \ + && apt-get install -y --no-install-recommends \ + apt-utils \ + locales \ + python3-setuptools \ + python3-pip \ + software-properties-common \ + git \ + && rm -Rf /var/lib/apt/lists/* \ + && rm -Rf /usr/share/doc && rm -Rf /usr/share/man \ + && apt-get clean + + # Set Python3 to be the default (allow users to call "python" and "pip" instead of "python3" "pip3" + update-alternatives --install /usr/bin/python python /usr/bin/python3 1 + + pip3 install $pip_packages +} + +prepare_centos7() { + system_packages_pre="\ + deltarpm \ + epel-release \ + initscripts \ + git \ + " + system_packages="python-pip" + + yum makecache fast + yum -y install $system_packages_pre + yum -y update + yum -y install $system_packages + yum clean all + + pip install $pip_packages +} + +ansible_prepare_server() { + ANSIBLE_HOME=$(dirname "$ANSIBLE_DEFAULT_HOST_LIST") + if [[ ! -d "$ANSIBLE_HOME/host_vars/$HOSTNAME_FQDN" ]]; then + echo "No ansible home directory found at $ANSIBLE_HOME. Preparing..." + mkdir --parent "$ANSIBLE_HOME/host_vars/$HOSTNAME_FQDN" + fi + if [[ ! -f "$ANSIBLE_DEFAULT_HOST_LIST" ]]; then + echo "No ansible inventory found at $ANSIBLE_DEFAULT_HOST_LIST. Preparing inventory..." + ansible_prepare_server_inventory + fi + if [[ ! -f "$ANSIBLE_HOME/ansible.cfg" ]]; then + echo "No ansible.cfg file found at $ANSIBLE_HOME/ansible.cfg. Copying ansible.default.cfg ..." + cp "$DEVSHOP_INSTALL_PATH/ansible.cfg" "$ANSIBLE_HOME/ansible.cfg" + fi +} + +ansible_prepare_server_inventory() { + # Strangest thing: if you leave a space after the variable "name:" the output will convert to a new line. + IFS=$'\n' + + echo "--- +# DevShop Ansible Static Inventory File +# ------------------------------------- +# This Ansible Inventory file was written by devshop's install.sh script at `date` +# You may add edit this inventory file as you wish, or to additional files in /etc/ansible/group_vars or /etc/ansible/host_vars +# Run 'devshop-ansible-playbook' as root after changing this file to apply the configuration. +devshop_server: + hosts: + $HOSTNAME_FQDN: + " > $ANSIBLE_DEFAULT_HOST_LIST + + # Write all extra vars to the file. + ANSIBLE_DEFAULT_HOST_VARS_FILE="/etc/ansible/host_vars/${HOSTNAME_FQDN}/devshop" + for i in ${ANSIBLE_EXTRA_VARS[@]}; do + echo -e "$i" >> $ANSIBLE_DEFAULT_HOST_VARS_FILE + done + echo $LINE + echo "Wrote static inventory to $ANSIBLE_DEFAULT_HOST_LIST:"; + echo $LINE + cat $ANSIBLE_DEFAULT_HOST_LIST + echo $LINE + echo "List Ansible Hosts:" + ansible all --list-hosts -i $ANSIBLE_DEFAULT_HOST_LIST +} + +usage() { + + echo \ +' + DevShop Standalone Install Script + ================================= + + This script will install a full devshop server from scratch. + + Please read the full "Installing DevShop" instructions at https://docs.opendevshop.com/install.html + + Before you start, please visit https://github.com/opendevshop/devshop/releases to be sure you have the latest version of this script, + + DNS & Hostnames + --------------- + For devshop to work, the server\''s hostname must be a fullly qualified domain name that resolves to an accessible IP address. + + Before you run this script, add DNS records for this server: + + devshop.mydomain.com. 1800 IN A 1.2.3.4 + *.devshop.mydomain.com. 1800 IN A 1.2.3.4 + + This install script will attempt to set your hostname for you, if you use the --hostname option. + + + Running Install.sh + ================== + + Must run as root or with sudo and -H option: + + root@ubuntu:~# wget https://raw.githubusercontent.com/opendevshop/devshop/1.x/install.sh + root@ubuntu:~# bash install.sh --hostname=devshop.mydomain.com + + OR + + sudo -H bash install.sh + + Options: + --hostname The desired fully qualified domain name to set as this machine\''s hostname (Default: Current hostname) + --install-path The path to install the main devshop source code. (Default: /usr/share/devshop) + --server-webserver Set to 'nginx' if you want to use the Aegir NGINX packages. (Default: apache) + --makefile The makefile to use to build the front-end site. (Default: {install-path}/build-devmaster.make) + --playbook The Ansible playbook.yml file to use other than the included playbook.yml. (Default: {install-path}/playbook.yml) + --email The email address to use for User 1. Enter your email to receive notification when the install is complete. + --aegir-uid The UID to use for creating the `aegir` user (Default: 12345) + --ansible-default-host-list If your server is using a different ansible default host, specify it here. Default: /etc/ansible/hosts* + --license The devshop.support license key for this server. + --help Displays this help message and exits + + Supporting DevShop + ================== + + Your contributions make DevShop possible. Please consider becoming a patron of open source! + + https://opencollective.com/devshop + https://www.patreon.com/devshop + +' + + exit 1 +} + +do_install() { + +# main + +POST_INSTALL_WELCOME_MSG=" + +Welcome to OpenDevShop! Use the link below to sign in. + +The password for user 'admin' was securely generated and hidden. +Use 'drush @hostmaster uli' or 'devshop login' to get another login link. + +Please visit http://getdevshop.com for help and information. + +Join the development community at https://github.com/opendevshop/devshop + +Thanks! + +--The OpenDevShop Team + +Issues: https://github.com/opendevshop/devshop/issues +Chat: https://gitter.im/opendevshop/devshop +Code: https://github.com/opendevshop/devshop + +Your contributions make DevShop possible. Please consider becoming a patron of open source! + + https://opencollective.com/devshop + https://www.patreon.com/devshop + +" +export ANSIBLE_FORCE_COLOR=true + +echo "=============================================" +echo " Welcome to the DevShop Standalone Installer " +echo " Version $DEVSHOP_VERSION" +echo " Source $DEVSHOP_SOURCE" +echo " Script Git Reference $SCRIPT_DEVSHOP_VERSION_REF" +echo " Script Git SHA $SCRIPT_DEVSHOP_VERSION_SHA" +echo "=============================================" + +# Fail if not running as root (sudo) +if [ $EUID -ne 0 ]; then + echo " This script must be run as root. Try 'sudo -H bash install.sh'." 1>&2 + exit 1 +fi + +LINE=--------------------------------------------- + +# perform some very rudimentary platform detection +lsb_dist=$( get_distribution ) +lsb_dist="$(echo "$lsb_dist" | tr '[:upper:]' '[:lower:]')" +dist_version=$( get_distribution_version $lsb_dist ) + +OS=$lsb_dist +VERSION=$dist_version + +# Output some info. +echo " OS: $lsb_dist" +echo " Version: $dist_version" +echo " Hostname: $HOSTNAME_FQDN" + # If /var/aegir/config/server_master/nginx.conf is found, use NGINX to install. + # If /var/aegir/config/server_master/apache.conf is found, use apache to install. + # This will override any selected option for web server. This is so we don't install + # a second webserver accidentally. + +# Break out preparation into separate functions. +echo $LINE +echo " Installing prerequisites (ansible, git etc)..." + +case "$lsb_dist $dist_version" in + "ubuntu 22.04") + prepare_ubuntu2204 > /dev/null + ;; + "ubuntu 20.04") + prepare_ubuntu2004 > /dev/null + ;; + "ubuntu 18.04") + prepare_ubuntu1804 > /dev/null + ;; + "centos 7") + prepare_centos7 > /dev/null + ;; + default) + echo "Automatic ansible install is not yet supported in $lsb_dist $dist_version. Install ansible according using the instructions for your operating system found at https://docs.ansible.com/ansible/latest/installation_guide/intro_installation.html and try to run this script again." + exit 1 + ;; +esac + +if [ -f "/var/aegir/config/server_master/nginx.conf" ]; then + SERVER_WEBSERVER=nginx +elif [ -f "/var/aegir/config/server_master/apache.conf" ]; then + SERVER_WEBSERVER=apache +fi + +# Output Web Server +echo " Web Server: $SERVER_WEBSERVER" + +echo $LINE + +# Notify user we are using the found webserver. +if [ -f "/var/aegir/config/server_master/nginx.conf" ]; then + echo " An existing Aegir NGINX installation was found. Using 'nginx' for variable 'server-webserver'" + echo $LINE +elif [ -f "/var/aegir/config/server_master/apache.conf" ]; then + echo " An existing Aegir Apache installation was found. Using 'apache' for variable 'server-webserver'" + echo $LINE +fi + +# Fail if server-webserver is not apache or nginx +if [ $SERVER_WEBSERVER != 'nginx' ] && [ $SERVER_WEBSERVER != 'apache' ]; then + echo ' Invalid argument for --server-webserver. Must be nginx or apache.' + exit 1 +fi + +if [ -f '/root/.my.cnf' ] +then + MYSQL_ROOT_PASSWORD=$(awk -F "=" '/pass/ {print $2}' /root/.my.cnf) + echo " Password found at /root/.my.cnf, using $MYSQL_ROOT_PASSWORD" +else + MYSQL_ROOT_PASSWORD=$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c${2:-32};echo;) + echo " Generating new MySQL root password... $MYSQL_ROOT_PASSWORD" + echo $MYSQL_ROOT_PASSWORD > /tmp/mysql_root_password +fi + +ANSIBLE_EXTRA_VARS+=("mysql_root_password: ${MYSQL_ROOT_PASSWORD}") + +# Clone the installer if $DEVSHOP_INSTALL_PATH does not exist yet. +if [ ! -d "$DEVSHOP_INSTALL_PATH" ]; then + git clone $DEVSHOP_SOURCE $DEVSHOP_INSTALL_PATH + cd $DEVSHOP_INSTALL_PATH + git checkout $DEVSHOP_VERSION +else + cd $DEVSHOP_INSTALL_PATH +# @TODO: This was needed when install.sh was the upgrade, but now it isn't. It breaks upgrade testing in PRs +# unless DEVSHOP_VERSION is set to the branch being tested. +# git fetch +# git checkout $DEVSHOP_VERSION +fi + +echo $LINE +echo " Hostname: $HOSTNAME_FQDN" +echo " MySQL Root Password: $MYSQL_ROOT_PASSWORD" +echo " Playbook: $DEVSHOP_INSTALL_PATH/$DEVSHOP_PLAYBOOK " +echo " Roles: $DEVSHOP_INSTALL_PATH/roles/" +echo $LINE + + +cd $DEVSHOP_INSTALL_PATH + +ansible --version +python --version + +# Check that DEFAULT_HOST_LIST ansible config matches ANSIBLE_DEFAULT_HOST_LIST +if [[ `ansible-config dump | grep ${ANSIBLE_DEFAULT_HOST_LIST}` ]]; then + echo " Ansible Inventory: $ANSIBLE_DEFAULT_HOST_LIST" +else + echo "[ERROR] The system's ansible configuration option DEFAULT_HOST_LIST does not match the install.sh option --ansible-default-host-list ($ANSIBLE_DEFAULT_HOST_LIST)" + echo "Result from ansible-config dump:" + ansible-config dump + echo "Exiting devshop install.sh. Ensure this system's ansible configuration for [defaults]inventory matches the install.sh option --ansible-default-host-list." + exit 1 +fi + +# Prepare Ansible inventory +ansible_prepare_server + +# Run the playbook. +echo $LINE +echo " Installing with devshop-ansible-playbook..." +echo $LINE + +# If ansible playbook fails syntax check, report it and exit. +ANSIBLE_PLAYBOOK="$DEVSHOP_INSTALL_PATH/$DEVSHOP_PLAYBOOK" +if [ ! `ansible-playbook --syntax-check ${ANSIBLE_PLAYBOOK}` ]; then + echo " Ansible syntax check failed! Check ${ANSIBLE_PLAYBOOK} and try again." + exit 1 +fi + +# Set the ENV vars that devshop-ansible-playbook expects, and run it. +export ANSIBLE_PLAYBOOK +export ANSIBLE_TAGS=all +export ANSIBLE_PLAYBOOK_COMMAND_OPTIONS=${ANSIBLE_PLAYBOOK_COMMAND_OPTIONS:-"--connection=local"} + +# Set devshop_version at runtime so it installs the correct source code via git and we don't get the version stuck in the static inventory file. +$DEVSHOP_INSTALL_PATH/scripts/devshop-ansible-playbook --extra-vars=devshop_version=${DEVSHOP_VERSION} + +# Run devshop status, return exit code. +su - aegir -c "devshop status" +if [ ${PIPESTATUS[0]} == 0 ]; then + echo $POST_INSTALL_WELCOME_MSG + su - aegir -c "devshop login" + exit 0 +else + echo "The command 'devshop status' had an error. Check the logs and try again." + exit 1 +fi + +} + +# wrapped up in a function so that we have some protection against only getting +# half the file during "curl | sh" +# shellcheck disable=SC2119 +do_install \ No newline at end of file