nixpkgs/overlays/custom-customer-project/default.nix

178 lines
6.7 KiB
Nix

self: super:
let
tmux = "${super.pkgs.tmux}/bin/tmux";
mycli = "${super.pkgs.mycli}/bin/mycli";
sed = "${super.pkgs.gnused}/bin/sed";
source = ''
#!${super.pkgs.bash}/bin/bash
# This script will create a new tmux session (or attach existing)
# TODO/NOTE: mysql is still coming from Ubuntu system, same goes for docker-compose
# TODO/NOTE: Does not yet start nix shells, something for future once I figured it out.
# Initialize some variables
domain="$(echo $1 | ${sed} 's/\./-/g')"
session="project-$domain"
projectName="$(pwd)/$1"
projectRoot="$(pwd)/$1"
url="https://$domain.$(basename $(pwd) | ${sed} 's/\-//g').localhost/"
editorPath="$projectRoot"
# Only create session if not already exists
${tmux} has-session -t "$session"
if [ $? != 0 ]
then
windowId=0
databaseName=$(basename $projectName)
databaseName="$(basename $(dirname $projectName))_"$databaseName
databaseName=''${databaseName//-/}
# Support legacy variant with underscrore in db name
if ! mysql -u admin "$databaseName" -e exit > /dev/null 2>&1 ; then
databaseName=$(basename $projectName)
# Replace - with _ for project name
databaseName=''${databaseName//-/_}
databaseName="$(basename $(dirname $projectName))_"$databaseName
# Replace - with nothing for customer name, which was added right above
databaseName=''${databaseName//-/}
fi
# Support legacy variant without customer prefix for now
if ! mysql -u admin "$databaseName" -e exit > /dev/null 2>&1 ; then
databaseName=$(basename $projectName)
databaseName=''${databaseName//-/_}
fi
editorPath="$projectRoot"
if [ -d "$projectRoot/project" ]; then
editorPath="$projectRoot/project"
elif [ -d "$projectRoot/htdocs" ]; then
editorPath="$projectRoot/htdocs"
fi
# Open Editor
${tmux} new-session -s "$session" -n editor -d
${tmux} send-keys "export TYPO3_BASE=$url TYPO3_COMPOSER_AUTOLOAD=1 SOLR_HOST=localhost SOLR_PORT=8983 SOLR_SCHEME=http SOLR_CORE=core_de" C-m
${tmux} send-keys "export typo3DatabaseName=testing typo3DatabaseHost=localhost typo3DatabaseUsername=testing typo3DatabasePassword=testing" C-m
${tmux} send-keys " renice -n 5 \$\$" C-m
${tmux} send-keys " cd $editorPath" C-m
${tmux} send-keys C-l
${tmux} send-keys " nvim" C-m
let "windowId+=1"
# Open Shell
${tmux} new-window -n project -t "$session"
${tmux} send-keys -t "$session:$windowId" "cd $editorPath" C-m
${tmux} send-keys " renice -n 5 \$\$" C-m
${tmux} send-keys "export TYPO3_BASE=$url TYPO3_COMPOSER_AUTOLOAD=1 SOLR_HOST=localhost SOLR_PORT=8983 SOLR_SCHEME=http SOLR_CORE=core_de" C-m
${tmux} send-keys "export typo3DatabaseName=testing typo3DatabaseHost=localhost typo3DatabaseUsername=testing typo3DatabasePassword=testing" C-m
${tmux} send-keys C-l
if [ "$databaseName" != "" ]; then
${tmux} send-keys "export TYPO3_DATABASE=$databaseName" C-m
${tmux} send-keys C-l
else
${tmux} send-keys "export TYPO3_DATABASE="
fi
let "windowId+=1"
${tmux} select-pane -t 0
# Connect to database
${tmux} new-window -n database -t "$session"
${tmux} send-keys -t "$session:$windowId" "cd $editorPath" C-m
${tmux} send-keys " renice -n 5 \$\$" C-m
if [ "$databaseName" != "" ]; then
${tmux} send-keys "${mycli} -u admin -D $databaseName" C-m
else
${tmux} send-keys "${mycli} -u admin -D "
fi
${tmux} send-keys C-l
${tmux} select-pane -t 0
let "windowId+=1"
# Open export folder
# This step is specific to one customer
if [ -d "$projectRoot/project/typo3export/files/export-edit/" ]; then
${tmux} new-window -n export -t "$session"
${tmux} send-keys -t "$session:$windowId" "cd $projectRoot/project/typo3export/files/export-edit/" C-m
${tmux} send-keys C-l
let "windowId+=1"
fi
# TODO: Build dynamically, check each folder for docker-compose.yml and execute?!
# Or at least define array of folder names to check
# Start solr docker container
if [ -d "$projectRoot/solr/" ]; then
solrPath="$projectRoot/solr/"
${tmux} new-window -n docker -t "$session"
${tmux} send-keys -t "$session:$windowId" "cd $solrPath" C-m
${tmux} send-keys C-l
# Missing C-m at end, because we don't want to submit.
# We often don't need solr running to do our job.
${tmux} send-keys -t "$session:$windowId" "docker-compose run --rm --service-ports solr"
let "windowId+=1"
fi
# Start elastic container
if [ -d "$projectRoot/elastic/" ]; then
elasticPath="$projectRoot/elastic/"
${tmux} new-window -n docker -t "$session"
${tmux} send-keys -t "$session:$windowId" "cd $elasticPath" C-m
${tmux} send-keys C-l
# Missing C-m at end, because we don't want to submit.
# We often don't need elastic running to do our job.
${tmux} send-keys -t "$session:$windowId" "docker-compose run --rm --service-ports elastic"
let "windowId+=1"
fi
# Start mysql docker container
if [ -d "$projectRoot/mysql/" ]; then
mysqlPath="$projectRoot/mysql/"
${tmux} split-window
${tmux} send-keys "cd $mysqlPath" C-m
${tmux} send-keys C-l
${tmux} send-keys "docker-compose run --rm mysql" C-m
fi
# Start mongodb container
if [ -d "$projectRoot/mongodb/" ]; then
mongodbPath="$projectRoot/mongodb/"
${tmux} new-window -n docker -t "$session"
${tmux} send-keys -t "$session:$windowId" "cd $mongodbPath" C-m
${tmux} send-keys C-l
# Missing C-m at end, because we don't want to submit.
# We often don't need mongodb running to do our job.
${tmux} send-keys -t "$session:$windowId" "docker-compose run --rm --service-ports mongodb"
let "windowId+=1"
fi
# Activate shell
${tmux} select-window -t 1
fi
# Attach to existing or created session
${tmux} attach -t "$session"
'';
in {
custom-customer-project = super.stdenv.mkDerivation {
name = "custom-customer-project";
src = source;
dontUnpack = true;
installPhase = ''
mkdir -p "$out/bin"
printf "%s" "$src" > "$out/bin/customerProject"
chmod ug+x $out/bin/customerProject
'';
};
}