325 lines
9.1 KiB
Bash
325 lines
9.1 KiB
Bash
#!/bin/zsh
|
|
|
|
#
|
|
# rnt() = RentDynamics God Function
|
|
#
|
|
# Performs one of the following actions based on first argument:
|
|
# - (arg = NO ARGUMENT) Deactivate current virtual environment and return to $RD_PATH
|
|
# - (arg = project-name) Activate (and step into) project by name
|
|
# - (arg = 'db') Connect to databases available to the 1-password api
|
|
# - (arg = 'op') 1pass login/logout tool for current shell (assists in quick db access)
|
|
# - (arg = 'refresh_db') Drops and recreates local POSTGRES databases
|
|
# - (arg = 'cleanup') Performs safe-deletions on all projects' inactive branches
|
|
# - (arg = 'status') Uses 'rockymadden/slack-cli' to update slack status
|
|
# - (arg = 'mail') BROKEN : Uses a VMAIL client to connect to email
|
|
#
|
|
# The (arg = project-name) case requires the following project file-structure:
|
|
# $RD_PATH/project-name
|
|
# | /code (created by git clone PROJECT_URL code)
|
|
# | /env (created by virtualenv or nodeenv)
|
|
#
|
|
|
|
function rnt() {
|
|
ERROR_CODE=0;
|
|
|
|
case $1 in
|
|
db | DB)
|
|
RENT_DYNAMICS_CONNECT_TO_DATABASE "${@:2}" || ERROR_CODE=1;
|
|
;;
|
|
refresh_db | REFRESH_DB)
|
|
RENT_DYNAMICS_REFRESH_LOCAL_POSTGRES_DATABASES "${@:2}" || ERROR_CODE=2;
|
|
;;
|
|
cleanup | CLEANUP)
|
|
RENT_DYNAMICS_GIT_PROJECT_CLEAN_UP "${@:2}" || ERROR_CODE=3;
|
|
;;
|
|
status | slack-status)
|
|
RENT_DYNAMICS_UPDATE_SLACK_STATUS "${@:2}" || ERROR_CODE=4;
|
|
;;
|
|
mail | MAIL | email | EMAIL)
|
|
RENT_DYNAMICS_CONNECT_TO_EMAIL || ERROR_CODE=5;
|
|
;;
|
|
op | 1pass )
|
|
RENT_DYNAMICS_ONE_PASSWORD "${@:2}" || ERROR_CODE=6;
|
|
;;
|
|
clone )
|
|
RENT_DYNAMICS_GIT_PROJECT_SET_UP "${@:2}" || ERROR_CODE=7;
|
|
;;
|
|
shell )
|
|
RENT_DYNAMICS_MANAGE_PY_SHELL "${@:2}" || ERROR_CODE=8;
|
|
;;
|
|
usage )
|
|
RENT_DYNAMICS_CHECK_PROJECT_USAGE "${@:2}" || ERROR_CODE=9;
|
|
;;
|
|
*)
|
|
deactivate >/dev/null 2>/dev/null || deactivate_node >/dev/null 2>/dev/null;
|
|
cd "$RD_PATH"
|
|
|
|
[ -d "$1" ] && {
|
|
cd "$1" >/dev/null 2>/dev/null;
|
|
[ -f "./env/bin/activate" ] \
|
|
&& source "./env/bin/activate" \
|
|
|| echo 'No virtual environment here, boss!';
|
|
[ -f "./myenv" ] \
|
|
&& source "./myenv" \
|
|
&& echo 'Loaded custom environment settings!';
|
|
[ -d "./code" ] && cd "./code";
|
|
}
|
|
esac
|
|
|
|
return ERROR_CODE;
|
|
}
|
|
_rnt () { # autocompletion
|
|
local state;
|
|
|
|
_arguments \
|
|
'1: :->project_or_command'\
|
|
':: :->command_args'\
|
|
;
|
|
case "$state" in
|
|
project_or_command)
|
|
compadd $(ls "$RD_PATH");
|
|
compadd db refresh_db cleanup mail status op clone usage;
|
|
;;
|
|
command_args)
|
|
[ $words[2] == 'status' ] && _RENT_DYNAMICS_UPDATE_SLACK_STATUS;
|
|
[ $words[2] == 'op' ] && _RENT_DYNAMICS_ONE_PASSWORD;
|
|
;;
|
|
esac
|
|
}
|
|
compdef _rnt rnt;
|
|
|
|
###############################################################################
|
|
### HELPERS ###################################################################
|
|
###############################################################################
|
|
|
|
function RENT_DYNAMICS_CONNECT_TO_DATABASE() {
|
|
"$DOTWRYN/bin/rentdynamics/db.sh" "$@";
|
|
}
|
|
|
|
function RENT_DYNAMICS_REFRESH_LOCAL_POSTGRES_DATABASES() {
|
|
psql -U postgres -c "DROP DATABASE rentdynamics;"
|
|
psql -U postgres -c "CREATE DATABASE rentdynamics with owner rd;"
|
|
psql -U postgres -c "DROP DATABASE rdrentplus;"
|
|
psql -U postgres -c "CREATE DATABASE rdrentplus with owner rd;"
|
|
}
|
|
|
|
function RENT_DYNAMICS_GIT_PROJECT_CLEAN_UP() {
|
|
printf "\nInitializing branch cleanup...\n\n"
|
|
for dir in $(ls $RD_PATH); do
|
|
rnt $dir >/dev/null 2>/dev/null;
|
|
if [ -d .git ]; then
|
|
printf " - %s\e[1;34m %s\e[0m..." "clearing repository" "$dir";
|
|
git branch -d $(git branch | sed -E "/master|\*|epic-*/d") >/dev/null 2>/dev/null;
|
|
printf "\e[1;32m%s\e[0m\n" " DONE";
|
|
else
|
|
printf " - \e[1;34m%s\e[1;31m %s\e[0m\n" "$dir" "is not a git repository";
|
|
fi
|
|
rnt;
|
|
done;
|
|
printf "\n\n\e[1;36m%s\e[1;35m %s\e[0m\n\n" "RentDynamics" "repository branches all clean!";
|
|
}
|
|
|
|
function RENT_DYNAMICS_CONNECT_TO_EMAIL() {
|
|
$WEBBROWSER https://mail.google.com/mail/u/1;
|
|
}
|
|
|
|
function RENT_DYNAMICS_UPDATE_SLACK_STATUS() {
|
|
slack-cli --version >/dev/null 2>&1 || {
|
|
echo 'I require the slack-cli. For installation and setup, see https://github.com/rockymadden/slack-cli';
|
|
}
|
|
ERROR_MESSAGE="Slack CLI Error"
|
|
|
|
local STATUS_ARG;
|
|
case $1 in
|
|
start)
|
|
STATUS_ARG='boost';
|
|
;;
|
|
stop)
|
|
STATUS_ARG='ride';
|
|
;;
|
|
*)
|
|
STATUS_ARG="$1";
|
|
;;
|
|
esac
|
|
|
|
local ACTIVE='active';
|
|
local AWAY='away';
|
|
local PRESENCE="$ACTIVE";
|
|
|
|
local MESSAGE;
|
|
local EMOJI;
|
|
case $STATUS_ARG in
|
|
boost | boost-fire | f-zero)
|
|
MESSAGE="Use your heart, and boost fire!"; EMOJI=':boost_fire:';
|
|
;;
|
|
monkas)
|
|
MESSAGE=" "; EMOJI=':monkas:';
|
|
;;
|
|
ride | bike-ride | bike)
|
|
MESSAGE="probably riding"; EMOJI=':man-biking:'; PRESENCE="$AWAY";
|
|
;;
|
|
plank)
|
|
MESSAGE="plank time!"; EMOJI=':evergreen_tree:';
|
|
;;
|
|
meal | eat | food)
|
|
MESSAGE="so hungry..."; EMOJI=':hamburger:'; PRESENCE="$AWAY";
|
|
;;
|
|
turbo)
|
|
MESSAGE="ZOOOM"; EMOJI=':turbo:';
|
|
;;
|
|
super)
|
|
MESSAGE="AAAAAAAAAAAAHHHHHHHHH"; EMOJI=':gohan:';
|
|
;;
|
|
meeting)
|
|
MESSAGE="afk"; EMOJI=':necktie:'; PRESENCE="$AWAY";
|
|
;;
|
|
budget)
|
|
MESSAGE="did somebody say skee-ball??"; EMOJI=':scales:';
|
|
;;
|
|
cheese)
|
|
MESSAGE="only the most important things on my mind"; EMOJI=':cheese_wedge:';
|
|
;;
|
|
foos)
|
|
MESSAGE="I will defeat Mike... someday..."; EMOJI=':soccer:'; PRESENCE="$AWAY";
|
|
;;
|
|
lax | belax | belax8 )
|
|
MESSAGE="BELAAAAAAAX"; EMOJI=':exploding_head:';
|
|
;;
|
|
panic)
|
|
MESSAGE="dont panic!"; EMOJI=':exclamation:';
|
|
;;
|
|
off | not-working | no-money)
|
|
MESSAGE="not making money"; EMOJI=':sunglasses:'; PRESENCE="$AWAY";
|
|
;;
|
|
school )
|
|
MESSAGE="Shhhh! Taking notes..."; EMOJI=':male-teacher:'; PRESENCE="$AWAY";
|
|
;;
|
|
clear | clear-status | no-status | please-turn-off-my-status-mr-slack-robot)
|
|
slack status clear >/dev/null 2>&1
|
|
;;
|
|
:*:)
|
|
MESSAGE=" "; EMOJI="$1";
|
|
;;
|
|
*)
|
|
ERROR_MESSAGE="Unrecognized preset or emoji";
|
|
;;
|
|
esac
|
|
|
|
[ $2 ] && MESSAGE="$2";
|
|
|
|
[ $EMOJI ] \
|
|
&& slack-cli status edit "$MESSAGE" "$EMOJI" >/dev/null 2>&1 \
|
|
&& slack-cli presence $PRESENCE >/dev/null 2>&1 \
|
|
&& echo "Slack status successfully updated! : ($STATUS_ARG)" \
|
|
|| echo "ERROR:::Failed to update slack status :c ($ERROR_MESSAGE)";
|
|
}
|
|
_RENT_DYNAMICS_UPDATE_SLACK_STATUS() { # autocompletion
|
|
compadd \
|
|
boost-fire bike-ride monkas surprised plank meal turbo super meeting budget cheese foos belax \
|
|
panic not-working school clear-status \
|
|
;
|
|
}
|
|
|
|
RENT_DYNAMICS_ONE_PASSWORD() {
|
|
ERROR_CODE=0;
|
|
|
|
case $1 in
|
|
login )
|
|
RENT_DYNAMICS_ONE_PASSWORD_LOGIN "${@:2}" || ERROR_CODE=1;
|
|
;;
|
|
logout | deactivate )
|
|
RENT_DYNAMICS_ONE_PASSWORD_LOGOUT "${@:2}" || ERROR_CODE=2;
|
|
;;
|
|
* )
|
|
RENT_DYNAMICS_ONE_PASSWORD_CHECK_LOGIN "${@:2}" || ERROR_CODE=3;
|
|
;;
|
|
esac
|
|
|
|
return "$ERROR_CODE";
|
|
}
|
|
_RENT_DYNAMICS_ONE_PASSWORD() { # autocompletion
|
|
compadd \
|
|
login deactivate\
|
|
;
|
|
}
|
|
|
|
RENT_DYNAMICS_ONE_PASSWORD_LOGIN() {
|
|
ERROR_CODE=0;
|
|
|
|
RENT_DYNAMICS_ONE_PASSWORD_IS_LOGGED_IN && {
|
|
echo 'Already logged in!';
|
|
} || {
|
|
unset OP_SESSION_rent_dynamics;
|
|
eval $(op signin rent_dynamics 2>/dev/null);
|
|
|
|
op list templates >/dev/null 2>&1 && {
|
|
echo 'Successfully logged in to 1-password!';
|
|
} || {
|
|
echo 'Failed to log in. Double check your password and op-cli settings.';
|
|
echo 'Have you run one-time setup? (`op signin rent-dynamics.1-password.com <your-email-address>`)';
|
|
ERROR_CODE=1;
|
|
};
|
|
}
|
|
|
|
return "$ERROR_CODE";
|
|
}
|
|
|
|
RENT_DYNAMICS_ONE_PASSWORD_LOGOUT() {
|
|
[ ! -z $OP_SESSION_rent_dynamics ] && {
|
|
unset OP_SESSION_rent_dynamics && echo 'Successfully logged out from 1-password';
|
|
} || {
|
|
echo 'Current shell is not logged in to 1-password';
|
|
return 1;
|
|
}
|
|
}
|
|
|
|
RENT_DYNAMICS_ONE_PASSWORD_CHECK_LOGIN() {
|
|
RENT_DYNAMICS_ONE_PASSWORD_IS_LOGGED_IN \
|
|
&& echo 'Current shell is logged-in to rent_dynamics 1-password'\
|
|
|| echo 'Current shell is not logged-in rent_dynamics 1-password';
|
|
return 0;
|
|
}
|
|
|
|
RENT_DYNAMICS_ONE_PASSWORD_IS_LOGGED_IN() {
|
|
op list templates >/dev/null 2>&1 && return 0 || return 1;
|
|
}
|
|
|
|
RENT_DYNAMICS_GIT_PROJECT_SET_UP() {
|
|
PROJECT_URL="git@github.com:RentDynamics/$1.git";
|
|
PROJECT_DIR="$RD_PATH/$1";
|
|
|
|
[ -d "$PROJECT_DIR" ] \
|
|
&& { echo "Project '$1' already exists locally (access quickly with 'rnt $1')."; return 1; }
|
|
|
|
git ls-remote "$PROJECT_URL" >/dev/null || return 2;
|
|
|
|
mkdir "$PROJECT_DIR" >/dev/null 2>&1;
|
|
git clone -q "$PROJECT_URL" "$PROJECT_DIR/code" \
|
|
&& echo "Succesfully cloned project '$1' (access quickly with 'rnt $1')." \
|
|
|| { echo "$PROJECT_DIR"; rm -rI "$PROJECT_DIR" }
|
|
}
|
|
|
|
RENT_DYNAMICS_MANAGE_PY_SHELL() {
|
|
echo 'TODO: Implement me!';
|
|
return;
|
|
|
|
MANAGE_PY_DIR="$(pwd | sed 's/\(.*code\).*/\1/')";
|
|
PROJECT_NAME="$(pwd | sed 's/.*\/\(.*\)\/code.*/\1/' | sed 's/-/_/g')";
|
|
|
|
IMPORT_MODELS="from $PROJECT_NAME.domain.models import *\n";
|
|
IMPORT_HELPER="from $PROJECT_NAME.test.helpers import *\n";
|
|
|
|
IMPORT_PPRINT='from pprint import pprint\n';
|
|
PPRINT_LAMBDA='P = lambda x: pprint(vars(x))\n';
|
|
|
|
COMMANDS="$IMPORT_MODELS$IMPORT_HELPER$IMPORT_PPRINT$PPRINT_LAMBDA";
|
|
|
|
"$MANAGE_PY_DIR/manage.py" shell -i ipython <(echo $COMMANDS);
|
|
}
|
|
|
|
RENT_DYNAMICS_CHECK_PROJECT_USAGE() {
|
|
echo "The regex $1 is found in the following projects/repositories:\n"
|
|
rg $1 $RD_PATH -l | sed 's/^.*w0ryn\/RentDynamics\///' | sed 's/\/.*$//' | sort | uniq;
|
|
echo;
|
|
}
|