v3.0.0 "The Great Overhaul"
===================================================================== Notice the major version change which comes with breaking changes to 2.x! Reconstructs "library" functions for both python and zsh scwrypts, with changes to virtualenv naming conventions (you'll need to refresh all virtualenv with the appropriate scwrypt). --- Changes ------------------------------ - changed a naming convention across zsh scripts, particularly removing underscores where there is no need to avoid naming clash (e.g. 'zsh/lib/utils/io.zsh' renames '__STATUS' to 'STATUS') - moved clients reliant on py.lib.http to the py.lib.http module - python scripts now rely on py.lib.scwrypts.execute - updated package.json in zx scripts to include `type = module` - 'scwrypts --list' commandline argument now includes additional relevant data for each scwrypt - environment variables no longer add themselves to be staged in the '.env.template' --- New Features ------------------------- - new 'use' syntax for disjoint import within zsh scripts; took me a very long time to convince myself this would be necessary - introduced scwrypt "groups" to allow portable module creation; (i.e. ability add your own scripts from another repo!) - py.lib.scwrypts.io provides a combined IO stream for quick, hybrid use of input/output files and stdin/stdout - py.lib.fzf provides a wrapper to provide similar functionality to zsh/utils/io.zsh including fzf_(head|tail) - improved efficiency of various scwrypts; notably reducing runtime of scwrypts/environment sync - improved scwrypts CLI by adding new options for exact scwrypt matching, better filtering, and prettier/more-detailed interfaces --- New Scripts -------------------------- - py/twilio ) basic SMS integration with twilio - send-sms - py/directus ) interactive directus GET query - get-items - py/discord ) post message to discord channel or webhook - post-message
This commit is contained in:
@ -1,13 +0,0 @@
|
||||
_DEPENDENCIES+=(
|
||||
aws
|
||||
jq
|
||||
)
|
||||
_REQUIRED_ENV+=(
|
||||
AWS_ACCOUNT
|
||||
AWS_PROFILE
|
||||
AWS_REGION
|
||||
)
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
||||
|
||||
_AWS() { aws --profile $AWS_PROFILE --region $AWS_REGION --output json $@; }
|
@ -1,6 +0,0 @@
|
||||
_DEPENDENCIES+=(
|
||||
docker
|
||||
)
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
@ -1,14 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
|
||||
__STATUS "performing AWS ECR docker login"
|
||||
|
||||
_AWS ecr get-login-password | docker login \
|
||||
--username AWS \
|
||||
--password-stdin \
|
||||
"$AWS_ACCOUNT.dkr.ecr.$AWS_REGION.amazonaws.com" \
|
||||
&& __SUCCESS "logged in to 'AWS:$AWS_ACCOUNT:$AWS_REGION'" \
|
||||
|| __FAIL 1 "unable to login to '$AWS_ACCOUNT' in '$AWS_REGION'"
|
@ -1,6 +0,0 @@
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=(
|
||||
AWS__EFS__LOCAL_MOUNT_POINT
|
||||
)
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
@ -1,34 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
|
||||
_EFS_DISCONNECT() {
|
||||
[ ! -d "$AWS__EFS__LOCAL_MOUNT_POINT" ] && {
|
||||
__STATUS 'no efs currently mounted'
|
||||
exit 0
|
||||
}
|
||||
|
||||
local MOUNTED=$(ls "$AWS__EFS__LOCAL_MOUNT_POINT")
|
||||
[ ! $MOUNTED ] && {
|
||||
__STATUS 'no efs currently mounted'
|
||||
exit 0
|
||||
}
|
||||
|
||||
__GETSUDO || exit 1
|
||||
|
||||
|
||||
local SELECTED=$(echo $MOUNTED | __FZF 'select a file system to unmount')
|
||||
[ ! $SELECTED ] && __ABORT
|
||||
|
||||
local EFS="$AWS__EFS__LOCAL_MOUNT_POINT/$SELECTED"
|
||||
__STATUS "unmounting '$SELECTED'"
|
||||
sudo umount $EFS >/dev/null 2>&1
|
||||
sudo rmdir $EFS \
|
||||
&& __SUCCESS "done" \
|
||||
|| __FAIL 2 "failed to unmount '$EFS'"
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
_EFS_DISCONNECT
|
@ -1,6 +0,0 @@
|
||||
_DEPENDENCIES+=(
|
||||
kubectl
|
||||
)
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
@ -1,19 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
|
||||
__STATUS "performing AWS ECR docker login"
|
||||
|
||||
CLUSTER_NAME=$(\
|
||||
_AWS eks list-clusters \
|
||||
| jq -r '.[] | .[]' \
|
||||
| __FZF 'select a cluster'
|
||||
)
|
||||
[ ! $CLUSTER_NAME ] && __ABORT
|
||||
|
||||
__STATUS "updating kubeconfig for '$CLUSTER_NAME'"
|
||||
_AWS eks update-kubeconfig --name $CLUSTER_NAME \
|
||||
&& __SUCCESS "kubeconfig updated with '$CLUSTER_NAME'" \
|
||||
|| __ERROR "failed to update kubeconfig; do you have permissions to access '$CLUSTER_NAME'?"
|
@ -1,6 +0,0 @@
|
||||
_DEPENDENCIES+=(
|
||||
cli53
|
||||
)
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
@ -1,4 +0,0 @@
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
@ -1,30 +0,0 @@
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=(
|
||||
AWS__S3__MEDIA_TARGETS
|
||||
AWS__S3__MEDIA_BUCKET
|
||||
)
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
||||
|
||||
AWS__S3__MEDIA_TARGETS=($(echo $AWS__S3__MEDIA_TARGETS | sed 's/,/\n/g'))
|
||||
|
||||
__SYNC_MEDIA() {
|
||||
local ACTION="$1"
|
||||
local REMOTE_TARGET="s3://$AWS__S3__MEDIA_BUCKET/$2"
|
||||
local LOCAL_TARGET="$HOME/$2"
|
||||
|
||||
local A B
|
||||
case $ACTION in
|
||||
push ) A="$LOCAL_TARGET"; B="$REMOTE_TARGET" ;;
|
||||
pull ) A="$REMOTE_TARGET"; B="$LOCAL_TARGET" ;;
|
||||
|
||||
* ) __ERROR "unknown action '$1'"; return 1 ;;
|
||||
esac
|
||||
|
||||
local FLAGS=(${@:3})
|
||||
|
||||
__STATUS "${ACTION}ing $2"
|
||||
_AWS s3 sync $A $B $FLAGS \
|
||||
&& __SUCCESS "$2 up-to-date" \
|
||||
|| { __ERROR "unable to sync $2 (see above)"; return 1; }
|
||||
}
|
@ -1,27 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
|
||||
__PULL_ALL_MEDIA() {
|
||||
local FLAGS=($@)
|
||||
local FAILED_COUNT=0
|
||||
|
||||
__STATUS 'starting media download from s3'
|
||||
|
||||
local TARGET
|
||||
for TARGET in $AWS__S3__MEDIA_TARGETS
|
||||
do
|
||||
__SYNC_MEDIA pull $TARGET $FLAGS || ((FAILED_COUNT+=1))
|
||||
done
|
||||
|
||||
[[ $FAILED_COUNT -eq 0 ]] \
|
||||
&& __SUCCESS 'local media files now up-to-date' \
|
||||
|| __FAIL $FAILED_COUNT 'unable to download one or more targets' \
|
||||
;
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
|
||||
__PULL_ALL_MEDIA $@
|
@ -1,27 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
|
||||
__PUSH_ALL_MEDIA() {
|
||||
local FLAGS=($@)
|
||||
local FAILED_COUNT=0
|
||||
|
||||
__STATUS 'starting media upload to s3'
|
||||
|
||||
local TARGET
|
||||
for TARGET in $AWS__S3__MEDIA_TARGETS
|
||||
do
|
||||
__SYNC_MEDIA push $TARGET $FLAGS || ((FAILED_COUNT+=1))
|
||||
done
|
||||
|
||||
[[ $FAILED_COUNT -eq 0 ]] \
|
||||
&& __SUCCESS 's3 media files now up-to-date' \
|
||||
|| __FAIL $FAILED_COUNT 'unable to upload one or more targets' \
|
||||
;
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
|
||||
__PUSH_ALL_MEDIA $@
|
10
zsh/cloud/aws/ecr/login
Executable file
10
zsh/cloud/aws/ecr/login
Executable file
@ -0,0 +1,10 @@
|
||||
#!/bin/zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use cloud/aws/ecr
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
ECR_LOGIN $@
|
@ -1,37 +1,40 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
DEPENDENCIES+=(jq)
|
||||
REQUIRED_ENV+=(AWS__EFS__LOCAL_MOUNT_POINT)
|
||||
|
||||
use cloud/aws/cli
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
_EFS_CONNECT() {
|
||||
__GETSUDO || exit 1
|
||||
EFS_CONNECT() {
|
||||
GETSUDO || exit 1
|
||||
[ ! -d $AWS__EFS__LOCAL_MOUNT_POINT ] && {
|
||||
sudo mkdir $AWS__EFS__LOCAL_MOUNT_POINT \
|
||||
&& __STATUS "created local mount point '$AWS__EFS__LOCAL_MOUNT_POINT'"
|
||||
&& STATUS "created local mount point '$AWS__EFS__LOCAL_MOUNT_POINT'"
|
||||
}
|
||||
|
||||
local FS_ID=$(\
|
||||
_AWS efs describe-file-systems \
|
||||
AWS efs describe-file-systems \
|
||||
| jq -r '.[] | .[] | .FileSystemId' \
|
||||
| __FZF 'select a filesystem to mount' \
|
||||
| FZF 'select a filesystem to mount' \
|
||||
)
|
||||
[ ! $FS_ID ] && __ABORT
|
||||
[ ! $FS_ID ] && ABORT
|
||||
|
||||
local MOUNT_POINT="$AWS__EFS__LOCAL_MOUNT_POINT/$FS_ID"
|
||||
[ -d "$MOUNT_POINT" ] && sudo rmdir "$MOUNT_POINT" >/dev/null 2>&1
|
||||
[ -d "$MOUNT_POINT" ] && {
|
||||
__STATUS "$FS_ID is already mounted"
|
||||
STATUS "$FS_ID is already mounted"
|
||||
exit 0
|
||||
}
|
||||
|
||||
local MOUNT_TARGETS=$(_AWS efs describe-mount-targets --file-system-id $FS_ID)
|
||||
local MOUNT_TARGETS=$(AWS efs describe-mount-targets --file-system-id $FS_ID)
|
||||
local ZONE=$(\
|
||||
echo $MOUNT_TARGETS \
|
||||
| jq -r '.[] | .[] | .AvailabilityZoneName' \
|
||||
| sort -u | __FZF 'select availability zone'\
|
||||
| sort -u | FZF 'select availability zone'\
|
||||
)
|
||||
[ ! $ZONE ] && __ABORT
|
||||
[ ! $ZONE ] && ABORT
|
||||
|
||||
local MOUNT_IP=$(\
|
||||
echo $MOUNT_TARGETS \
|
||||
@ -39,15 +42,15 @@ _EFS_CONNECT() {
|
||||
| head -n1 \
|
||||
)
|
||||
|
||||
__SUCCESS 'ready to mount!'
|
||||
__REMINDER 'your device must be connected to the appropriate VPN'
|
||||
SUCCESS 'ready to mount!'
|
||||
REMINDER 'for private file-systems, you must be connected to the appropriate VPN'
|
||||
|
||||
__STATUS "file system id : $FS_ID"
|
||||
__STATUS "availability zone : $ZONE"
|
||||
__STATUS "file system ip : $MOUNT_IP"
|
||||
__STATUS "local mount point : $MOUNT_POINT"
|
||||
STATUS "file system id : $FS_ID"
|
||||
STATUS "availability zone : $ZONE"
|
||||
STATUS "file system ip : $MOUNT_IP"
|
||||
STATUS "local mount point : $MOUNT_POINT"
|
||||
|
||||
__Yn 'proceed?' || __ABORT
|
||||
Yn 'proceed?' || ABORT
|
||||
|
||||
sudo mkdir $MOUNT_POINT \
|
||||
&& sudo mount \
|
||||
@ -55,12 +58,12 @@ _EFS_CONNECT() {
|
||||
-o nfsvers=4.1,rsize=1048576,wsize=1048576,hard,timeo=600,retrans=2,noresvport \
|
||||
$MOUNT_IP:/ \
|
||||
"$MOUNT_POINT" \
|
||||
&& __SUCCESS "mounted at '$MOUNT_POINT'" \
|
||||
&& SUCCESS "mounted at '$MOUNT_POINT'" \
|
||||
|| {
|
||||
sudo rmdir $MOUNT_POINT >/dev/null 2>&1
|
||||
__FAIL 2 "unable to mount '$FS_ID'"
|
||||
FAIL 2 "unable to mount '$FS_ID'"
|
||||
}
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
_EFS_CONNECT
|
||||
EFS_CONNECT $@
|
37
zsh/cloud/aws/efs/unmount
Executable file
37
zsh/cloud/aws/efs/unmount
Executable file
@ -0,0 +1,37 @@
|
||||
#!/bin/zsh
|
||||
DEPENDENCIES+=(jq)
|
||||
REQUIRED_ENV+=(AWS__EFS__LOCAL_MOUNT_POINT)
|
||||
|
||||
use cloud/aws/cli
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
EFS_DISCONNECT() {
|
||||
[ ! -d "$AWS__EFS__LOCAL_MOUNT_POINT" ] && {
|
||||
STATUS 'no efs currently mounted'
|
||||
exit 0
|
||||
}
|
||||
|
||||
local MOUNTED=$(ls "$AWS__EFS__LOCAL_MOUNT_POINT")
|
||||
[ ! $MOUNTED ] && {
|
||||
STATUS 'no efs currently mounted'
|
||||
exit 0
|
||||
}
|
||||
|
||||
GETSUDO || exit 1
|
||||
|
||||
|
||||
local SELECTED=$(echo $MOUNTED | FZF 'select a file system to unmount')
|
||||
[ ! $SELECTED ] && ABORT
|
||||
|
||||
local EFS="$AWS__EFS__LOCAL_MOUNT_POINT/$SELECTED"
|
||||
STATUS "unmounting '$SELECTED'"
|
||||
sudo umount $EFS >/dev/null 2>&1
|
||||
sudo rmdir $EFS \
|
||||
&& SUCCESS "done" \
|
||||
|| FAIL 2 "failed to unmount '$EFS'"
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
EFS_DISCONNECT $@
|
10
zsh/cloud/aws/eks/login
Executable file
10
zsh/cloud/aws/eks/login
Executable file
@ -0,0 +1,10 @@
|
||||
#!/bin/zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use cloud/aws/eks
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
EKS_CLUSTER_LOGIN $@
|
@ -1,14 +1,18 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use cloud/aws/rds
|
||||
use db/postgres
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
RDS_INTERACTIVE_LOGIN() {
|
||||
CREATE_BACKUP() {
|
||||
local DB_HOST DB_PORT DB_NAME DB_USER DB_PASS
|
||||
GET_DATABASE_CREDENTIALS $@ || return 1
|
||||
RDS__GET_DATABASE_CREDENTIALS $@ || return 1
|
||||
|
||||
__RUN_SCWRYPT 'zsh/db/postgres/pg_dump' -- \
|
||||
PG_DUMP \
|
||||
--host $DB_HOST \
|
||||
--port $DB_PORT \
|
||||
--name $DB_NAME \
|
||||
@ -17,6 +21,5 @@ RDS_INTERACTIVE_LOGIN() {
|
||||
;
|
||||
}
|
||||
|
||||
|
||||
#####################################################################
|
||||
RDS_INTERACTIVE_LOGIN $@
|
||||
CREATE_BACKUP $@
|
@ -1,14 +1,18 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use cloud/aws/rds
|
||||
use db/postgres
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
RDS_INTERACTIVE_LOGIN() {
|
||||
local DB_HOST DB_PORT DB_NAME DB_USER DB_PASS
|
||||
GET_DATABASE_CREDENTIALS $@ || return 1
|
||||
RDS__GET_DATABASE_CREDENTIALS $@ || return 1
|
||||
|
||||
__RUN_SCWRYPT 'zsh/db/interactive/postgres' -- \
|
||||
POSTGRES__LOGIN_INTERACTIVE \
|
||||
--host $DB_HOST \
|
||||
--port $DB_PORT \
|
||||
--name $DB_NAME \
|
@ -1,14 +1,18 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use cloud/aws/rds
|
||||
use db/postgres
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
RDS_INTERACTIVE_LOGIN() {
|
||||
LOAD_BACKUP() {
|
||||
local DB_HOST DB_PORT DB_NAME DB_USER DB_PASS
|
||||
GET_DATABASE_CREDENTIALS $@ || return 1
|
||||
RDS__GET_DATABASE_CREDENTIALS $@ || return 1
|
||||
|
||||
__RUN_SCWRYPT 'zsh/db/postgres/pg_restore' -- \
|
||||
PG_RESTORE \
|
||||
--host $DB_HOST \
|
||||
--port $DB_PORT \
|
||||
--name $DB_NAME \
|
||||
@ -19,4 +23,4 @@ RDS_INTERACTIVE_LOGIN() {
|
||||
|
||||
|
||||
#####################################################################
|
||||
RDS_INTERACTIVE_LOGIN $@
|
||||
LOAD_BACKUP $@
|
@ -1,21 +1,22 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
DEPENDENCIES+=(cli53)
|
||||
REQUIRED_ENV+=(AWS_PROFILE)
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
_ROUTE53_BACKUP() {
|
||||
ROUTE53_BACKUP() {
|
||||
local BACKUP_PATH="$SCWRYPTS_OUTPUT_PATH/$ENV_NAME/aws-dns-backup/$(date '+%Y-%m-%d')"
|
||||
mkdir -p $BACKUP_PATH >/dev/null 2>&1
|
||||
|
||||
local DOMAIN
|
||||
local JOBS=()
|
||||
for DOMAIN in $(_ROUTE53_GET_DOMAINS)
|
||||
for DOMAIN in $(ROUTE53_GET_DOMAINS)
|
||||
do
|
||||
( __STATUS "creating '$BACKUP_PATH/$DOMAIN.txt'" \
|
||||
( STATUS "creating '$BACKUP_PATH/$DOMAIN.txt'" \
|
||||
&& cli53 export --profile $AWS_PROFILE $DOMAIN > "$BACKUP_PATH/$DOMAIN.txt" \
|
||||
&& __SUCCESS "backed up '$DOMAIN'" \
|
||||
|| __ERROR "failed to back up '$DOMAIN'" \
|
||||
&& SUCCESS "backed up '$DOMAIN'" \
|
||||
|| ERROR "failed to back up '$DOMAIN'" \
|
||||
) &
|
||||
JOBS+=$!
|
||||
done
|
||||
@ -24,7 +25,7 @@ _ROUTE53_BACKUP() {
|
||||
for P in ${JOBS[@]}; do wait $P >/dev/null 2>&1; done
|
||||
}
|
||||
|
||||
_ROUTE53_GET_DOMAINS() {
|
||||
ROUTE53_GET_DOMAINS() {
|
||||
cli53 list --profile $AWS_PROFILE \
|
||||
| awk '{print $2;}' \
|
||||
| sed '1d; s/\.$//'\
|
||||
@ -32,4 +33,4 @@ _ROUTE53_GET_DOMAINS() {
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
_ROUTE53_BACKUP
|
||||
ROUTE53_BACKUP
|
10
zsh/cloud/media-sync/pull
Executable file
10
zsh/cloud/media-sync/pull
Executable file
@ -0,0 +1,10 @@
|
||||
#!/bin/zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use cloud/media-sync
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
MEDIA_SYNC__PULL $@
|
10
zsh/cloud/media-sync/push
Executable file
10
zsh/cloud/media-sync/push
Executable file
@ -0,0 +1,10 @@
|
||||
#!/bin/zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use cloud/media-sync
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
MEDIA_SYNC__PUSH $@
|
@ -1,31 +0,0 @@
|
||||
#####################################################################
|
||||
|
||||
source ${0:a:h}/../global/common.zsh
|
||||
source ${0:a:h}/utils/utils.module.zsh \
|
||||
|| { [ $DONT_EXIT ] && return 1 || exit 1; }
|
||||
|
||||
#####################################################################
|
||||
|
||||
__GET_ENV_FILES() { ls $SCWRYPTS_CONFIG_PATH/env | sort -r }
|
||||
[ ! "$(__GET_ENV_FILES)" ] && {
|
||||
cp $__ENV_TEMPLATE "$SCWRYPTS_CONFIG_PATH/env/dev"
|
||||
cp $__ENV_TEMPLATE "$SCWRYPTS_CONFIG_PATH/env/local"
|
||||
cp $__ENV_TEMPLATE "$SCWRYPTS_CONFIG_PATH/env/prod"
|
||||
}
|
||||
|
||||
__GET_ENV_NAMES() { __GET_ENV_FILES | sed 's/.*\///'; }
|
||||
__GET_ENV_FILE() { echo "$SCWRYPTS_CONFIG_PATH/env/$1"; }
|
||||
|
||||
__SELECT_OR_CREATE_ENV() { __GET_ENV_NAMES | __FZF_TAIL 'select/create an environment'; }
|
||||
__SELECT_ENV() { __GET_ENV_NAMES | __FZF 'select an environment'; }
|
||||
|
||||
#####################################################################
|
||||
|
||||
__GET_AVAILABLE_SCRIPTS() {
|
||||
cd $SCWRYPTS_ROOT;
|
||||
find . -mindepth 2 -type f -executable \
|
||||
| grep -v '\.git' \
|
||||
| grep -v 'node_modules' \
|
||||
| sed 's/^\.\///; s/\.[^.]*$//' \
|
||||
;
|
||||
}
|
@ -1,6 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
__EDIT "$CONFIG__USER_SETTINGS"
|
@ -1,10 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
|
||||
__STATUS 'updating all config files and links'
|
||||
__RUN_SCWRYPT zsh/config/symlinks || exit 1
|
||||
__RUN_SCWRYPT zsh/config/terminfo || exit 2
|
||||
__SUCCESS 'finished updating config files and links'
|
@ -1,24 +0,0 @@
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
||||
|
||||
|
||||
GET_POSTGRES_LOGIN_ARGS() {
|
||||
while [[ $# -gt 0 ]]
|
||||
do
|
||||
case $1 in
|
||||
--host | -h ) _HOST="$2"; shift 2 ;;
|
||||
--name | -d ) _NAME="$2"; shift 2 ;;
|
||||
--pass | -w ) _PASS="$2"; shift 2 ;;
|
||||
--port | -p ) _PORT="$2"; shift 2 ;;
|
||||
--user | -U ) _USER="$2"; shift 2 ;;
|
||||
* ) shift 1 ;;
|
||||
esac
|
||||
done
|
||||
|
||||
[ ! $_HOST ] && _HOST=127.0.0.1
|
||||
[ ! $_NAME ] && _NAME=postgres
|
||||
[ ! $_PORT ] && _PORT=5432
|
||||
[ ! $_USER ] && _USER=postgres
|
||||
}
|
@ -1,4 +0,0 @@
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
@ -1,29 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=(
|
||||
pgcli
|
||||
)
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
|
||||
_LOGIN_POSTGRES() {
|
||||
local _HOST _NAME _PASS _PORT _USER
|
||||
GET_POSTGRES_LOGIN_ARGS $@
|
||||
|
||||
local DATA_DIR="$SCWRYPTS_DATA_PATH/db/$_HOST"
|
||||
[ ! -d $DATA_DIR ] && mkdir -p $DATA_DIR
|
||||
cd $DATA_DIR
|
||||
|
||||
__STATUS "performing login : $_USER@$_HOST:$_PORT/$_NAME"
|
||||
__STATUS "working directory : $DATA_DIR"
|
||||
|
||||
PGPASSWORD="$_PASS" pgcli \
|
||||
--host $_HOST \
|
||||
--port $_PORT \
|
||||
--user $_USER \
|
||||
--dbname $_NAME \
|
||||
;
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
_LOGIN_POSTGRES $@
|
@ -1,4 +0,0 @@
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
9
zsh/db/postgres/interactive-pgcli
Executable file
9
zsh/db/postgres/interactive-pgcli
Executable file
@ -0,0 +1,9 @@
|
||||
#!/bin/zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use db/postgres
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
POSTGRES__LOGIN_INTERACTIVE $@
|
@ -1,44 +1,9 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=(
|
||||
pg_dump
|
||||
)
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use db/postgres
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
BACKUP_POSTGRES() {
|
||||
local _HOST _NAME _PASS _PORT _USER
|
||||
GET_POSTGRES_LOGIN_ARGS $@
|
||||
|
||||
local DATA_DIR="$SCWRYPTS_DATA_PATH/db/$_HOST/$_NAME/pg_dump"
|
||||
[ ! -d $DATA_DIR ] && mkdir -p $DATA_DIR
|
||||
cd $DATA_DIR
|
||||
|
||||
local OUTPUT_FILE="$DATA_DIR/$_NAME.dump"
|
||||
[ -f $OUTPUT_FILE ] && {
|
||||
local BACKUP_COUNT=$(ls "$DATA_DIR/$_NAME."*".dump" | wc -l)
|
||||
ls "$DATA_DIR/$_NAME."*".dump"
|
||||
|
||||
__INFO "discovered previous dump for '$_HOST/$_NAME'"
|
||||
__INFO "backing up previous dump to '$_NAME.$BACKUP_COUNT.dump'"
|
||||
|
||||
mv "$OUTPUT_FILE" "$DATA_DIR/$_NAME.$BACKUP_COUNT.dump"
|
||||
}
|
||||
|
||||
__STATUS "making backup of : $_USER@$_HOST:$_PORT/$_NAME"
|
||||
__STATUS "output file : $OUTPUT_FILE"
|
||||
|
||||
PGPASSWORD="$_PASS" pg_dump \
|
||||
--verbose \
|
||||
--format custom \
|
||||
--host "$_HOST" \
|
||||
--port "$_PORT" \
|
||||
--username "$_USER" \
|
||||
--dbname "$_NAME" \
|
||||
--file "$OUTPUT_FILE" \
|
||||
&& { __SUCCESS "finished backup of '$_HOST/$_NAME'"; __SUCCESS "saved to '$OUTPUT_FILE'"; } \
|
||||
|| { __ERROR "error creating backup for '$_HOST/$_NAME' (see above)"; return 1; }
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
BACKUP_POSTGRES $@
|
||||
PG_DUMP $@
|
||||
|
@ -1,55 +1,9 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=(
|
||||
pg_dump
|
||||
)
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use db/postgres
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
BACKUP_POSTGRES() {
|
||||
local _HOST _NAME _PASS _PORT _USER
|
||||
GET_POSTGRES_LOGIN_ARGS $@
|
||||
|
||||
local DATA_DIR="$SCWRYPTS_DATA_PATH/db/$_HOST/$_NAME/pg_restore"
|
||||
[ ! -d $DATA_DIR ] && mkdir -p $DATA_DIR
|
||||
cd $DATA_DIR
|
||||
|
||||
local INPUT_FILE="$DATA_DIR/$_NAME.dump"
|
||||
|
||||
[ ! -f $INPUT_FILE ] && {
|
||||
local DUMP="$(dirname $DATA_DIR)/pg_dump/$_NAME.dump"
|
||||
__STATUS $DUMP
|
||||
ls $DUMP
|
||||
|
||||
[ -f "$DUMP" ] && {
|
||||
__SUCCESS "discovered previous scwrypts dump"
|
||||
__SUCCESS "$DUMP"
|
||||
__Yn 'restore from this backup?' && INPUT_FILE="$DUMP"
|
||||
}
|
||||
|
||||
[ ! -f "$INPUT_FILE" ] && {
|
||||
__STATUS 'place backup in the following location:'
|
||||
__STATUS "$INPUT_FILE"
|
||||
}
|
||||
|
||||
while [ ! -f $INPUT_FILE ]; do sleep 1; done
|
||||
}
|
||||
|
||||
__STATUS "backup file : $DATA_DIR"
|
||||
__STATUS "database : $_USER@$_HOST:$_PORT/$_NAME"
|
||||
|
||||
PGPASSWORD="$_PASS" pg_restore \
|
||||
--verbose \
|
||||
--single-transaction \
|
||||
--format custom \
|
||||
--host "$_HOST" \
|
||||
--port "$_PORT" \
|
||||
--username "$_USER" \
|
||||
--dbname "$_NAME" \
|
||||
"$INPUT_FILE" \
|
||||
&& { __SUCCESS "finished restoring backup for '$_HOST/$_NAME'"; } \
|
||||
|| { __ERROR "error restoring backup for '$_HOST/$_NAME' (see above)"; return 1; }
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
BACKUP_POSTGRES $@
|
||||
PG_RESTORE $@
|
||||
|
51
zsh/db/postgres/run-sql
Executable file
51
zsh/db/postgres/run-sql
Executable file
@ -0,0 +1,51 @@
|
||||
#!/bin/zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use db/postgres
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
RUN_SQL_POSTGRES() {
|
||||
local _PASS _ARGS=()
|
||||
POSTGRES__SET_LOGIN_ARGS $@
|
||||
|
||||
local INPUT_FILE="$FILENAME"
|
||||
|
||||
local SQL_DIR="$SCWRYPTS_DATA_PATH/sql"
|
||||
[ ! -d $SQL_DIR ] && mkdir -p $SQL_DIR
|
||||
|
||||
cd $SQL_DIR
|
||||
|
||||
[[ $(ls "*.sql" 2>&1 | wc -l) -eq 0 ]] && {
|
||||
ERROR "you haven't made any SQL commands yet"
|
||||
REMINDER "add '.sql' files here: '$SQL_DIR/'"
|
||||
return 1
|
||||
}
|
||||
|
||||
[ ! $INPUT_FILE ] && INPUT_FILE=$(FZF 'select a sql file to run')
|
||||
[ ! $INPUT_FILE ] && ABORT
|
||||
|
||||
[ ! -f "$INPUT_FILE" ] && FAIL 2 "no such sql file '$SQL_DIR/$INPUT_FILE'"
|
||||
|
||||
STATUS "loading '$INPUT_FILE' preview..."
|
||||
LESS "$INPUT_FILE"
|
||||
|
||||
STATUS "login : $_USER@$_HOST:$_PORT/$_NAME"
|
||||
STATUS "command : '$INPUT_FILE'"
|
||||
|
||||
yN 'run this command?' || ABORT
|
||||
|
||||
STATUS "running '$INPUT_FILE'"
|
||||
|
||||
PSQL < $INPUT_FILE \
|
||||
&& SUCCESS "finished running '$INPUT_FILE'" \
|
||||
|| FAIL 3 "something went wrong running '$INPUT_FILE' (see above)"
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
WARNING
|
||||
WARNING 'this function is in a beta state'
|
||||
WARNING
|
||||
RUN_SQL_POSTGRES $@
|
@ -1,4 +0,0 @@
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
@ -1,72 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=(
|
||||
psql
|
||||
)
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
|
||||
_RUN_SQL_POSTGRES() {
|
||||
local _HOST _NAME _PASS _PORT _USER INPUT_FILE
|
||||
|
||||
while [[ $# -gt 0 ]]
|
||||
do
|
||||
case $1 in
|
||||
--host | -h ) _HOST="$2"; shift 2 ;;
|
||||
--name | -d ) _NAME="$2"; shift 2 ;;
|
||||
--pass | -w ) _PASS="$2"; shift 2 ;;
|
||||
--port | -p ) _PORT="$2"; shift 2 ;;
|
||||
--user | -U ) _USER="$2"; shift 2 ;;
|
||||
--file | -i ) INPUT_FILE="$2"; shift 2 ;;
|
||||
* ) shift 1 ;;
|
||||
esac
|
||||
done
|
||||
|
||||
[ ! $_HOST ] && _HOST=127.0.0.1
|
||||
[ ! $_NAME ] && _NAME=postgres
|
||||
[ ! $_PORT ] && _PORT=5432
|
||||
[ ! $_USER ] && _USER=postgres
|
||||
|
||||
local SQL_DIR="$SCWRYPTS_DATA_PATH/sql"
|
||||
[ ! -d $SQL_DIR ] && mkdir -p $SQL_DIR
|
||||
cd $SQL_DIR
|
||||
|
||||
[[ $(ls "*.sql" 2>&1 | wc -l) -eq 0 ]] && {
|
||||
__ERROR "you haven't made any SQL commands yet"
|
||||
__REMINDER "add '.sql' files here: '$SQL_DIR/'"
|
||||
exit 1
|
||||
}
|
||||
|
||||
[ ! $INPUT_FILE ] && INPUT_FILE=$(\
|
||||
__FZF 'select a sql file to run'
|
||||
)
|
||||
[ ! $INPUT_FILE ] && __ABORT
|
||||
|
||||
[ ! -f $INPUT_FILE ] && {
|
||||
__FAIL 2 "no such sql file '$SQL_DIR/$INPUT_FILE'"
|
||||
}
|
||||
|
||||
__STATUS "loading $INPUT_FILE preview..."
|
||||
_LESS $INPUT_FILE
|
||||
|
||||
__STATUS "login : $_USER@$_HOST:$_PORT/$_NAME"
|
||||
__STATUS "command : ./$INPUT_FILE"
|
||||
|
||||
__yN 'run this command?' || __ABORT
|
||||
|
||||
__STATUS "running './$INPUT_FILE'"
|
||||
PGPASSWORD="$_PASS" psql \
|
||||
-h $_HOST \
|
||||
-p $_PORT \
|
||||
-U $_USER \
|
||||
-d $_NAME \
|
||||
< $INPUT_FILE \
|
||||
&& __SUCCESS "finished running './$INPUT_FILE'" \
|
||||
|| __FAIL 3 "something went wrong running './$INPUT_FILE' (see above)"
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
__WARNING
|
||||
__WARNING 'this function is in a beta state'
|
||||
__WARNING
|
||||
_RUN_SQL_POSTGRES $@
|
19
zsh/docker/cleanup
Executable file
19
zsh/docker/cleanup
Executable file
@ -0,0 +1,19 @@
|
||||
#!/bin/zsh
|
||||
DEPENDENCIES+=(docker)
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
DOCKER_CLEAN() {
|
||||
WARNING 'this will prune all docker resources from the current machine'
|
||||
WARNING 'pruned resources are PERMANENTLY DELETED'
|
||||
yN 'continue?' || return 1
|
||||
|
||||
SUCCESS "CONTAINER : $(docker container prune -f 2>/dev/null | tail -n 1)"
|
||||
SUCCESS "IMAGE : $(docker image prune -f 2>/dev/null | tail -n 1)"
|
||||
SUCCESS "VOLUME : $(docker volume prune -f 2>/dev/null | tail -n 1)"
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
DOCKER_CLEAN $@
|
@ -1,6 +0,0 @@
|
||||
_DEPENDENCIES+=(
|
||||
git
|
||||
)
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
@ -1,6 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
__RUN_SCWRYPT zsh/git/package/install -- --only-build $@
|
@ -1,6 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
__RUN_SCWRYPT zsh/git/package/install -- --only-pull $@
|
@ -1,6 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
__RUN_SCWRYPT zsh/git/package/install -- --update $@
|
@ -1,7 +1,8 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
__SUCCESS 'hello world!'
|
||||
SUCCESS 'hello world!'
|
||||
|
@ -1,14 +0,0 @@
|
||||
_DEPENDENCIES+=(
|
||||
i3
|
||||
i3-msg
|
||||
)
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
||||
|
||||
[ ! $DISPLAY ] && export DISPLAY=:0
|
||||
|
||||
_NOTIFY() {
|
||||
__CHECK_DEPENDENCY notify-send || return 0
|
||||
notify-send "SCWRYPTS $SCWRYPT_NAME" $@
|
||||
}
|
@ -1,31 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=(
|
||||
pdflatex
|
||||
rg
|
||||
)
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
|
||||
PDFLATEX() {
|
||||
[ ! $1 ] && __FAIL 1 'must provide filename'
|
||||
local FILENAME=$(GET_MAIN_LATEX_FILENAME "$1")
|
||||
|
||||
local ARGS=(-interaction=nonstopmode)
|
||||
ARGS+=("$FILENAME")
|
||||
|
||||
cd "$(dirname $FILENAME)"
|
||||
|
||||
__STATUS 'running compile (1/2)'
|
||||
pdflatex ${ARGS[@]} \
|
||||
|| __FAIL 2 'first compile failed (see above)'
|
||||
|
||||
__STATUS 'running compile (2/2)'
|
||||
pdflatex ${ARGS[@]} >/dev/null 2>&1 \
|
||||
|| __FAIL 3 'second compile failed :c'
|
||||
|
||||
__SUCCESS "created '$(echo $FILENAME | sed 's/\.[^.]*$/.pdf/')'"
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
PDFLATEX $@
|
@ -1,34 +0,0 @@
|
||||
_DEPENDENCIES+=(
|
||||
rg
|
||||
)
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
||||
|
||||
GET_MAIN_LATEX_FILENAME() {
|
||||
local FILENAME=$(__GET_PATH_TO_RELATIVE_ARGUMENT "$1")
|
||||
local DIRNAME="$FILENAME"
|
||||
|
||||
for _ in {1..3}
|
||||
do
|
||||
CHECK_IS_MAIN_LATEX_FILE && return 0
|
||||
DIRNAME="$(dirname "$FILENAME")"
|
||||
__STATUS "checking '$DIRNAME'"
|
||||
[[ $DIRNAME =~ ^$HOME$ ]] && break
|
||||
FILENAME=$(
|
||||
rg -l --max-depth 1 'documentclass' "$DIRNAME/" \
|
||||
| grep '\.tex$' \
|
||||
| head -n1 \
|
||||
)
|
||||
__STATUS "here is '$FILENAME'"
|
||||
done
|
||||
|
||||
__WARNING 'unable to find documentclass; pdflatex will probably fail'
|
||||
echo "$1"
|
||||
}
|
||||
|
||||
CHECK_IS_MAIN_LATEX_FILE() {
|
||||
[ ! $FILENAME ] && return 1
|
||||
grep -q 'documentclass' $FILENAME 2>/dev/null && echo $FILENAME || return 3
|
||||
}
|
||||
|
@ -1,15 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
|
||||
GET_PDF() {
|
||||
local FILENAME=$(GET_MAIN_LATEX_FILENAME "$1" | sed 's/\.[^.]*$/.pdf/')
|
||||
[ $FILENAME ] && [ -f $FILENAME ] || __FAIL 1 "no compiled pdf found for '$1'; have you run 'build-pdf'?"
|
||||
__SUCCESS 'found main pdf'
|
||||
echo $FILENAME
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
GET_PDF $@
|
21
zsh/lib/cloud/aws/cli.module.zsh
Normal file
21
zsh/lib/cloud/aws/cli.module.zsh
Normal file
@ -0,0 +1,21 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=(
|
||||
aws
|
||||
)
|
||||
|
||||
REQUIRED_ENV+=(
|
||||
AWS_ACCOUNT
|
||||
AWS_PROFILE
|
||||
AWS_REGION
|
||||
)
|
||||
|
||||
#####################################################################
|
||||
|
||||
AWS() {
|
||||
aws \
|
||||
--profile $AWS_PROFILE \
|
||||
--region $AWS_REGION \
|
||||
--output json \
|
||||
$@
|
||||
}
|
28
zsh/lib/cloud/aws/ecr.module.zsh
Normal file
28
zsh/lib/cloud/aws/ecr.module.zsh
Normal file
@ -0,0 +1,28 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=(
|
||||
docker
|
||||
)
|
||||
|
||||
REQUIRED_ENV+=(
|
||||
AWS_ACCOUNT
|
||||
AWS_REGION
|
||||
)
|
||||
|
||||
use cloud/aws/cli
|
||||
|
||||
#####################################################################
|
||||
|
||||
ECR_LOGIN() {
|
||||
STATUS "performing AWS ECR docker login"
|
||||
AWS ecr get-login-password \
|
||||
| docker login \
|
||||
--username AWS \
|
||||
--password-stdin \
|
||||
"$AWS_ACCOUNT.dkr.ecr.$AWS_REGION.amazonaws.com" \
|
||||
&& SUCCESS "authenticated docker for '$AWS_ACCOUNT' in '$AWS_REGION'" \
|
||||
|| {
|
||||
ERROR "unable to authenticate docker for '$AWS_ACCOUNT' in '$AWS_REGION'"
|
||||
return 1
|
||||
}
|
||||
}
|
60
zsh/lib/cloud/aws/eks.module.zsh
Normal file
60
zsh/lib/cloud/aws/eks.module.zsh
Normal file
@ -0,0 +1,60 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=(
|
||||
kubectl
|
||||
)
|
||||
|
||||
REQUIRED_ENV+=(
|
||||
AWS_ACCOUNT
|
||||
AWS_REGION
|
||||
)
|
||||
|
||||
use cloud/aws/cli
|
||||
|
||||
#####################################################################
|
||||
|
||||
EKS_CLUSTER_LOGIN() {
|
||||
local USAGE="
|
||||
usage: [...options...]
|
||||
|
||||
options
|
||||
-c, --cluster-name <string> (optional) login a specific cluster
|
||||
|
||||
|
||||
Interactively sets the default kubeconfig to match the selected
|
||||
cluster in EKS. Also creates the kubeconfig entry if it does not
|
||||
already exist.
|
||||
"
|
||||
|
||||
local CLUSTER_NAME
|
||||
|
||||
while [[ $# -gt 0 ]]
|
||||
do
|
||||
case $1 in
|
||||
-c | --cluster-name ) CLUSTER_NAME="$2"; shift 1 ;;
|
||||
|
||||
* ) [ ! $APPLICATION ] && APPLICATION="$1" \
|
||||
|| ERROR "extra positional argument '$1'"
|
||||
;;
|
||||
esac
|
||||
shift 1
|
||||
done
|
||||
|
||||
[ ! $CLUSTER_NAME ] && CLUSTER_NAME=$(\
|
||||
AWS eks list-clusters \
|
||||
| jq -r '.[] | .[]' \
|
||||
| FZF 'select a cluster'
|
||||
)
|
||||
|
||||
[ ! $CLUSTER_NAME ] && ERROR 'must select a valid cluster or use -c flag'
|
||||
|
||||
CHECK_ERRORS
|
||||
|
||||
##########################################
|
||||
|
||||
STATUS 'creating / updating kubeconfig for EKS cluster'
|
||||
STATUS "updating kubeconfig for '$CLUSTER_NAME'"
|
||||
AWS eks update-kubeconfig --name $CLUSTER_NAME \
|
||||
&& SUCCESS "kubeconfig updated with '$CLUSTER_NAME'" \
|
||||
|| ERROR "failed to update kubeconfig; do you have permissions to access '$CLUSTER_NAME'?"
|
||||
}
|
@ -1,9 +1,48 @@
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
||||
|
||||
GET_DATABASE_CREDENTIALS() {
|
||||
DEPENDENCIES+=(
|
||||
docker
|
||||
)
|
||||
|
||||
REQUIRED_ENV+=(
|
||||
AWS_ACCOUNT
|
||||
AWS_REGION
|
||||
)
|
||||
|
||||
use cloud/aws/cli
|
||||
|
||||
#####################################################################
|
||||
|
||||
RDS__SELECT_DATABASE() {
|
||||
local DATABASES=$(_RDS__GET_AVAILABLE_DATABASES)
|
||||
[ ! $DATABASES ] && FAIL 1 'no databases available'
|
||||
|
||||
local ID=$(\
|
||||
echo $DATABASES | jq -r '.instance + " @ " + .cluster' \
|
||||
| FZF 'select a database (instance@cluster)' \
|
||||
)
|
||||
[ ! $ID ] && ABORT
|
||||
|
||||
local INSTANCE=$(echo $ID | sed 's/ @ .*$//')
|
||||
local CLUSTER=$(echo $ID | sed 's/^.* @ //')
|
||||
|
||||
echo $DATABASES | jq "select (.instance == \"$INSTANCE\" and .cluster == \"$CLUSTER\")"
|
||||
}
|
||||
|
||||
_RDS__GET_AVAILABLE_DATABASES() {
|
||||
AWS rds describe-db-instances \
|
||||
| jq -r '.[] | .[] | {
|
||||
instance: .DBInstanceIdentifier,
|
||||
cluster: .DBClusterIdentifier,
|
||||
type: .Engine,
|
||||
host: .Endpoint.Address,
|
||||
port: .Endpoint.Port,
|
||||
user: .MasterUsername,
|
||||
database: .DBName
|
||||
}'
|
||||
}
|
||||
|
||||
RDS__GET_DATABASE_CREDENTIALS() {
|
||||
local PRINT_PASSWORD=0
|
||||
local ERRORS=0
|
||||
|
||||
@ -12,22 +51,22 @@ GET_DATABASE_CREDENTIALS() {
|
||||
case $1 in
|
||||
--print-password ) PRINT_PASSWORD=1 ;;
|
||||
* )
|
||||
__WARNING "unrecognized argument $1"
|
||||
WARNING "unrecognized argument $1"
|
||||
ERRORS+=1
|
||||
;;
|
||||
esac
|
||||
shift 1
|
||||
done
|
||||
|
||||
__ERROR_CHECK
|
||||
CHECK_ERRORS
|
||||
|
||||
##########################################
|
||||
|
||||
local DATABASE=$(SELECT_DATABASE)
|
||||
[ ! $DATABASE ] && __ABORT
|
||||
local DATABASE=$(RDS__SELECT_DATABASE)
|
||||
[ ! $DATABASE ] && ABORT
|
||||
|
||||
DB_HOST="$(echo $DATABASE | jq -r '.host')"
|
||||
[ ! $DB_HOST ] && { __ERROR 'unable to find host'; return 2; }
|
||||
[ ! $DB_HOST ] && { ERROR 'unable to find host'; return 2; }
|
||||
|
||||
DB_PORT="$(echo $DATABASE | jq -r '.port')"
|
||||
[ ! $DB_PORT ] && DB_PORT=5432
|
||||
@ -37,37 +76,37 @@ GET_DATABASE_CREDENTIALS() {
|
||||
|
||||
local AUTH_METHOD=$(\
|
||||
echo "iam\nsecretsmanager\nuser-input" \
|
||||
| __FZF 'select an authentication method' \
|
||||
| FZF 'select an authentication method' \
|
||||
)
|
||||
[ ! $AUTH_METHOD ] && __ABORT
|
||||
[ ! $AUTH_METHOD ] && ABORT
|
||||
|
||||
case $AUTH_METHOD in
|
||||
iam ) GET_AUTH__IAM ;;
|
||||
secretsmanager ) GET_AUTH__SECRETSMANAGER ;;
|
||||
user-input ) GET_AUTH__USER_INPUT ;;
|
||||
iam ) _RDS_AUTH__iam ;;
|
||||
secretsmanager ) _RDS_AUTH__secretsmanager ;;
|
||||
user-input ) _RDS_AUTH__userinput ;;
|
||||
esac
|
||||
|
||||
__STATUS
|
||||
__STATUS "host : $DB_HOST"
|
||||
__STATUS "type : $DB_TYPE"
|
||||
__STATUS "port : $DB_PORT"
|
||||
__STATUS "database : $DB_NAME"
|
||||
__STATUS "username : $DB_USER"
|
||||
[[ $PRINT_PASSWORD -eq 1 ]] && __STATUS "password : $DB_PASS"
|
||||
__STATUS
|
||||
STATUS
|
||||
STATUS "host : $DB_HOST"
|
||||
STATUS "type : $DB_TYPE"
|
||||
STATUS "port : $DB_PORT"
|
||||
STATUS "database : $DB_NAME"
|
||||
STATUS "username : $DB_USER"
|
||||
[[ $PRINT_PASSWORD -eq 1 ]] && STATUS "password : $DB_PASS"
|
||||
STATUS
|
||||
}
|
||||
|
||||
GET_AUTH__IAM() {
|
||||
_RDS_AUTH__iam() {
|
||||
DB_PASS=$(\
|
||||
_AWS rds generate-db-auth-token \
|
||||
AWS rds generate-db-auth-token \
|
||||
--hostname $DB_HOST \
|
||||
--port $DB_PORT \
|
||||
--username $DB_USER \
|
||||
)
|
||||
}
|
||||
|
||||
GET_AUTH__SECRETSMANAGER() {
|
||||
local CREDENTIALS=$(GET_SECRETSMANAGER_CREDENTIALS)
|
||||
_RDS_AUTH__secretsmanager() {
|
||||
local CREDENTIALS=$(_RDS__GET_SECRETSMANAGER_CREDENTIALS)
|
||||
echo $CREDENTIALS | jq -e '.pass' >/dev/null 2>&1 \
|
||||
&& DB_PASS="'$(echo $CREDENTIALS | jq -r '.pass' | sed "s/'/'\"'\"'/g")'"
|
||||
|
||||
@ -87,44 +126,15 @@ GET_AUTH__SECRETSMANAGER() {
|
||||
&& DB_NAME=$(echo $CREDENTIALS | jq -r '.dbname')
|
||||
}
|
||||
|
||||
GET_SECRETSMANAGER_CREDENTIALS() {
|
||||
_RDS__GET_SECRETSMANAGER_CREDENTIALS() {
|
||||
local ID=$(\
|
||||
_AWS secretsmanager list-secrets \
|
||||
AWS secretsmanager list-secrets \
|
||||
| jq -r '.[] | .[] | .Name' \
|
||||
| __FZF 'select a secret' \
|
||||
| FZF 'select a secret' \
|
||||
)
|
||||
[ ! $ID ] && return 1
|
||||
|
||||
_AWS secretsmanager get-secret-value --secret-id "$ID" \
|
||||
AWS secretsmanager get-secret-value --secret-id "$ID" \
|
||||
| jq -r '.SecretString' | jq
|
||||
}
|
||||
|
||||
SELECT_DATABASE() {
|
||||
local DATABASES=$(GET_AVAILABLE_DATABASES)
|
||||
[ ! $DATABASES ] && __FAIL 1 'no databases available'
|
||||
|
||||
local ID=$(\
|
||||
echo $DATABASES | jq -r '.instance + " @ " + .cluster' \
|
||||
| __FZF 'select a database (instance@cluster)' \
|
||||
)
|
||||
[ ! $ID ] && __ABORT
|
||||
|
||||
local INSTANCE=$(echo $ID | sed 's/ @ .*$//')
|
||||
local CLUSTER=$(echo $ID | sed 's/^.* @ //')
|
||||
|
||||
echo $DATABASES | jq "select (.instance == \"$INSTANCE\" and .cluster == \"$CLUSTER\")"
|
||||
}
|
||||
|
||||
GET_AVAILABLE_DATABASES() {
|
||||
_AWS rds describe-db-instances \
|
||||
| jq -r '.[] | .[] | {
|
||||
instance: .DBInstanceIdentifier,
|
||||
cluster: .DBClusterIdentifier,
|
||||
type: .Engine,
|
||||
host: .Endpoint.Address,
|
||||
port: .Endpoint.Port,
|
||||
user: .MasterUsername,
|
||||
database: .DBName
|
||||
}'
|
||||
}
|
||||
|
69
zsh/lib/cloud/media-sync.module.zsh
Normal file
69
zsh/lib/cloud/media-sync.module.zsh
Normal file
@ -0,0 +1,69 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=()
|
||||
|
||||
REQUIRED_ENV+=(
|
||||
MEDIA_SYNC__TARGETS
|
||||
MEDIA_SYNC__S3_BUCKET
|
||||
)
|
||||
|
||||
use cloud/aws/cli
|
||||
|
||||
#####################################################################
|
||||
|
||||
MEDIA_SYNC__PUSH() {
|
||||
local FLAGS=($@)
|
||||
local FAILED_COUNT=0
|
||||
|
||||
STATUS 'starting media upload to s3'
|
||||
|
||||
local TARGET
|
||||
for TARGET in ${MEDIA_SYNC__TARGETS[@]}
|
||||
do
|
||||
_MEDIA_SYNC push $TARGET $FLAGS || ((FAILED_COUNT+=1))
|
||||
done
|
||||
|
||||
[[ $FAILED_COUNT -eq 0 ]] \
|
||||
&& SUCCESS 's3 media files now up-to-date' \
|
||||
|| FAIL $FAILED_COUNT 'unable to upload one or more targets' \
|
||||
;
|
||||
}
|
||||
|
||||
MEDIA_SYNC__PULL() {
|
||||
local FLAGS=($@)
|
||||
local FAILED_COUNT=0
|
||||
|
||||
STATUS 'starting media download from s3'
|
||||
|
||||
local TARGET
|
||||
for TARGET in ${MEDIA_SYNC__TARGETS[@]}
|
||||
do
|
||||
_MEDIA_SYNC pull $TARGET $FLAGS || ((FAILED_COUNT+=1))
|
||||
done
|
||||
|
||||
[[ $FAILED_COUNT -eq 0 ]] \
|
||||
&& SUCCESS 'local media files now up-to-date' \
|
||||
|| FAIL $FAILED_COUNT 'unable to download one or more targets' \
|
||||
;
|
||||
}
|
||||
|
||||
_MEDIA_SYNC() {
|
||||
local ACTION="$1"
|
||||
local REMOTE_TARGET="s3://$MEDIA_SYNC__S3_BUCKET/$2"
|
||||
local LOCAL_TARGET="$HOME/$2"
|
||||
|
||||
local A B
|
||||
case $ACTION in
|
||||
push ) A="$LOCAL_TARGET"; B="$REMOTE_TARGET" ;;
|
||||
pull ) A="$REMOTE_TARGET"; B="$LOCAL_TARGET" ;;
|
||||
|
||||
* ) ERROR "unknown action '$1'"; return 1 ;;
|
||||
esac
|
||||
|
||||
local FLAGS=(${@:3})
|
||||
|
||||
STATUS "${ACTION}ing $2"
|
||||
AWS s3 sync $A $B $FLAGS \
|
||||
&& SUCCESS "$2 up-to-date" \
|
||||
|| { ERROR "unable to sync $2 (see above)"; return 1; }
|
||||
}
|
15
zsh/lib/config.group.zsh
Normal file
15
zsh/lib/config.group.zsh
Normal file
@ -0,0 +1,15 @@
|
||||
export SCWRYPTS_ROOT__scwrypts="$SCWRYPTS_ROOT"
|
||||
export SCWRYPTS_LIBRARY_ROOT__scwrypts="$SCWRYPTS_ROOT/zsh/lib"
|
||||
export SCWRYPTS_COLOR__scwrypts='\033[0;32m'
|
||||
|
||||
export SCWRYPTS_ENV_PATH__scwrypts="$SCWRYPTS_CONFIG_PATH/scwrypts/env"
|
||||
[ ! -d "$SCWRYPTS_ENV_PATH__scwrypts" ] && mkdir -p "$SCWRYPTS_ENV_PATH__scwrypts"
|
||||
|
||||
export SCWRYPTS_ENV_TEMPLATE__scwrypts="$SCWRYPTS_ROOT__scwrypts/.env.template"
|
||||
export SCWRYPTS_ENV_TEMPLATE_DESCRIPTIONS__scwrypts="$SCWRYPTS_ROOT__scwrypts/.env.template.descriptions"
|
||||
|
||||
export SCWRYPTS_VIRTUALENV_PATH__scwrypts="$SCWRYPTS_DATA_PATH/virtualenv"
|
||||
[ ! -d "$SCWRYPTS_VIRTUALENV_PATH__scwrypts" ] && mkdir -p "$SCWRYPTS_VIRTUALENV_PATH__scwrypts"
|
||||
|
||||
export SCWRYPTS_PREFERRED_PYTHON_VERSIONS__scwrypts=(3.11 3.10 3.9)
|
||||
export SCWRYPTS_NODE_VERSION__scwrypts=18.0.0
|
BIN
zsh/lib/config.user.zsh
Normal file
BIN
zsh/lib/config.user.zsh
Normal file
Binary file not shown.
42
zsh/lib/config.zsh
Normal file
42
zsh/lib/config.zsh
Normal file
@ -0,0 +1,42 @@
|
||||
[[ $__SCWRYPT -eq 1 ]] && return 0
|
||||
#####################################################################
|
||||
|
||||
[ ! $SCWRYPTS_ROOT ] \
|
||||
&& SCWRYPTS_ROOT="$(cd $(dirname "${0:a:h}"); git rev-parse --show-toplevel)"
|
||||
|
||||
#####################################################################
|
||||
|
||||
DEFAULT_CONFIG="$SCWRYPTS_ROOT/zsh/lib/config.user.zsh"
|
||||
source "$DEFAULT_CONFIG"
|
||||
|
||||
USER_CONFIG_OVERRIDES="$SCWRYPTS_CONFIG_PATH/config.zsh"
|
||||
[ ! -f "$USER_CONFIG_OVERRIDES" ] && {
|
||||
mkdir -p $(dirname "$USER_CONFIG_OVERRIDES")
|
||||
cp "$DEFAULT_CONFIG" "$USER_CONFIG_OVERRIDES"
|
||||
}
|
||||
source "$USER_CONFIG_OVERRIDES"
|
||||
|
||||
[ ! -d $SCWRYPTS_CONFIG_PATH ] && mkdir -p $SCWRYPTS_CONFIG_PATH
|
||||
[ ! -d $SCWRYPTS_DATA_PATH ] && mkdir -p $SCWRYPTS_DATA_PATH
|
||||
[ ! -d $SCWRYPTS_ENV_PATH ] && mkdir -p $SCWRYPTS_ENV_PATH
|
||||
[ ! -d $SCWRYPTS_LOG_PATH ] && mkdir -p $SCWRYPTS_LOG_PATH
|
||||
[ ! -d $SCWRYPTS_OUTPUT_PATH ] && mkdir -p $SCWRYPTS_OUTPUT_PATH
|
||||
|
||||
export \
|
||||
SCWRYPTS_GROUPS \
|
||||
SCWRYPTS_CONFIG_PATH \
|
||||
SCWRYPTS_DATA_PATH \
|
||||
SCWRYPTS_SHORTCUT \
|
||||
SCWRYPTS_ENV_SHORTCUT \
|
||||
SCWRYPTS_LOG_PATH \
|
||||
SCWRYPTS_OUTPUT_PATH \
|
||||
;
|
||||
|
||||
SCWRYPTS_GROUPS+=(scwrypts) # 'scwrypts' group is required!
|
||||
SCWRYPTS_GROUPS=($(echo $SCWRYPTS_GROUPS | sed 's/\s\+/\n/g' | sort -u))
|
||||
|
||||
source "$SCWRYPTS_ROOT/zsh/lib/config.group.zsh" \
|
||||
|| FAIL 69 'failed to set up scwrypts group; aborting'
|
||||
|
||||
#####################################################################
|
||||
__SCWRYPT=1 # arbitrary; indicates currently inside a scwrypt
|
158
zsh/lib/db/postgres.module.zsh
Normal file
158
zsh/lib/db/postgres.module.zsh
Normal file
@ -0,0 +1,158 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=(
|
||||
pg_dump
|
||||
pg_restore
|
||||
psql
|
||||
pgcli
|
||||
)
|
||||
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
#####################################################################
|
||||
|
||||
PSQL() {
|
||||
[[ ${#ARGS[@]} -eq 0 ]] && POSTGRES__SET_LOGIN_ARGS $@
|
||||
|
||||
eval PGPASSWORD=$_PASS psql ${_ARGS[@]}
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
|
||||
PG_DUMP() {
|
||||
local _HOST _NAME _PORT _USER _FILE
|
||||
local DATA_DIR _PASS _ARGS=()
|
||||
POSTGRES__SET_LOGIN_ARGS --verbose $@
|
||||
|
||||
local OUTPUT_FILE="$DATA_DIR/backup.$(date '+%Y-%m-%d.%H-%M')"
|
||||
|
||||
STATUS "
|
||||
making backup of : $_USER@$_HOST:$_PORT/$_NAME
|
||||
|
||||
(compressed) : '$OUTPUT_FILE.dump'
|
||||
(safe-raw) : '$OUTPUT_FILE.sql'
|
||||
(raw) : '$OUTPUT_FILE.raw.sql'
|
||||
"
|
||||
|
||||
: \
|
||||
&& STATUS "creating compressed backup..." \
|
||||
&& eval PGPASSWORD=$_PASS pg_dump ${_ARGS[@]} --format custom --file "$OUTPUT_FILE.dump" \
|
||||
&& SUCCESS "completed compressed backup" \
|
||||
&& STATUS "creating raw backup..." \
|
||||
&& eval PGPASSWORD=$_PASS pg_dump ${_ARGS[@]} > "$OUTPUT_FILE.raw.sql" \
|
||||
&& SUCCESS "completed raw backup" \
|
||||
&& STATUS "creating single-transaction raw backup..." \
|
||||
&& { echo "BEGIN;"; cat "$OUTPUT_FILE.raw.sql"; echo "END;" } > "$OUTPUT_FILE.sql" \
|
||||
&& SUCCESS "completed single-transaction raw backup" \
|
||||
|| { ERROR "error creating backup for '$_HOST/$_NAME' (see above)"; return 1; }
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
|
||||
PG_RESTORE() {
|
||||
local _HOST _NAME _PORT _USER
|
||||
local _PASS _ARGS=()
|
||||
local _FILE
|
||||
POSTGRES__SET_LOGIN_ARGS $@
|
||||
|
||||
local INPUT_FILE=$(find "$DATA_DIR"/backup.* -type f | FZF 'select database file to restore')
|
||||
|
||||
[ $INPUT_FILE ] && [ -f "$INPUT_FILE" ] || {
|
||||
ERROR 'no file selected or missing backup file; aborting'
|
||||
REMINDER "
|
||||
backups must be *.sql or *.dump files starting with the prefix 'backup.'
|
||||
in the following directory:
|
||||
|
||||
'$DATA_DIR'
|
||||
"
|
||||
return 1
|
||||
}
|
||||
|
||||
local RAW=1
|
||||
[[ $INPUT_FILE =~ \\.dump$ ]] && RAW=0
|
||||
|
||||
STATUS "
|
||||
loading backup for : $_USER@$_HOST:$_PORT/$_NAME
|
||||
|
||||
file : '$INPUT_FILE'
|
||||
"
|
||||
|
||||
local EXIT_CODE
|
||||
[[ $RAW -eq 1 ]] && {
|
||||
REMINDER "
|
||||
loading a backup from a raw sql dump may result in data loss
|
||||
|
||||
make sure your database is ready to accept the database file!
|
||||
"
|
||||
|
||||
yN 'continue?' || ABORT
|
||||
|
||||
PSQL < "$INPUT_FILE"
|
||||
EXIT_CODE=$?
|
||||
}
|
||||
|
||||
[[ $RAW -eq 0 ]] && {
|
||||
PGPASSWORD="$_PASS" pg_restore ${_ARGS[@]} \
|
||||
--verbose \
|
||||
--format custom \
|
||||
--single-transaction \
|
||||
"$INPUT_FILE"
|
||||
EXIT_CODE=$?
|
||||
}
|
||||
|
||||
[[ $EXIT_CODE -eq 0 ]] \
|
||||
&& SUCCESS "finished restoring backup for '$_HOST/$_NAME'" \
|
||||
|| ERROR "error restoring backup for '$_HOST/$_NAME' (see above)" \
|
||||
;
|
||||
|
||||
return $EXIT_CODE
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
|
||||
POSTGRES__LOGIN_INTERACTIVE() {
|
||||
local _PASS _ARGS=()
|
||||
POSTGRES__SET_LOGIN_ARGS $@
|
||||
|
||||
STATUS "performing login : $_USER@$_HOST:$_PORT/$_NAME"
|
||||
STATUS "working directory : $DATA_DIR"
|
||||
|
||||
eval PGPASSWORD=$_PASS pgcli ${_ARGS[@]}
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
|
||||
POSTGRES__SET_LOGIN_ARGS() {
|
||||
while [[ $# -gt 0 ]]
|
||||
do
|
||||
case $1 in
|
||||
--host ) _ARGS+=(-h $2); _HOST="$2"; shift 1 ;;
|
||||
--name ) _ARGS+=(-d $2); _NAME="$2"; shift 1 ;;
|
||||
--port ) _ARGS+=(-p $2); _PORT="$2"; shift 1 ;;
|
||||
--user ) _ARGS+=(-U $2); _USER="$2"; shift 1 ;;
|
||||
|
||||
--pass ) _PASS="$2"; shift 1 ;;
|
||||
|
||||
--file ) _FILE="$2"; shift 1 ;;
|
||||
|
||||
* ) _ARGS+=($1) ;;
|
||||
esac
|
||||
shift 1
|
||||
done
|
||||
|
||||
[ $_FILE ] && [ ! -f "$_FILE" ] && {
|
||||
ERROR "no such file '$_FILE'"
|
||||
exit 1
|
||||
}
|
||||
|
||||
[ $_HOST ] && [ $_NAME ] \
|
||||
&& DATA_DIR="$SCWRYPTS_DATA_PATH/db/$_HOST/$_NAME" \
|
||||
|| DATA_DIR="$EXECUTION_DIR/temp-db" \
|
||||
;
|
||||
|
||||
[ ! -d "$DATA_DIR" ] && mkdir -p "$DATA_DIR"
|
||||
cd "$DATA_DIR"
|
||||
|
||||
return 0
|
||||
}
|
||||
|
147
zsh/lib/import.driver.zsh
Normal file
147
zsh/lib/import.driver.zsh
Normal file
@ -0,0 +1,147 @@
|
||||
[[ $SCWRYPTS_IMPORT_DRIVER_READY -eq 1 ]] && return 0
|
||||
###################################################################
|
||||
# #
|
||||
# usage: use [OPTIONS ...] zsh/module/path #
|
||||
# #
|
||||
###################################################################
|
||||
# #
|
||||
# OPTIONS: #
|
||||
# #
|
||||
# -g, --group lookup library root from friendly group #
|
||||
# name (requires configuration) #
|
||||
# (default: scwrypts) #
|
||||
# #
|
||||
# -r, --library-root fully qualified path to a library root #
|
||||
# #
|
||||
# --check-environment check environment immediately rather than #
|
||||
# wait for downstream CHECK_ENVIRONMENT call #
|
||||
# #
|
||||
# #
|
||||
# Allows for import-style library loading in zsh. No matter what #
|
||||
# scwrypt is run, this function (and required helpers) are *also* #
|
||||
# loaded, ensuring that 'use' is always available in scwrypts #
|
||||
# context. #
|
||||
# #
|
||||
# #
|
||||
# Friendly group-names can be configured by setting the variable #
|
||||
# 'SCWRYPTS_LIBRARY_ROOT__<group-name>' to the fully qualified path #
|
||||
# to the root directory of the modules library. #
|
||||
# #
|
||||
# #
|
||||
###################################################################
|
||||
|
||||
source "${0:a:h}/config.zsh"
|
||||
|
||||
use() {
|
||||
local SCWRYPTS_LIBRARY SCWRYPTS_LIBRARY_ROOT SCWRYPTS_LIBRARY_GROUP
|
||||
local DEFER_ENVIRONMENT_CHECK=1
|
||||
|
||||
while [[ $# -gt 0 ]]
|
||||
do
|
||||
case $1 in
|
||||
-g | --group )
|
||||
[ $SCWRYPTS_LIBRARY_ROOT ] && ERROR 'specify only one of {(-g), (-r)}'
|
||||
SCWRYPTS_LIBRARY_GROUP=$2
|
||||
shift 1
|
||||
;;
|
||||
-r | --library-root )
|
||||
[ $SCWRYPTS_LIBRARY_GROUP ] && ERROR 'specify only one of {(-g), (-r)}'
|
||||
SCWRYPTS_LIBRARY_ROOT=$2
|
||||
shift 1
|
||||
;;
|
||||
--check-environment )
|
||||
DEFER_ENVIRONMENT_CHECK=0
|
||||
;;
|
||||
* )
|
||||
[ ! $SCWRYPTS_LIBRARY ] \
|
||||
&& SCWRYPTS_LIBRARY=$1 \
|
||||
|| ERROR 'too many arguments; expected exactly 1 argument' \
|
||||
|
||||
;;
|
||||
esac
|
||||
shift 1
|
||||
done
|
||||
|
||||
[ ! $SCWRYPTS_LIBRARY ] && ERROR 'no library specified for import'
|
||||
|
||||
: \
|
||||
&& [ ! $SCWRYPTS_LIBRARY_GROUP ] \
|
||||
&& [ ! $SCWRYPTS_LIBRARY_ROOT ] \
|
||||
&& SCWRYPTS_LIBRARY_GROUP=scwrypts
|
||||
|
||||
[ ! $SCWRYPTS_LIBRARY_ROOT ] && SCWRYPTS_LIBRARY_ROOT=$(GET_SCWRYPTS_LIBRARY_ROOT)
|
||||
[ ! $SCWRYPTS_LIBRARY_ROOT ] && ERROR "unable to determine library root from group name '$SCWRYPTS_LIBRARY_GROUP'"
|
||||
|
||||
#####################################################################
|
||||
|
||||
local LIBRARY_FILE LIBRARY_FILE_TEMP
|
||||
|
||||
[ ! $LIBRARY_FILE ] \
|
||||
&& LIBRARY_FILE_TEMP="$SCWRYPTS_LIBRARY_ROOT/$SCWRYPTS_LIBRARY.module.zsh" \
|
||||
&& [ -f "$LIBRARY_FILE_TEMP" ] \
|
||||
&& LIBRARY_FILE="$LIBRARY_FILE_TEMP"
|
||||
|
||||
[ ! $LIBRARY_FILE ] \
|
||||
&& LIBRARY_FILE_TEMP="$SCWRYPTS_LIBRARY_ROOT/$SCWRYPTS_LIBRARY/$(echo $SCWRYPTS_LIBRARY | sed 's/.*\///').module.zsh" \
|
||||
&& [ -f "$LIBRARY_FILE_TEMP" ] \
|
||||
&& LIBRARY_FILE="$LIBRARY_FILE_TEMP" \
|
||||
|
||||
[ ! $LIBRARY_FILE ] \
|
||||
&& ERROR "no such library '$SCWRYPTS_LIBRARY_GROUP/$SCWRYPTS_LIBRARY'"
|
||||
|
||||
#####################################################################
|
||||
|
||||
CHECK_ERRORS --no-fail || {
|
||||
((IMPORT_ERRORS+=1))
|
||||
return 1
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
|
||||
IS_LOADED && return 0
|
||||
|
||||
source "$LIBRARY_FILE" || {
|
||||
((IMPORT_ERRORS+=1))
|
||||
ERROR "import error for '$SCWRYPTS_LIBRARY_GROUP/$SCWRYPTS_LIBRARY'"
|
||||
return 1
|
||||
}
|
||||
|
||||
[[ $DEFER_ENVIRONMENT_CHECK -eq 0 ]] && {
|
||||
CHECK_ENVIRONMENT || {
|
||||
((IMPORT_ERRORS+=1))
|
||||
ERROR "import error for '$SCWRYPTS_LIBRARY_GROUP/$SCWRYPTS_LIBRARY'"
|
||||
return 1
|
||||
}
|
||||
}
|
||||
|
||||
IS_LOADED --set
|
||||
}
|
||||
|
||||
GET_SCWRYPTS_LIBRARY_ROOT() {
|
||||
eval echo '$SCWRYPTS_LIBRARY_ROOT__'$SCWRYPTS_LIBRARY_GROUP
|
||||
}
|
||||
|
||||
IS_LOADED() {
|
||||
local VARIABLE_NAME="SCWRYPTS_LIBRARY_LOADED__${SCWRYPTS_LIBRARY_GROUP}__$(echo $SCWRYPTS_LIBRARY | sed 's|[/-]|_|g')"
|
||||
|
||||
[[ $1 =~ ^--set$ ]] \
|
||||
&& eval $VARIABLE_NAME=1 \
|
||||
|
||||
[[ $(eval echo '$'$VARIABLE_NAME || echo 0) -eq 1 ]]
|
||||
}
|
||||
|
||||
|
||||
# temporary definitions for first load
|
||||
CHECK_ERRORS() { return 0; unset -f CHECK_ERRORS; }
|
||||
CHECK_ENVIRONMENT() { return 0; unset -f CHECK_ENVIRONMENT; }
|
||||
ERROR() { echo $@ >&2; exit 1; }
|
||||
|
||||
#####################################################################
|
||||
|
||||
# ensures that zsh/utils and zsh/scwrypts/meta are always present!
|
||||
|
||||
use utils
|
||||
use scwrypts/meta
|
||||
|
||||
#####################################################################
|
||||
SCWRYPTS_IMPORT_DRIVER_READY=1
|
@ -1,9 +1,12 @@
|
||||
_DEPENDENCIES+=(
|
||||
youtube-dl
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=(
|
||||
ffmpeg
|
||||
youtube-dl
|
||||
)
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
#####################################################################
|
||||
|
||||
YT__GLOBAL_ARGS=(
|
26
zsh/lib/misc/k8s-helper.plugin.zsh
Normal file
26
zsh/lib/misc/k8s-helper.plugin.zsh
Normal file
@ -0,0 +1,26 @@
|
||||
K8s_HELPER__NAMESPACE_KEY='k8s-helper'
|
||||
K8s_HELPER__REDIS_HOST=127.0.0.1
|
||||
K8s_HELPER__REDIS_PORT=6379
|
||||
K8s_HELPER__REDIS_AUTH=
|
||||
|
||||
REDIS_CLI() {
|
||||
local ARGS=()
|
||||
[ $K8s_HELPER__REDIS_HOST ] && ARGS+=(-h $K8s_HELPER__REDIS_HOST)
|
||||
[ $K8s_HELPER__REDIS_PORT ] && ARGS+=(-p $K8s_HELPER__REDIS_PORT)
|
||||
[ $K8s_HELPER__REDIS_AUTH ] && ARGS+=(-a $K8s_HELPER__REDIS_AUTH --no-auth-warning)
|
||||
redis-cli ${ARGS[@|} $@
|
||||
}
|
||||
|
||||
K8s_HELPER__SET_NAMESPACE() {
|
||||
REDIS_CLI hset $K8s_HELPER__NAMESPACE_KEY namespace $@
|
||||
}
|
||||
|
||||
K8s_HELPER__GET_NAMESPACE() {
|
||||
REDIS_CLI hget $K8s_HELPER__NAMESPACE_KEY namespace
|
||||
}
|
||||
|
||||
K8s_HELPER__KUBECTL() {
|
||||
kubectl -n $(K8s_HELPER__GET_NAMESPACE) $@
|
||||
}
|
||||
|
||||
alias k='K8s_HELPER__PREFIX '
|
44
zsh/lib/office/latex.module.zsh
Normal file
44
zsh/lib/office/latex.module.zsh
Normal file
@ -0,0 +1,44 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=(
|
||||
rg
|
||||
pdflatex
|
||||
)
|
||||
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
#####################################################################
|
||||
|
||||
LATEX__GET_MAIN_FILENAME() {
|
||||
local FILENAME=$(SCWRYPTS__GET_PATH_TO_RELATIVE_ARGUMENT "$1")
|
||||
local DIRNAME="$FILENAME"
|
||||
|
||||
for _ in {1..3}
|
||||
do
|
||||
CHECK_IS_MAIN_LATEX_FILE && return 0
|
||||
DIRNAME="$(dirname "$FILENAME")"
|
||||
STATUS "checking '$DIRNAME'"
|
||||
[[ $DIRNAME =~ ^$HOME$ ]] && break
|
||||
FILENAME=$(
|
||||
rg -l --max-depth 1 'documentclass' "$DIRNAME/" \
|
||||
| grep '\.tex$' \
|
||||
| head -n1 \
|
||||
)
|
||||
STATUS "here is '$FILENAME'"
|
||||
done
|
||||
|
||||
WARNING 'unable to find documentclass; pdflatex will probably fail'
|
||||
echo "$1"
|
||||
}
|
||||
|
||||
LATEX__CHECK_IS_MAIN_FILE() {
|
||||
[ ! $FILENAME ] && return 1
|
||||
grep -q 'documentclass' $FILENAME 2>/dev/null && echo $FILENAME || return 3
|
||||
}
|
||||
|
||||
LATEX__GET_PDF() {
|
||||
local FILENAME=$(LATEX__GET_MAIN_FILENAME "$1" | sed 's/\.[^.]*$/.pdf/')
|
||||
[ $FILENAME ] && [ -f $FILENAME ] || FAIL 1 "no compiled pdf found for '$1'; have you run 'build-pdf'?"
|
||||
SUCCESS 'found main pdf'
|
||||
echo $FILENAME
|
||||
}
|
15
zsh/lib/office/memo.module.zsh
Normal file
15
zsh/lib/office/memo.module.zsh
Normal file
@ -0,0 +1,15 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
#####################################################################
|
||||
|
||||
set +o noglob
|
||||
|
||||
MEMO__FILETYPE=md
|
||||
MEMO__DIR="$SCWRYPTS_DATA_PATH/memo"
|
||||
|
||||
[ ! -d $MEMO__DIR ] && mkdir -p $MEMO__DIR
|
||||
|
||||
MEMO__LIST_ALL() { ls $MEMO__DIR | sed "s/\.$MEMO__FILETYPE$//" | sort; }
|
43
zsh/lib/redis/redis.module.zsh
Normal file
43
zsh/lib/redis/redis.module.zsh
Normal file
@ -0,0 +1,43 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=(
|
||||
redis-cli
|
||||
)
|
||||
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
#####################################################################
|
||||
|
||||
REDIS() {
|
||||
[[ ${#ARGS[@]} -eq 0 ]] && REDIS__SET_LOGIN_ARGS $@
|
||||
|
||||
redis-cli ${#ARGS[@]}
|
||||
}
|
||||
|
||||
|
||||
REDIS__SET_LOGIN_ARGS() {
|
||||
while [[ $# -gt 0 ]]
|
||||
do
|
||||
case $1 in
|
||||
--host ) _ARGS+=(-h $2); _HOST="$2"; shift 1 ;;
|
||||
--port ) _ARGS+=(-p $2); _PORT="$2"; shift 1 ;;
|
||||
--pass ) _ARGS+=(-a $2); _PASS="$2"; shift 1 ;;
|
||||
|
||||
--file ) _FILE="$2"; shift 1 ;;
|
||||
|
||||
* ) _ARGS+=($1) ;;
|
||||
esac
|
||||
shift 1
|
||||
done
|
||||
|
||||
[ $_FILE ] && [ ! -f "$_FILE" ] && {
|
||||
ERROR "no such file '$_FILE'"
|
||||
exit 1
|
||||
}
|
||||
|
||||
return 0
|
||||
}
|
||||
|
||||
REDIS__ENABLED() {
|
||||
REDIS ping 2>&1 | grep -qi pong
|
||||
}
|
94
zsh/lib/scwrypts/environment-files.module.zsh
Normal file
94
zsh/lib/scwrypts/environment-files.module.zsh
Normal file
@ -0,0 +1,94 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use utils
|
||||
|
||||
#####################################################################
|
||||
|
||||
SCWRYPTS__SELECT_ENV() {
|
||||
SCWRYPTS__GET_ENV_NAMES | FZF 'select an environment'
|
||||
}
|
||||
|
||||
SCWRYPTS__SELECT_OR_CREATE_ENV() {
|
||||
SCWRYPTS__GET_ENV_NAMES | FZF_TAIL 'select / create an environment'
|
||||
}
|
||||
|
||||
SCWRYPTS__GET_ENV_FILE() {
|
||||
local NAME="$1"
|
||||
|
||||
echo "$SCWRYPTS_ENV_PATH/$NAME"
|
||||
|
||||
SCWRYPTS__GET_ENV_NAMES | grep -q $NAME \
|
||||
|| { ERROR "no environment '$NAME' exists"; return 1; }
|
||||
}
|
||||
|
||||
SCWRYPTS__GET_ENV_TEMPLATE_FILES() {
|
||||
local GROUP
|
||||
for GROUP in ${SCWRYPTS_GROUPS[@]}
|
||||
do
|
||||
eval echo '$SCWRYPTS_ENV_TEMPLATE__'$GROUP
|
||||
done
|
||||
}
|
||||
|
||||
SCWRYPTS__GET_ENV_NAMES() {
|
||||
SCWRYPTS__INIT_ENVIRONMENTS || {
|
||||
ERROR 'environment initialization error'
|
||||
return 1
|
||||
}
|
||||
ls "$SCWRYPTS_ENV_PATH" | sort -r
|
||||
}
|
||||
|
||||
SCWRYPTS__INIT_ENVIRONMENTS() {
|
||||
[ ! -d "$SCWRYPTS_ENV_PATH" ] && mkdir -p "$SCWRYPTS_ENV_PATH"
|
||||
[[ $(ls "$SCWRYPTS_ENV_PATH" | wc -l) -gt 0 ]] && return 0
|
||||
|
||||
STATUS "initializing environments for scwrypts"
|
||||
|
||||
local BASIC_ENV
|
||||
for BASIC_ENV in local dev prod
|
||||
do
|
||||
GENERATE_TEMPLATE > "$SCWRYPTS_ENV_PATH/$BASIC_ENV"
|
||||
done
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
|
||||
_SED() { sed --follow-symlinks $@; }
|
||||
|
||||
GENERATE_TEMPLATE() {
|
||||
echo "#!/bin/zsh"
|
||||
echo '#####################################################################'
|
||||
echo "### scwrypts runtime configuration ##################################"
|
||||
echo '#####################################################################'
|
||||
local FILE GROUP CONTENT
|
||||
local VARIABLE DESCRIPTION
|
||||
for GROUP in ${SCWRYPTS_GROUPS[@]}
|
||||
do
|
||||
FILE=$(eval echo '$SCWRYPTS_ENV_TEMPLATE__'$GROUP)
|
||||
|
||||
CONTENT=$(GET_VARIABLE_NAMES "$FILE" | sed 's/^/export /; s/$/=/')
|
||||
|
||||
while read DESCRIPTION_LINE
|
||||
do
|
||||
VARIABLE=$(echo $DESCRIPTION_LINE | sed 's/ \+| .*$//')
|
||||
DESCRIPTION=$(echo $DESCRIPTION_LINE | sed 's/^.* | //')
|
||||
[ ! $DESCRIPTION ] && continue
|
||||
|
||||
CONTENT=$(echo "$CONTENT" | sed "/^export $VARIABLE=/i #" | sed "/^export $VARIABLE=/i # $DESCRIPTION")
|
||||
done < <(_SED -n '/^[^ ]\+ \+| /p' "$FILE.descriptions")
|
||||
|
||||
echo "$CONTENT" | sed 's/^#$//'
|
||||
echo '\n#####################################################################'
|
||||
done
|
||||
}
|
||||
|
||||
GET_VARIABLE_NAMES() {
|
||||
local FILE="$1"
|
||||
grep '^export' "$FILE" \
|
||||
| sed 's/^export //; s/=.*//' \
|
||||
| grep -v '__[a-z]\+$' \
|
||||
;
|
||||
}
|
||||
|
22
zsh/lib/scwrypts/meta.module.zsh
Normal file
22
zsh/lib/scwrypts/meta.module.zsh
Normal file
@ -0,0 +1,22 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use scwrypts/environment-files
|
||||
use scwrypts/run
|
||||
|
||||
#####################################################################
|
||||
|
||||
SCWRYPTS__RUN() {
|
||||
local EXIT_CODE=0
|
||||
((SUBSCWRYPT+=1))
|
||||
|
||||
echo "--- START SUBSCWRYPT=$SUBSCWRYPT $@"
|
||||
SUBSCWRYPT=$SUBSCWRYPT $SCWRYPTS_ROOT/run $@
|
||||
EXIT_CODE=$?
|
||||
|
||||
((SUBSCWRYPT-=1))
|
||||
return $EXIT_CODE
|
||||
echo "--- END SUBSCWRYPT=$SUBSCWRYPT $@"
|
||||
}
|
120
zsh/lib/scwrypts/run.module.zsh
Normal file
120
zsh/lib/scwrypts/run.module.zsh
Normal file
@ -0,0 +1,120 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use scwrypts/environment-files
|
||||
|
||||
#####################################################################
|
||||
|
||||
SCWRYPTS__GET_AVAILABLE_SCWRYPTS() {
|
||||
local TYPE_COLOR='\033[0;37m'
|
||||
local GROUP GROUP_PATH GROUP_COLOR LOOKUP_PIDS=()
|
||||
{
|
||||
echo 'NAME^TYPE^GROUP'
|
||||
for GROUP in ${SCWRYPTS_GROUPS}
|
||||
do
|
||||
GROUP_PATH=$(eval echo '$SCWRYPTS_ROOT__'$GROUP)
|
||||
GROUP_COLOR=$(eval echo '$SCWRYPTS_COLOR__'$GROUP)
|
||||
{
|
||||
cd "$GROUP_PATH"
|
||||
find . -mindepth 2 -type f -executable \
|
||||
| grep -v '\.git' \
|
||||
| grep -v 'node_modules' \
|
||||
| sed "s/^\\.\\///; s/\\.[^.]*$//" \
|
||||
| sed "s|\\([^/]*\\)/\(.*\)$|$(printf $__COLOR_RESET)\\2^$(printf $TYPE_COLOR)\\1^$(printf $GROUP_COLOR)$GROUP$(printf $__COLOR_RESET)|" \
|
||||
;
|
||||
} &
|
||||
LOOKUP_PIDS+=($!)
|
||||
done
|
||||
for p in ${LOOKUP_PIDS[@]}; do wait $p; done
|
||||
} | column -t -s '^'
|
||||
}
|
||||
|
||||
SCWRYPTS__SEPARATE_SCWRYPT_SELECTION() {
|
||||
set -- $(echo $@ | sed -e 's/\x1b\[[0-9;]*m//g')
|
||||
while [[ $# -gt 0 ]]
|
||||
do
|
||||
[ ! $NAME ] && NAME=$1 && shift 1 && continue
|
||||
[ ! $TYPE ] && TYPE=$1 && shift 1 && continue
|
||||
[ ! $GROUP ] && GROUP=$1 && shift 1 && continue
|
||||
shift 1
|
||||
done
|
||||
}
|
||||
|
||||
SCWRYPTS__GET_RUNSTRING() {
|
||||
# accepts a selected line from SCWRYPTS__GET_AVAILABLE_SCWRYPTS
|
||||
local NAME="$1"
|
||||
local TYPE="$2"
|
||||
local GROUP="$3"
|
||||
local GROUP_PATH=$(eval echo '$SCWRYPTS_ROOT__'$GROUP)
|
||||
local RUNSTRING
|
||||
|
||||
[ $NAME ] && [ $TYPE ] && [ $GROUP ] || {
|
||||
ERROR 'missing required information to get runstring'
|
||||
return 1
|
||||
}
|
||||
[ $ENV_REQUIRED ] && [[ $ENV_REQUIRED -eq 1 ]] && [ ! $ENV_NAME ] && {
|
||||
ERROR 'missing required information to get runstring'
|
||||
return 1
|
||||
}
|
||||
|
||||
typeset -f SCWRYPTS__GET_RUNSTRING__${GROUP}__${TYPE} >/dev/null 2>&1 && {
|
||||
RUNSTRING=$(SCWRYPTS__GET_RUNSTRING__${GROUP}__${TYPE})
|
||||
[ ! $RUNSTRING ] && {
|
||||
ERROR "SCWRYPTS__GET_RUNSTRING__${GROUP}__${TYPE} error"
|
||||
return 2
|
||||
}
|
||||
}
|
||||
|
||||
typeset -f SCWRYPTS__GET_RUNSTRING__${TYPE} >/dev/null 2>&1 && {
|
||||
RUNSTRING=$(SCWRYPTS__GET_RUNSTRING__${TYPE})
|
||||
[ ! $RUNSTRING ] && {
|
||||
ERROR "SCWRYPTS__GET_RUNSTRING__${TYPE} error"
|
||||
return 3
|
||||
}
|
||||
}
|
||||
|
||||
[ ! $RUNSTRING ] && {
|
||||
ERROR "type ${TYPE} (group ${GROUP}) has no supported runstring generator"
|
||||
return 4
|
||||
}
|
||||
|
||||
RUNSTRING="SCWRYPTS_ENV=$ENV_NAME; $RUNSTRING"
|
||||
RUNSTRING="source $SCWRYPTS_ROOT/zsh/lib/import.driver.zsh; $RUNSTRING"
|
||||
|
||||
local _VIRTUALENV=$(eval echo '$SCWRYPTS_VIRTUALENV_PATH__'$GROUP'/$TYPE/bin/activate')
|
||||
[ -f $_VIRTUALENV ] && RUNSTRING="source $_VIRTUALENV; $RUNSTRING"
|
||||
|
||||
local G SCWRYPTSENV
|
||||
for G in ${SCWRYPTS__GROUPS[@]}
|
||||
do
|
||||
SCWRYPTSENV=$(eval echo '$SCWRYPTS_ENV_PATH__'$GROUP'/$ENV_NAME')
|
||||
[ -f $SCWRYPTSENV ] && RUNSTRING="source $SCWRYPTSENV; $RUNSTRING"
|
||||
done
|
||||
|
||||
echo "$RUNSTRING"
|
||||
}
|
||||
|
||||
SCWRYPTS__GET_RUNSTRING__zsh() {
|
||||
__CHECK_DEPENDENCY zsh || return 1
|
||||
|
||||
echo "source $GROUP_PATH/$TYPE/$NAME"
|
||||
}
|
||||
|
||||
SCWRYPTS__GET_RUNSTRING__py() {
|
||||
__CHECK_DEPENDENCY python || return 1
|
||||
CURRENT_PYTHON_VERSION=$(python --version | sed 's/^[^0-9]*\(3\.[^.]*\).*$/\1/')
|
||||
echo $SCWRYPTS_PREFERRED_PYTHON_VERSIONS__scwrypts | grep -q $CURRENT_PYTHON_VERSION || {
|
||||
WARNING "only tested on the following python versions: $(printf ', %s.x' ${SCWRYPTS_PREFERRED_PYTHON_VERSIONS__scwrypts[@]} | sed 's/^, //')"
|
||||
WARNING 'compatibility may vary'
|
||||
}
|
||||
|
||||
echo "cd $GROUP_PATH; python -m $(echo $TYPE/$NAME | sed 's/\//./g; s/\.py$//; s/\.\.//')"
|
||||
}
|
||||
|
||||
SCWRYPTS__GET_RUNSTRING__zx() {
|
||||
__CHECK_DEPENDENCY zx || return 1
|
||||
|
||||
echo "FORCE_COLOR=3; cd $GROUP_PATH; ./$TYPE/$NAME.js"
|
||||
}
|
127
zsh/lib/scwrypts/virtualenv.module.zsh
Normal file
127
zsh/lib/scwrypts/virtualenv.module.zsh
Normal file
@ -0,0 +1,127 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=(
|
||||
virtualenv
|
||||
nodeenv
|
||||
)
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use utils
|
||||
|
||||
#####################################################################
|
||||
|
||||
AVAILABLE_VIRTUALENVS=(py zx)
|
||||
|
||||
REFRESH_VIRTUALENV() {
|
||||
local GROUP="$1"
|
||||
local TYPE="$2"
|
||||
[ ! $TYPE ] && {
|
||||
ERROR 'no virtualenv type specified'
|
||||
return 1
|
||||
}
|
||||
STATUS "refreshing $GROUP/$TYPE virtual environment"
|
||||
DELETE_VIRTUALENV $GROUP $TYPE \
|
||||
&& UPDATE_VIRTUALENV $GROUP $TYPE \
|
||||
&& SUCCESS 'successfully refreshed virtual environment' \
|
||||
|| { ERROR 'something went wrong during refresh (see above)'; return 1; } \
|
||||
;
|
||||
}
|
||||
|
||||
UPDATE_VIRTUALENV() {
|
||||
local GROUP="$1"
|
||||
local TYPE="$2"
|
||||
[ ! $TYPE ] && {
|
||||
ERROR 'no virtualenv type specified'
|
||||
return 1
|
||||
}
|
||||
|
||||
local VIRTUALENV_PATH=$(GET_VIRTUALENV_PATH $GROUP $TYPE)
|
||||
|
||||
[ ! -d $VIRTUALENV_PATH ] && CREATE_VIRTUALENV__${GROUP}__${TYPE} $VIRTUALENV_PATH
|
||||
|
||||
STATUS "updating $TYPE virtual environment"
|
||||
|
||||
source $VIRTUALENV_PATH/bin/activate || {
|
||||
ERROR 'failed to activate virtualenv; did create fail?'
|
||||
return 1
|
||||
}
|
||||
|
||||
cd $SCWRYPTS_ROOT
|
||||
local UPDATE_CODE=0
|
||||
case $TYPE in
|
||||
py ) cd py; pip install -r requirements.txt; UPDATE_CODE=$? ;;
|
||||
zx ) cd zx; npm install ;;
|
||||
esac
|
||||
UPDATE_CODE=$?
|
||||
[[ $UPDATE_CODE -eq 0 ]] \
|
||||
&& SUCCESS "$TYPE virtual environment up-to-date" \
|
||||
|| ERROR "failed to update $TYPE virtual environment (see errors above)" \
|
||||
;
|
||||
|
||||
deactivate_node >/dev/null 2>&1
|
||||
deactivate >/dev/null 2>&1
|
||||
return $UPDATE_CODE
|
||||
}
|
||||
|
||||
DELETE_VIRTUALENV() {
|
||||
local GROUP="$1"
|
||||
local TYPE="$2"
|
||||
local VIRTUALENV_PATH="$(GET_VIRTUALENV_PATH $GROUP $TYPE)"
|
||||
|
||||
STATUS "dropping $TYPE virtual environment artifacts"
|
||||
|
||||
[ ! -d $VIRTUALENV_PATH ] && {
|
||||
SUCCESS "no $TYPE environment detected"
|
||||
return 0
|
||||
}
|
||||
|
||||
rm -rf $VIRTUALENV_PATH \
|
||||
&& SUCCESS "succesfully cleaned up $TYPE virtual environment" \
|
||||
|| { ERROR "unabled to remove '$VIRTUALENV_PATH'"; return 1; }
|
||||
}
|
||||
|
||||
GET_VIRTUALENV_PATH() {
|
||||
local GROUP="$1"
|
||||
local TYPE="$2"
|
||||
eval echo '$SCWRYPTS_VIRTUALENV_PATH__'$GROUP/$TYPE
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
|
||||
CREATE_VIRTUALENV__scwrypts__py() {
|
||||
local VIRTUALENV_PATH="$1"
|
||||
|
||||
STATUS 'creating python virtual environment'
|
||||
local PY PYTHON
|
||||
for PY in $(echo $SCWRYPTS_PREFERRED_PYTHON_VERSIONS__scwrypts)
|
||||
do
|
||||
which python$PY >/dev/null 2>&1 && {
|
||||
PYTHON=$(which python$PY)
|
||||
break
|
||||
}
|
||||
done
|
||||
[ ! $PYTHON ] && {
|
||||
ERROR 'python>=3.9 not available; skipping python env'
|
||||
return 1
|
||||
}
|
||||
|
||||
STATUS 'setting up virtualenv'
|
||||
virtualenv $VIRTUALENV_PATH --python="$PYTHON" \
|
||||
&& SUCCESS 'python virtualenv created' \
|
||||
|| {
|
||||
ERROR "unable to create '$VIRTUALENV_PATH' with '$PYTHON'"
|
||||
return 2
|
||||
}
|
||||
}
|
||||
|
||||
CREATE_VIRTUALENV__scwrypts__zx() {
|
||||
local VIRTUALENV_PATH="$1"
|
||||
|
||||
STATUS 'setting up nodeenv'
|
||||
nodeenv $VIRTUALENV_PATH --node=$SCWRYPTS_NODE_VERSION__scwrypts \
|
||||
&& SUCCESS 'node virtualenv created' \
|
||||
|| {
|
||||
ERROR "unable to create '$VIRTUALENV_PATH' with '$SCWRYPTS__NODE_VERSION'"
|
||||
return 2
|
||||
}
|
||||
}
|
@ -1,14 +1,18 @@
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
DEFAULT_CONFIG="${0:a:h}/default.conf.zsh"
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
#####################################################################
|
||||
|
||||
DEFAULT_CONFIG="${0:a:h}/default.conf.zsh"
|
||||
|
||||
SAFE_SYMLINKS=1
|
||||
|
||||
# in case dotfiles.zsh is sourced... allow user to provide initial config ;)
|
||||
# in case dotfiles.zsh is sourced; allows users to provide initial config
|
||||
[ ! $CONFIG__USER_SETTINGS ] \
|
||||
&& CONFIG__USER_SETTINGS="$SCWRYPTS_CONFIG_PATH/dotfiles.zsh"
|
||||
|
||||
[ ! -f "$CONFIG__USER_SETTINGS" ] && cp "$DEFAULT_CONFIG" "$CONFIG__USER_SETTINGS"
|
||||
source $CONFIG__USER_SETTINGS
|
||||
|
||||
source "$CONFIG__USER_SETTINGS"
|
16
zsh/lib/system/desktop/notify.module.zsh
Normal file
16
zsh/lib/system/desktop/notify.module.zsh
Normal file
@ -0,0 +1,16 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=(
|
||||
notify-send
|
||||
)
|
||||
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
#####################################################################
|
||||
|
||||
NOTIFY() {
|
||||
local D=$DISPLAY
|
||||
[ ! $D ] && D=:0
|
||||
|
||||
DISPLAY=$D notify-send "SCWRYPTS $SCWRYPT_NAME" $@
|
||||
}
|
@ -1,6 +1,12 @@
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=(
|
||||
git
|
||||
make
|
||||
)
|
||||
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
#####################################################################
|
||||
|
||||
PACKAGE_INSTALL_DIR="$HOME/.local/share/source-packages"
|
||||
@ -10,19 +16,19 @@ PACKAGE_INSTALL_DIR="$HOME/.local/share/source-packages"
|
||||
|
||||
CLONE() {
|
||||
cd "$PACKAGE_INSTALL_DIR"
|
||||
__STATUS "downloading $NAME"
|
||||
STATUS "downloading $NAME"
|
||||
git clone "$TARGET" "$NAME" \
|
||||
&& __SUCCESS "successfully downloaded '$NAME'" \
|
||||
|| __FAIL 1 "failed to download '$NAME'" \
|
||||
&& SUCCESS "successfully downloaded '$NAME'" \
|
||||
|| FAIL 1 "failed to download '$NAME'" \
|
||||
;
|
||||
}
|
||||
|
||||
PULL() {
|
||||
__STATUS "updating '$NAME'"
|
||||
STATUS "updating '$NAME'"
|
||||
cd "$PACKAGE_INSTALL_DIR/$NAME"
|
||||
git pull origin $(git rev-parse --abbrev-ref HEAD) \
|
||||
&& __SUCCESS "successfully updated '$NAME'" \
|
||||
|| __FAIL 1 "failed to update '$NAME'" \
|
||||
&& SUCCESS "successfully updated '$NAME'" \
|
||||
|| FAIL 1 "failed to update '$NAME'" \
|
||||
;
|
||||
}
|
||||
|
||||
@ -34,10 +40,10 @@ BUILD() {
|
||||
CHECK_MAKE && { MAKE && return 0 || return 1; }
|
||||
CHECK_MAKEPKG && { MAKEPKG && return 0 || return 2; }
|
||||
|
||||
__WARNING 'could not detect supported installation method'
|
||||
WARNING 'could not detect supported installation method'
|
||||
|
||||
__REMINDER 'complete manual installation in the directory below:'
|
||||
__REMINDER "$PACKAGE_INSTALL_DIR/$NAME"
|
||||
REMINDER 'complete manual installation in the directory below:'
|
||||
REMINDER "$PACKAGE_INSTALL_DIR/$NAME"
|
||||
}
|
||||
|
||||
CHECK_MAKE() { [ -f ./Makefile ]; }
|
||||
@ -45,30 +51,28 @@ CHECK_MAKEPKG() { [ -f ./PKGBUILD ]; }
|
||||
|
||||
MAKE() {
|
||||
[[ $CLEAN -eq 1 ]] && {
|
||||
__STATUS "cleaning '$NAME'"
|
||||
STATUS "cleaning '$NAME'"
|
||||
make clean
|
||||
}
|
||||
|
||||
__STATUS "building '$NAME'"
|
||||
STATUS "building '$NAME'"
|
||||
make \
|
||||
&& __SUCCESS "finished building '$NAME'" \
|
||||
|| __FAIL 1 "build failed for '$NAME' (see above)"\
|
||||
&& SUCCESS "finished building '$NAME'" \
|
||||
|| FAIL 1 "build failed for '$NAME' (see above)"\
|
||||
;
|
||||
|
||||
__STATUS "installing '$NAME'"
|
||||
__GETSUDO
|
||||
STATUS "installing '$NAME'"
|
||||
GETSUDO
|
||||
sudo make install \
|
||||
&& __SUCCESS "succesfully installed '$NAME'" \
|
||||
|| __FAIL 2 "failed to install '$NAME' (see above)"\
|
||||
&& SUCCESS "succesfully installed '$NAME'" \
|
||||
|| FAIL 2 "failed to install '$NAME' (see above)"\
|
||||
;
|
||||
}
|
||||
|
||||
MAKEPKG() {
|
||||
__STATUS "installing '$NAME'"
|
||||
STATUS "installing '$NAME'"
|
||||
yes | makepkg -si \
|
||||
&& __SUCCESS "succesfully installed '$NAME'" \
|
||||
|| __FAIL 1 "failed to install '$NAME' (see above)"\
|
||||
&& SUCCESS "succesfully installed '$NAME'" \
|
||||
|| FAIL 1 "failed to install '$NAME' (see above)"\
|
||||
;
|
||||
}
|
||||
|
||||
#####################################################################
|
11
zsh/lib/system/vim/vim.module.zsh
Normal file
11
zsh/lib/system/vim/vim.module.zsh
Normal file
@ -0,0 +1,11 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=(
|
||||
vim
|
||||
)
|
||||
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
#####################################################################
|
||||
|
||||
VIM() { vim $@ </dev/tty >/dev/tty; }
|
53
zsh/lib/system/vim/vundle.module.zsh
Normal file
53
zsh/lib/system/vim/vundle.module.zsh
Normal file
@ -0,0 +1,53 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use system/vim
|
||||
|
||||
#####################################################################
|
||||
|
||||
VUNDLE__PLUGIN_DIR="$HOME/.vim/bundle"
|
||||
VUNDLE__BUILD_DEFINITIONS="$SCWRYPTS_CONFIG_PATH/vundle.zsh"
|
||||
|
||||
[ ! -f $VUNDLE__BUILD_DEFINITIONS ] && {
|
||||
{
|
||||
echo -e "#\n# Scwrypts Build Definitions\n#\n"
|
||||
} > $VUNDLE__BUILD_DEFINITIONS
|
||||
}
|
||||
|
||||
VUNDLE__PLUGIN_LIST=$(ls $VUNDLE__PLUGIN_DIR | grep -v 'Vundle.vim' | grep -v 'build.zsh')
|
||||
source $VUNDLE__BUILD_DEFINITIONS
|
||||
for PLUGIN in $(echo $VUNDLE__PLUGIN_LIST)
|
||||
do
|
||||
typeset -f VUNDLE__BUILD__$PLUGIN >/dev/null 2>/dev/null || {
|
||||
echo -e "\nVUNDLE__BUILD__$PLUGIN() {\n # ... build steps from $HOME/.vim/$PLUGIN \n}" \
|
||||
>> $VUNDLE__BUILD_DEFINITIONS
|
||||
VUNDLE__BUILD__$PLUGIN() {}
|
||||
}
|
||||
done
|
||||
|
||||
#####################################################################
|
||||
|
||||
VUNDLE__PLUGIN_INSTALL() {
|
||||
VIM +PluginInstall +qall \
|
||||
&& SUCCESS 'successfully installed Vundle.vim plugins' \
|
||||
|| FAIL 1 'failed to install Vundle.vim plugins'
|
||||
}
|
||||
|
||||
VUNDLE__REBUILD_PLUGINS() {
|
||||
local ERRORS=0
|
||||
|
||||
local PLUGIN
|
||||
for PLUGIN in $(echo $VUNDLE__PLUGIN_LIST)
|
||||
do
|
||||
cd "$VUNDLE__PLUGIN_DIR/$PLUGIN"
|
||||
STATUS "building '$PLUGIN'"
|
||||
VUNDLE__BUILD__$PLUGIN \
|
||||
&& SUCCESS "finished building '$PLUGIN'" \
|
||||
|| ERROR "failed to build '$PLUGIN' (see above)" \
|
||||
;
|
||||
done
|
||||
|
||||
return $ERRORS
|
||||
}
|
@ -11,7 +11,7 @@ Doing so will *also* check for path dependencies and required environment variab
|
||||
```shell
|
||||
#!/bin/zsh
|
||||
source ./path/to/utils.plugin.zsh
|
||||
__SUCCESS 'ZSH utilities online!'
|
||||
SUCCESS 'ZSH utilities online!'
|
||||
```
|
||||
|
||||
Checkout [io](./io.zsh) and [os](./os.zsh) for available simple functions.
|
||||
@ -20,14 +20,14 @@ Checkout [io](./io.zsh) and [os](./os.zsh) for available simple functions.
|
||||
Ensures dependent programs are available for execution.
|
||||
Specify a simple name to check the current `PATH`, or give a fully-qualified path for arbitrary dependency inclusion.
|
||||
|
||||
Include a dependency by adding to the `_DEPENDENCIES` array.
|
||||
Include a dependency by adding to the `DEPENDENCIES` array.
|
||||
*Always using `+=` makes your dependencies extensible to other scripts :)*
|
||||
|
||||
If any dependencies are missing, `source utils.module.zsh` will return an error code and count the number of missing dependencies in the variable `DEP_ERROR_COUNT`.
|
||||
|
||||
```shell
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=(
|
||||
DEPENDENCIES+=(
|
||||
path-executable-1
|
||||
path-executable-2
|
||||
/path/to/arbitrary/program
|
||||
@ -39,7 +39,7 @@ echo "missing $DEP_ERROR required dependencies"
|
||||
### Environment
|
||||
Similar to [Dependencies](#dependencies), `environment.zsh` ensures a list of environment variables are *set to non-empty values*.
|
||||
|
||||
Include an environment variable by adding to the `_REQUIRED_ENV` array.
|
||||
Include an environment variable by adding to the `REQUIRED_ENV` array.
|
||||
*Something something use `+=` here too ;)*
|
||||
|
||||
If any environment variables are missing, `source utils.module.zsh` will return an error code and count the number of missing variables in `ENV_ERROR_COUNT`.
|
||||
@ -48,7 +48,7 @@ Missing environment variables will be added to the environment template (*exclus
|
||||
|
||||
```shell
|
||||
#!/bin/zsh
|
||||
_REQUIRED_ENV+=(
|
||||
REQUIRED_ENV+=(
|
||||
AWS_PROFILE
|
||||
AWS_REGION
|
||||
)
|
@ -1,7 +1,9 @@
|
||||
__CHECK_DEPENDENCIES() {
|
||||
local DEP ERROR=0
|
||||
|
||||
for DEP in $*; do __CHECK_DEPENDENCY $DEP || ((ERROR+=1)); done
|
||||
DEPENDENCIES=($(echo $DEPENDENCIES | sed 's/ \+/\n/g' | sort -u))
|
||||
|
||||
for DEP in ${DEPENDENCIES[@]}; do __CHECK_DEPENDENCY $DEP || ((ERROR+=1)); done
|
||||
__CHECK_COREUTILS || ((ERROR+=$?))
|
||||
|
||||
return $ERROR
|
||||
@ -11,7 +13,7 @@ __CHECK_DEPENDENCY() {
|
||||
local DEPENDENCY="$1"
|
||||
[ ! $DEPENDENCY ] && return 1
|
||||
command -v $DEPENDENCY >/dev/null 2>&1 || {
|
||||
__ERROR "'$1' required but not installed. $(__CREDITS $1)"
|
||||
ERROR "'$1' required but not available on PATH $(__CREDITS $1)"
|
||||
return 1
|
||||
}
|
||||
}
|
||||
@ -27,14 +29,14 @@ __CHECK_COREUTILS() {
|
||||
__CHECK_DEPENDENCY $UTIL || { ((MISSING_DEPENDENCY_COUNT+=1)); continue; }
|
||||
|
||||
$UTIL --version 2>&1 | grep -q 'GNU' || {
|
||||
__WARNING "non-GNU version of $UTIL detected"
|
||||
WARNING "non-GNU version of $UTIL detected"
|
||||
((NON_GNU_DEPENDENCY_COUNT+=1))
|
||||
}
|
||||
done
|
||||
|
||||
[[ $NON_GNU_DEPENDENCY_COUNT -gt 0 ]] && {
|
||||
__WARNING 'scripts rely on GNU coreutils; functionality may be limited'
|
||||
__IS_MACOS && __REMINDER 'GNU coreutils can be installed and linked through Homebrew'
|
||||
WARNING 'scripts rely on GNU coreutils; functionality may be limited'
|
||||
IS_MACOS && REMINDER 'GNU coreutils can be installed and linked through Homebrew'
|
||||
}
|
||||
|
||||
return $MISSING_DEPENDENCY_COUNT
|
@ -1,6 +1,7 @@
|
||||
__CHECK_REQUIRED_ENV() {
|
||||
local VAR ERROR=0
|
||||
for VAR in $*; do __CHECK_ENV_VAR $VAR || ((ERROR+=1)); done
|
||||
REQUIRED_ENV=($(echo $REQUIRED_ENV | sed 's/\s\+/\n/g' | sort -u))
|
||||
for VAR in ${REQUIRED_ENV[@]}; do __CHECK_ENV_VAR $VAR || ((ERROR+=1)); done
|
||||
return $ERROR
|
||||
}
|
||||
|
||||
@ -17,9 +18,9 @@ __CHECK_ENV_VAR() {
|
||||
local VALUE=$(eval echo '$'$NAME)
|
||||
[ $VALUE ] && return 0
|
||||
|
||||
local SELECTION_VALUES=$(eval echo '$'$NAME'__select' | sed 's/,/\n/g')
|
||||
[ $SELECTION_VALUES ] && {
|
||||
local SELECTION=$(echo $SELECTION_VALUES | __FZF "select a value for '$NAME'")
|
||||
local SELECTION_VALUES=$(eval echo '$'$NAME'__select' | sed 's/,/\n/g; s/ /\n/g')
|
||||
[[ $ERROR -eq 0 ]] && [[ ${#SELECTION_VALUES[@]} -gt 0 ]] && {
|
||||
local SELECTION=$(echo $SELECTION_VALUES | FZF "select a value for '$NAME'")
|
||||
[ $SELECTION ] && {
|
||||
export $NAME=$SELECTION
|
||||
return 0
|
||||
@ -27,23 +28,11 @@ __CHECK_ENV_VAR() {
|
||||
}
|
||||
[ $VALUE ] && return 0
|
||||
|
||||
[ $__SCWRYPT ] && {
|
||||
# scwrypts exclusive (missing vars staged in env.template)
|
||||
local LINE="export $NAME="
|
||||
|
||||
grep -q -- "^$LINE" "$__ENV_TEMPLATE" || {
|
||||
__STATUS 'staging new variable in template'
|
||||
|
||||
echo "$LINE" >> "$__ENV_TEMPLATE" \
|
||||
&& __RUN_SCWRYPT zsh/scwrypts/environment/synchronize -- --no-prompt
|
||||
}
|
||||
}
|
||||
|
||||
[ $OPTIONAL ] && {
|
||||
[ $DEFAULT_VALUE ] && $NAME="$DEFAULT_VALUE"
|
||||
return 0
|
||||
} || {
|
||||
__ERROR "'$NAME' required"
|
||||
ERROR "'$NAME' required"
|
||||
return 1
|
||||
}
|
||||
}
|
152
zsh/lib/utils/io.zsh
Normal file
152
zsh/lib/utils/io.zsh
Normal file
@ -0,0 +1,152 @@
|
||||
PRINT() {
|
||||
local MESSAGE
|
||||
local LAST_LINE_END='\n'
|
||||
local STDERR=1
|
||||
local STDOUT=0
|
||||
|
||||
local LTRIM=1
|
||||
while [[ $# -gt 0 ]]
|
||||
do
|
||||
case $1 in
|
||||
-n | --no-trim-tabs ) LTRIM=0 ;;
|
||||
-x | --no-line-end ) LAST_LINE_END='' ;;
|
||||
-o | --use-stdout ) STDOUT=1; STDERR=0 ;;
|
||||
* ) MESSAGE+="$(echo $1) " ;;
|
||||
esac
|
||||
shift 1
|
||||
done
|
||||
|
||||
local STYLED_MESSAGE="${COLOR}$({
|
||||
printf "${COLOR}"
|
||||
while IFS='' read line
|
||||
do
|
||||
[[ $PREFIX =~ ^[[:space:]]\+$ ]] && printf '\n'
|
||||
|
||||
printf "${PREFIX} : $(echo "$line" | sed 's/^ \+//; s/ \+$//')"
|
||||
|
||||
PREFIX=$(echo $PREFIX | sed 's/./ /g')
|
||||
done <<< $MESSAGE
|
||||
})${__COLOR_RESET}${LAST_LINE_END}"
|
||||
[[ $STDERR -eq 1 ]] && printf $STYLED_MESSAGE >&2
|
||||
[[ $STDOUT -eq 1 ]] && printf $STYLED_MESSAGE
|
||||
|
||||
return 0
|
||||
}
|
||||
|
||||
[ ! $ERRORS ] && ERRORS=0
|
||||
ERROR() { PREFIX="ERROR ✖" COLOR=$__RED PRINT "$@"; ((ERRORS+=1)); }
|
||||
SUCCESS() { PREFIX="SUCCESS ✔" COLOR=$__GREEN PRINT "$@"; }
|
||||
WARNING() { PREFIX="WARNING " COLOR=$__ORANGE PRINT "$@"; }
|
||||
STATUS() { PREFIX="STATUS " COLOR=$__BLUE PRINT "$@"; }
|
||||
REMINDER() { PREFIX="REMINDER " COLOR=$__PURPLE PRINT "$@"; }
|
||||
INFO() { PREFIX="INFO " COLOR=$__WHITE PRINT "$@"; }
|
||||
|
||||
PROMPT() {
|
||||
PREFIX="PROMPT " COLOR=$__CYAN PRINT "$@"
|
||||
PREFIX="USER " COLOR=$__CYAN PRINT '' --no-line-end
|
||||
}
|
||||
|
||||
FAIL() { ERROR "${@:2}"; exit $1; }
|
||||
ABORT() { FAIL 69 'user abort'; }
|
||||
|
||||
CHECK_ERRORS() {
|
||||
local FAIL_OUT=1
|
||||
|
||||
while [[ $# -gt 0 ]]
|
||||
do
|
||||
case $1 in
|
||||
-n | --no-fail ) FAIL_OUT=0 ;;
|
||||
esac
|
||||
shift 1
|
||||
done
|
||||
|
||||
[ ! $ERRORS ] && ERRORS=0
|
||||
[[ $ERRORS -ne 0 ]] && USAGE
|
||||
[[ $ERRORS -eq 0 ]] || {
|
||||
[[ $FAIL_OUT -eq 1 ]] \
|
||||
&& exit $ERRORS \
|
||||
|| return $ERRORS
|
||||
}
|
||||
}
|
||||
|
||||
USAGE() {
|
||||
[ ! $USAGE ] && return 0
|
||||
USAGE=$(echo $USAGE | sed "s/^\t\+//; s/\s\+$//")
|
||||
|
||||
local USAGE_LINE=$(\
|
||||
echo $USAGE \
|
||||
| grep -i '^ *usage *:' \
|
||||
| sed "s;^[^:]*:;& scwrypts $SCWRYPT_NAME --;" \
|
||||
| sed 's/ \{2,\}/ /g; s/scwrypts -- scwrypts/scwrypts/' \
|
||||
)
|
||||
local THE_REST=$(echo $USAGE | grep -vi '^ *usage *:' | sed 'N;/^\n$/D;P;D;')
|
||||
|
||||
{ echo; printf "$__DARK_BLUE $USAGE_LINE$__COLOR_RESET\n"; echo $THE_REST; echo } >&2
|
||||
}
|
||||
|
||||
INPUT() {
|
||||
PROMPT "${@:2}"
|
||||
READ $1
|
||||
local VALUE=$(eval echo '$'$1)
|
||||
[ $VALUE ]
|
||||
}
|
||||
|
||||
Yn() {
|
||||
PROMPT "$@ [Yn]"
|
||||
[ $CI ] && { echo y; return 0; }
|
||||
|
||||
local Yn; READ -k Yn; echo
|
||||
[[ $Yn =~ [nN] ]] && return 1 || return 0
|
||||
}
|
||||
|
||||
yN() {
|
||||
PROMPT "$@ [yN]"
|
||||
[ $CI ] && { echo y; return 0; }
|
||||
|
||||
local yN; READ -k yN; echo
|
||||
[[ $yN =~ [yY] ]] && return 0 || return 1
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
|
||||
GETSUDO() {
|
||||
echo "\\033[1;36mPROMPT : checking sudo password...\\033[0m" >&2
|
||||
sudo echo hi >/dev/null 2>&1 </dev/tty \
|
||||
&& SUCCESS '...authenticated!' \
|
||||
|| { ERROR 'failed :c'; return 1; }
|
||||
}
|
||||
|
||||
LESS() { less -R $@ </dev/tty >/dev/tty; }
|
||||
|
||||
FZF() {
|
||||
[ $CI ] && {
|
||||
ERROR 'currently in CI, but FZF requires user input'
|
||||
exit 1
|
||||
}
|
||||
|
||||
local SELECTION=$(fzf -i --height=30% --layout=reverse --prompt "$1 : " ${@:2})
|
||||
PROMPT "$1"
|
||||
echo $SELECTION >&2
|
||||
echo $SELECTION
|
||||
}
|
||||
FZF_HEAD() { FZF $@ --print-query | sed '/^$/d' | head -n1; } # prefer user input over selected
|
||||
FZF_TAIL() { FZF $@ --print-query | sed '/^$/d' | tail -n1; } # prefer selected over user input
|
||||
|
||||
READ() {
|
||||
[ $CI ] && {
|
||||
INFO 'currently in CI, skipping READ'
|
||||
return 0
|
||||
}
|
||||
read $@ </dev/tty
|
||||
}
|
||||
|
||||
EDIT() {
|
||||
[ $CI ] && {
|
||||
INFO 'currently in CI, skipping EDIT'
|
||||
return 0
|
||||
}
|
||||
|
||||
STATUS "opening '$1' for editing"
|
||||
$EDITOR $@ </dev/tty >/dev/tty
|
||||
SUCCESS "finished editing '$1'!"
|
||||
}
|
12
zsh/lib/utils/os.zsh
Normal file
12
zsh/lib/utils/os.zsh
Normal file
@ -0,0 +1,12 @@
|
||||
IS_MACOS() { uname -s | grep -q 'Darwin'; }
|
||||
|
||||
OPEN() {
|
||||
local OPEN=''
|
||||
{
|
||||
command -v xdg-open && OPEN=xdg-open
|
||||
command -v open && OPEN=open
|
||||
} >/dev/null 2>&1
|
||||
|
||||
[ ! $OPEN ] && { ERROR 'unable to detect default open command (e.g. xdg-open)'; return 1 }
|
||||
$OPEN $@
|
||||
}
|
76
zsh/lib/utils/utils.module.zsh
Normal file
76
zsh/lib/utils/utils.module.zsh
Normal file
@ -0,0 +1,76 @@
|
||||
#####################################################################
|
||||
|
||||
DEPENDENCIES+=(fzf) # (extensible) list of PATH dependencies
|
||||
REQUIRED_ENV+=() # (extensible) list of required environment variables
|
||||
|
||||
#####################################################################
|
||||
|
||||
source ${0:a:h}/colors.zsh
|
||||
source ${0:a:h}/io.zsh
|
||||
source ${0:a:h}/os.zsh
|
||||
source ${0:a:h}/credits.zsh
|
||||
|
||||
#####################################################################
|
||||
|
||||
source ${0:a:h}/dependencies.zsh
|
||||
source ${0:a:h}/environment.zsh
|
||||
|
||||
#####################################################################
|
||||
|
||||
CHECK_ENVIRONMENT() {
|
||||
local ENVIRONMENT_STATUS=0
|
||||
|
||||
__CHECK_DEPENDENCIES $DEPENDENCIES
|
||||
local MISSING_DEPENDENCIES=$?
|
||||
|
||||
__CHECK_REQUIRED_ENV $REQUIRED_ENV
|
||||
local MISSING_ENVIRONMENT_VARIABLES=$?
|
||||
|
||||
##########################################
|
||||
|
||||
local ERROR_MESSAGE=""
|
||||
[[ $MISSING_DEPENDENCIES -ne 0 ]] && {
|
||||
((ENVIRONMENT_STATUS+=1))
|
||||
ERROR_MESSAGE+="\n$MISSING_DEPENDENCIES missing "
|
||||
|
||||
[[ $MISSING_DEPENDENCIES -eq 1 ]] \
|
||||
&& ERROR_MESSAGE+='dependency' \
|
||||
|| ERROR_MESSAGE+='dependencies' \
|
||||
;
|
||||
}
|
||||
|
||||
[[ $MISSING_ENVIRONMENT_VARIABLES -ne 0 ]] && {
|
||||
((ENVIRONMENT_STATUS+=2))
|
||||
ERROR_MESSAGE+="\n$MISSING_ENVIRONMENT_VARIABLES missing environment variable"
|
||||
|
||||
[[ $MISSING_ENVIRONMENT_VARIABLES -gt 1 ]] && ERROR_MESSAGE+=s
|
||||
}
|
||||
|
||||
[ $IMPORT_ERRORS ] && [[ $IMPORT_ERRORS -ne 0 ]] && {
|
||||
((ENVIRONMENT_STATUS+=4))
|
||||
ERROR_MESSAGE+="\n$IMPORT_ERRORS import error"
|
||||
|
||||
[[ $IMPORT_ERRORS -gt 1 ]] && ERROR_MESSAGE+=s
|
||||
}
|
||||
|
||||
##########################################
|
||||
|
||||
[[ ENVIRONMENT_STATUS -eq 0 ]] || {
|
||||
ERROR_MESSAGE=$(echo $ERROR_MESSAGE | sed '1d; s/^/ /')
|
||||
ERROR "environment errors found (see above)\n$ERROR_MESSAGE"
|
||||
}
|
||||
|
||||
[[ $MISSING_ENVIRONMENT_VARIABLES -ne 0 ]] && {
|
||||
REMINDER "
|
||||
to quickly update missing environment variables, run:
|
||||
'scwrypts zsh/scwrypts/environment/edit'
|
||||
"
|
||||
}
|
||||
|
||||
[[ $ENVIRONMENT_STATUS -eq 0 ]] || {
|
||||
[[ $NO_EXIT -eq 1 ]] && return $ENVIRONMENT_STATUS
|
||||
exit $ENVIRONMENT_STATUS
|
||||
}
|
||||
}
|
||||
|
||||
CHECK_ENVIRONMENT
|
28
zsh/media/youtube/download
Executable file
28
zsh/media/youtube/download
Executable file
@ -0,0 +1,28 @@
|
||||
#!/bin/zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use media/youtube
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
DOWNLOAD_VIDEO() {
|
||||
local URLS=($@)
|
||||
|
||||
[[ ${#URLS[@]} -eq 0 ]] && URLS=($(echo '' | FZF_HEAD 'enter URL'))
|
||||
[[ ${#URLS[@]} -eq 0 ]] && ABORT
|
||||
|
||||
local FILENAME=$(YT__GET_FILENAME $URLS)
|
||||
[ ! $FILENAME ] && ERROR "unable to download '$URLS'"
|
||||
|
||||
SUCCESS "Found '$FILENAME'"
|
||||
Yn "Proceed with download?" || return 1
|
||||
|
||||
YT__DOWNLOAD $URLS \
|
||||
&& SUCCESS "downloaded to '$YT__OUTPUT_DIR/$FILENAME'" \
|
||||
|| { ERROR "failed to download '$FILENAME'"; return 2; }
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
DOWNLOAD_VIDEO $@
|
54
zsh/media/youtube/get-audio-clip
Executable file
54
zsh/media/youtube/get-audio-clip
Executable file
@ -0,0 +1,54 @@
|
||||
#!/bin/zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use media/youtube
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
GET_AUDIO_CLIP() {
|
||||
local URLS=($@)
|
||||
|
||||
[[ ${#URLS[@]} -eq 0 ]] && URLS=($(echo '' | FZF_HEAD 'enter URL'))
|
||||
[[ ${#URLS[@]} -eq 0 ]] && ABORT
|
||||
|
||||
local FILENAME=$(YT__GET_FILENAME $URLS)
|
||||
[ ! $FILENAME ] && ERROR "unable to download '$URLS'"
|
||||
|
||||
INPUT_FILE="$YT__OUTPUT_DIR/$FILENAME"
|
||||
|
||||
[ ! -f "$INPUT_FILE" ] && {
|
||||
SCWRYPTS__RUN youtube/download -- $URLS || return 1
|
||||
}
|
||||
|
||||
SUCCESS "video download '$FILENAME' detected!"
|
||||
|
||||
LENGTH=$(GET_VIDEO_LENGTH "$INPUT_FILE")
|
||||
[ ! $LENGTH ] && { ERROR "unable to determine video length for '$INPUT_FILE'"; return 2; }
|
||||
START_TIME=$(echo 0 | FZF_HEAD "enter start time (0 ≤ t < $LENGTH)")
|
||||
[ ! $START_TIME ] && ABORT
|
||||
END_TIME=$(echo $LENGTH | FZF_HEAD "enter end time ($START_TIME > t ≥ $LENGTH)")
|
||||
[ ! $END_TIME ] && ABORT
|
||||
|
||||
STATUS
|
||||
STATUS "video : $FILENAME"
|
||||
STATUS "start time : $START_TIME"
|
||||
STATUS "end time : $END_TIME"
|
||||
STATUS
|
||||
OUTPUT_FILE=$(echo '' \
|
||||
| FZF_HEAD 'what should I call this clip? (.mp3)' \
|
||||
| sed 's/\.mp3$//' \
|
||||
)
|
||||
[ ! $OUTPUT_FILE ] && ABORT
|
||||
OUTPUT_FILE="$YT__OUTPUT_DIR/$OUTPUT_FILE.mp3"
|
||||
|
||||
ffmpeg -i "$INPUT_FILE" -q:a 0 -map a \
|
||||
-ss $START_TIME -t $(($END_TIME - $START_TIME))\
|
||||
"$OUTPUT_FILE" \
|
||||
&& SUCCESS "created clip '$OUTPUT_FILE'" \
|
||||
|| { ERROR "error creating clip '$(basename $OUTPUT_FILE)' (see above)"; return 3; }
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
GET_AUDIO_CLIP $@
|
@ -1,19 +0,0 @@
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/../common.zsh
|
||||
#####################################################################
|
||||
|
||||
set +o noglob
|
||||
MEMO__FILETYPE=md
|
||||
MEMO__DIR="$SCWRYPTS_DATA_PATH/memo"
|
||||
[ ! -d $MEMO__DIR ] && mkdir -p $MEMO__DIR
|
||||
|
||||
LIST_MEMOS() { ls $MEMO__DIR | sed "s/\.$MEMO__FILETYPE$//" | sort; }
|
||||
|
||||
# TODO : remove deprecated migration
|
||||
[ -d $HOME/.memos ] && {
|
||||
__Yn 'detected legacy memos folder; upgrade now?' && {
|
||||
mv $HOME/.memos/* $MEMO__DIR
|
||||
rmdir "$HOME/.memos"
|
||||
}
|
||||
}
|
@ -1,32 +0,0 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
|
||||
OPEN_MEMO() {
|
||||
local MEMO_NAME=$(LIST_MEMOS | __FZF 'select a memo to delete')
|
||||
local MEMO_FILE="$MEMO__DIR/$MEMO_NAME.$MEMO__FILETYPE"
|
||||
[ "$MEMO_NAME" ] && [ -f "$MEMO_FILE" ] || __ABORT
|
||||
|
||||
__STATUS "--- START OF MEMO ---------------------------------------------------"
|
||||
cat "$MEMO_FILE"
|
||||
__STATUS "--- END OF MEMO -----------------------------------------------------"
|
||||
|
||||
__WARNING
|
||||
__WARNING 'memos are not backed up by default; deletion is permanent!'
|
||||
__WARNING
|
||||
|
||||
__yN 'are you sure you want to delete this memo?' || __ABORT
|
||||
|
||||
__STATUS "deleting memo '$MEMO_FILE'"
|
||||
rm "$MEMO_FILE" \
|
||||
&& __SUCCESS "removed memo '$MEMO_NAME'" \
|
||||
|| __FAIL 1 "failed to remove memo '$MEMO_NAME'" \
|
||||
;
|
||||
}
|
||||
|
||||
|
||||
|
||||
#####################################################################
|
||||
OPEN_MEMO $@
|
31
zsh/office/latex/build-pdf
Executable file
31
zsh/office/latex/build-pdf
Executable file
@ -0,0 +1,31 @@
|
||||
#!/bin/zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use office/latex
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
PDFLATEX() {
|
||||
[ ! $1 ] && FAIL 1 'must provide filename'
|
||||
local FILENAME=$(LATEX__GET_MAIN_FILENAME "$1")
|
||||
|
||||
local ARGS=(-interaction=nonstopmode)
|
||||
ARGS+=("$FILENAME")
|
||||
|
||||
cd "$(dirname $FILENAME)"
|
||||
|
||||
STATUS 'running compile (1/2)'
|
||||
pdflatex ${ARGS[@]} \
|
||||
|| FAIL 2 'first compile failed (see above)'
|
||||
|
||||
STATUS 'running compile (2/2)'
|
||||
pdflatex ${ARGS[@]} >/dev/null 2>&1 \
|
||||
|| FAIL 3 'second compile failed :c'
|
||||
|
||||
SUCCESS "created '$(echo $FILENAME | sed 's/\.[^.]*$/.pdf/')'"
|
||||
}
|
||||
|
||||
#####################################################################
|
||||
PDFLATEX $@
|
@ -1,19 +1,22 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use office/latex
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
CLEAN_LATEX_LOGFILES() {
|
||||
local DIRECTORY=$(__GET_PATH_TO_RELATIVE_ARGUMENT ".")
|
||||
[ $1 ] && DIRECTORY="$(dirname "$(GET_MAIN_LATEX_FILENAME "$1")")"
|
||||
local DIRECTORY=$(SCWRYPTS__GET_PATH_TO_RELATIVE_ARGUMENT ".")
|
||||
[ $1 ] && DIRECTORY="$(dirname "$(LATEX__GET_MAIN_FILENAME "$1")")"
|
||||
[ $DIRECTORY ] && [ -d $DIRECTORY ] \
|
||||
|| __FAIL 1 'unable to parse valid directory'
|
||||
|| FAIL 1 'unable to parse valid directory'
|
||||
|
||||
cd $DIRECTORY
|
||||
rm $(ls | grep '\.\(aux\)\|\(log\)\|\(pdf\)\|\(out\)\|\(dvi\)$')
|
||||
|
||||
__SUCCESS "cleaned up latex artifacts in '$DIRECTORY'"
|
||||
SUCCESS "cleaned up latex artifacts in '$DIRECTORY'"
|
||||
}
|
||||
|
||||
#####################################################################
|
@ -1,29 +1,28 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=(
|
||||
pdflatex
|
||||
rg
|
||||
)
|
||||
_REQUIRED_ENV+=()
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use office/latex
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
TEMPLATE_DIR="${0:a:h}/templates"
|
||||
|
||||
source ${0:a:h}/common.zsh
|
||||
#####################################################################
|
||||
|
||||
CREATE_NEW_LATEX_DOCUMENT_FROM_TEMPLATE() {
|
||||
local DOCUMENT_DIR="$EXECUTION_DIR"
|
||||
local TEMPLATE=$(GET_TEMPLATES | __FZF 'select a template')
|
||||
[ ! $TEMPLATE ] && __ABORT
|
||||
__SUCCESS "selected template '$TEMPLATE'"
|
||||
local TEMPLATE=$(GET_TEMPLATES | FZF 'select a template')
|
||||
[ ! $TEMPLATE ] && ABORT
|
||||
SUCCESS "selected template '$TEMPLATE'"
|
||||
|
||||
__INPUT DOC_TITLE 'document title' || __ABORT
|
||||
INPUT DOC_TITLE 'document title' || ABORT
|
||||
|
||||
local DOCUMENT_FILE="$DOCUMENT_DIR/$(SLUGIFY_TITLE).tex"
|
||||
[ -f "$DOCUMENT_FILE" ] && __FAIL 1 "'$(basename $DOCUMENT_FILE)' already exists"
|
||||
[ -f "$DOCUMENT_FILE" ] && FAIL 1 "'$(basename $DOCUMENT_FILE)' already exists"
|
||||
|
||||
__INPUT DOC_ID 'document id/subtitle'
|
||||
__INPUT AUTHOR 'author name'
|
||||
__INPUT AUTHOR_ID 'author id/title'
|
||||
INPUT DOC_ID 'document id/subtitle'
|
||||
INPUT AUTHOR 'author name'
|
||||
INPUT AUTHOR_ID 'author id/title'
|
||||
|
||||
{
|
||||
PRINT_TITLE_INFO
|
||||
@ -37,7 +36,7 @@ CREATE_NEW_LATEX_DOCUMENT_FROM_TEMPLATE() {
|
||||
[[ ! $TEMPLATE =~ ^basic$ ]] \
|
||||
&& mkdir "$DOCUMENT_DIR/sections" "$DOCUMENT_DIR/graphics"
|
||||
|
||||
__SUCCESS "finished generating '$(basename $DOCUMENT_FILE)' from '$TEMPLATE'"
|
||||
SUCCESS "finished generating '$(basename $DOCUMENT_FILE)' from '$TEMPLATE'"
|
||||
}
|
||||
|
||||
GET_TEMPLATES() {
|
10
zsh/office/latex/get-pdf
Executable file
10
zsh/office/latex/get-pdf
Executable file
@ -0,0 +1,10 @@
|
||||
#!/bin/zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use office/latex
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
LATEX__GET_PDF $@
|
@ -1,14 +1,17 @@
|
||||
#!/bin/zsh
|
||||
_DEPENDENCIES+=()
|
||||
_REQUIRED_ENV+=()
|
||||
source ${0:a:h}/common.zsh
|
||||
DEPENDENCIES+=()
|
||||
REQUIRED_ENV+=()
|
||||
|
||||
use office/latex
|
||||
|
||||
CHECK_ENVIRONMENT
|
||||
#####################################################################
|
||||
|
||||
OPEN_PDF() {
|
||||
local PDF=$(__RUN_SCWRYPT latex/get-pdf -n -- $1)
|
||||
local PDF=$(LATEX__GET_PDF $@)
|
||||
[ ! $PDF ] && return 1
|
||||
|
||||
__OPEN "$PDF"
|
||||
OPEN "$PDF"
|
||||
}
|
||||
|
||||
#####################################################################
|
0
zsh/office/latex/templates/math/gitignore
Normal file
0
zsh/office/latex/templates/math/gitignore
Normal file
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user