Compare commits
11 Commits
5180bc805c
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
bc58d71ed5 | ||
|
|
5c36c869cd | ||
|
|
b8c01492e2 | ||
|
|
7d83c328be | ||
|
|
1d407d1893 | ||
|
|
9190f0dd6a | ||
|
|
d38de67704 | ||
|
|
b0d8421b70 | ||
|
|
434c84caf6 | ||
|
|
0e65223381 | ||
|
|
283ef0417b |
@@ -5,7 +5,7 @@ SCRIPT_DIR="$(dirname $(realpath "$0"))"
|
||||
function run() {
|
||||
if [ $# -lt 2 ]; then
|
||||
echo "Usage: $0 <category> <script> [args...]"
|
||||
find "$SCRIPT_DIR" -mindepth 2 | awk -F'[./]' '{printf "$ run %s %s\n",$(NF-2),$(NF-1)}'
|
||||
find "$SCRIPT_DIR" -mindepth 2 -iname "*.sh" | awk -F'[./]' '{printf "$ run %s %s\n",$(NF-2),$(NF-1)}'
|
||||
return
|
||||
fi
|
||||
bash "$SCRIPT_DIR/$1/$2.sh" ${@:3}
|
||||
|
||||
@@ -9,4 +9,5 @@ i3 workspace number 2
|
||||
i3 move workspace to output right
|
||||
i3 workspace number 3
|
||||
i3 move workspace to output right
|
||||
i3 workspace number 3
|
||||
i3 move workspace to output right
|
||||
|
||||
12
ledger/reconcile.sh
Normal file
12
ledger/reconcile.sh
Normal file
@@ -0,0 +1,12 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
if [[ -f "~/.simplefin.enc" ]]; then
|
||||
echo "Simplefin access URL is missing."
|
||||
echo "Please run the setup script before running update."
|
||||
exit
|
||||
fi
|
||||
|
||||
SCRIPT_DIR="$(dirname -- "${BASH_SOURCE[0]}")"
|
||||
ACCESS_URL="$(cat ~/.simplefin.enc | openssl aes-256-cbc -d -a -salt -pbkdf2 -iter 1000000)"
|
||||
|
||||
curl -L "${ACCESS_URL}/accounts?start-date=$(date '+%s')&pending=1" | jq -rc '.accounts | map({name, balance})[]'
|
||||
21
ledger/setup.sh
Normal file
21
ledger/setup.sh
Normal file
@@ -0,0 +1,21 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
read -p "Enter your setup token: " token
|
||||
|
||||
while : ; do
|
||||
read -sp "Enter password: " password
|
||||
echo
|
||||
read -sp "Confirm password: " confirmed
|
||||
echo
|
||||
[[ "$password" == "$confirmed" ]] && break || echo "Passwords are not equal."
|
||||
echo
|
||||
done
|
||||
|
||||
CLAIM_URL="$(echo "$token" | base64 -d)"
|
||||
ACCESS_URL="$(curl -H "Content-Length: 0" -X POST "$CLAIM_URL")"
|
||||
|
||||
echo "Claim URL: $CLAIM_URL"
|
||||
echo "Access URL: $ACCESS_URL"
|
||||
|
||||
echo "$ACCESS_URL" | openssl aes-256-cbc -salt -a -pbkdf2 -iter 1000000 -pass "pass:$password" > ~/.simplefin.enc
|
||||
|
||||
43
ledger/update.jq
Normal file
43
ledger/update.jq
Normal file
@@ -0,0 +1,43 @@
|
||||
# Takes in a string as the transaction description and returns the
|
||||
# acconut to categorize as.
|
||||
def categorize_transaction:
|
||||
if test("MURNMGMT-MIRA") then "Expenses:Bills:Rent"
|
||||
elif test("VERIZON\\s+DES") then "Expenses:Bills:Internet"
|
||||
elif test("PEPCO\\s+PAYMENTUS|WASHINGTON\\s+GAS\\s+DES") then "Expenses:Bills:Utilities"
|
||||
elif test("HEALTHEQUITY\\s+INC") then "Assets:HealthEquity"
|
||||
elif test("LOCKHEED\\s+MARTIN") then "Income:Work"
|
||||
elif test("CASH\\s+REWARDS") then "Income:Gifts"
|
||||
elif test("Roosters") then "Expenses:Essentials:Hygiene"
|
||||
elif test("ALASKA\\s+AIR") then "Expenses:Travel:Flights"
|
||||
elif test("HELP\\.UBER\\.COMCA") then "Expenses:Travel:Taxi"
|
||||
elif test("STEAM GAMES") then "Expenses:Entertainment:Games"
|
||||
elif test("YouTubePremium|DOORDASHDASHPASS|Prime\\s+Video\\s+Channels|TIDAL\\.COM|Amazon Grocery|SIMPLEFIN BRIDGE|(APPLE\\.COM.*RECURRING$)") then "Expenses:Subscriptions"
|
||||
elif test("MOMS OF|SAFEWAY\\.COM|MAYORGA") then "Expenses:Food:Groceries"
|
||||
elif test("CHICK-FIL-A|GEMELLIS\\s+ITALIAN|CHIPOTLE|SHEETZ|KUNG\\s+FU\\s+TEA") then "Expenses:Food:Restaurants"
|
||||
elif test("GRUBHUB|DD\\s+\\*DOORDASH") then "Expenses:Food:Delivery"
|
||||
elif test("MARKET@WORK") then "Expenses:Food:Snacks"
|
||||
else "UNKNOWN" end;
|
||||
|
||||
def format_transactions:
|
||||
map(
|
||||
.name as $name |
|
||||
.transactions |
|
||||
map(.account = $name)[]
|
||||
) |
|
||||
sort_by(.transacted_at) |
|
||||
map(
|
||||
(.transacted_at | strftime("%Y/%m/%d")) + " " +
|
||||
(.description | gsub("\\s+"; " ")) + "\n " + (.description | categorize_transaction) + " $" +
|
||||
(-(.amount | tonumber) | tostring) + " ; Payee: " +
|
||||
.payee + "\n " +
|
||||
.account + "\n"
|
||||
);
|
||||
|
||||
def rename_accounts:
|
||||
map(.name |= (
|
||||
if (.| startswith("Adv Plus Banking")) then "Checking"
|
||||
elif (.| startswith("Unlimited Cash Rewards Visa Signature")) then "Credit"
|
||||
elif (.| startswith("Amazon Prime Rewards Visa Signature")) then "Amazon"
|
||||
end));
|
||||
|
||||
.accounts | rename_accounts | format_transactions[]
|
||||
17
ledger/update.sh
Normal file
17
ledger/update.sh
Normal file
@@ -0,0 +1,17 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
if [[ $# < 1 ]]; then
|
||||
echo "Usage: $0 <start-date>"
|
||||
exit
|
||||
fi
|
||||
|
||||
if [[ -f "~/.simplefin.enc" ]]; then
|
||||
echo "Simplefin access URL is missing."
|
||||
echo "Please run the setup script before running update."
|
||||
exit
|
||||
fi
|
||||
|
||||
SCRIPT_DIR="$(dirname -- "${BASH_SOURCE[0]}")"
|
||||
ACCESS_URL="$(cat ~/.simplefin.enc | openssl aes-256-cbc -d -a -salt -pbkdf2 -iter 1000000)"
|
||||
|
||||
curl -L "${ACCESS_URL}/accounts?start-date=$(date -d "$1" '+%s')&pending=1" | jq -r -f "${SCRIPT_DIR}/update.jq"
|
||||
27
life/left.sh
Normal file
27
life/left.sh
Normal file
@@ -0,0 +1,27 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
MINUTE=60
|
||||
HOUR=$(($MINUTE * 60))
|
||||
DAY=$(($HOUR * 24))
|
||||
MONTH=$(($DAY * 30))
|
||||
YEAR=$(($DAY * 365))
|
||||
|
||||
if [[ $# < 2 ]]; then
|
||||
echo "Usage: $0 <birthdate> <age>"
|
||||
exit
|
||||
fi
|
||||
|
||||
print_lifetime() {
|
||||
future=$(date +%s -d "$1 + $2 years")
|
||||
epoch=$(($future - $(date +%s)))
|
||||
|
||||
echo "Seconds until $2 years old: $epoch"
|
||||
echo "Minutes until $2 years old: $(($epoch / $MINUTE))"
|
||||
echo "Hours until $2 years old: $(($epoch / $HOUR))"
|
||||
echo "Days until $2 years old: $(($epoch / $DAY))"
|
||||
echo "Months until $2 years old: $(($epoch / $MONTH))"
|
||||
echo "Years until $2 years old: $(($epoch / $YEAR))"
|
||||
}
|
||||
|
||||
|
||||
print_lifetime "$1" "$2"
|
||||
@@ -1,6 +1,10 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
update() {
|
||||
cd ~/dotfiles
|
||||
git pull
|
||||
git submodule init
|
||||
git submodule update
|
||||
sudo nixos-rebuild switch --flake ~/dotfiles
|
||||
home-manager switch --flake ~/dotfiles
|
||||
}
|
||||
@@ -9,7 +13,7 @@ update() {
|
||||
ssh media@media.randomctf.com -t "$(typeset -f update); update"
|
||||
ssh logging@logging.randomctf.local -t "$(typeset -f update); update"
|
||||
ssh mindforge@mindforge.randomctf.local -t "$(typeset -f update); update"
|
||||
ssh sampledb@sampledb.randomctf.local -t "$(typeset -f update); update"
|
||||
ssh mnemosyne@mnemosyne.randomctf.local -t "$(typeset -f update); update"
|
||||
|
||||
# Ubuntu VMs
|
||||
ssh pbx@pbx.randomctf.local -t "sudo apt update -y && sudo apt upgrade -y"
|
||||
|
||||
18
prod/pom.sh
Normal file
18
prod/pom.sh
Normal file
@@ -0,0 +1,18 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
|
||||
cycle_raw=$(gum choose --header="Choose your pomodoro cycle for work/break." "50/10" "25/5")
|
||||
work_time=$(echo "$cycle_raw" | cut -d/ -f 1)
|
||||
break_time=$(echo "$cycle_raw" | cut -d/ -f 2)
|
||||
|
||||
while true; do
|
||||
timer "${work_time}m"
|
||||
|
||||
if gum confirm "Do you want to take a break?"; then
|
||||
timer "${break_time}m"
|
||||
fi
|
||||
|
||||
if ! gum confirm "Do you want to resume working?"; then
|
||||
break
|
||||
fi
|
||||
done
|
||||
3
proxmox/display.sh
Normal file
3
proxmox/display.sh
Normal file
@@ -0,0 +1,3 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
nohup remote-viewer ~/Downloads/pve-spice.vv 2>&1 >/dev/null &
|
||||
3
r330/start.sh
Normal file
3
r330/start.sh
Normal file
@@ -0,0 +1,3 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
sshpass -p "$(rbw get iDRAC)" ssh root@192.168.100.11 racadm serveraction powerup
|
||||
3
r330/status.sh
Normal file
3
r330/status.sh
Normal file
@@ -0,0 +1,3 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
sshpass -p "$(rbw get iDRAC)" ssh root@192.168.100.11 racadm serveraction powerstatus
|
||||
3
r330/stop.sh
Normal file
3
r330/stop.sh
Normal file
@@ -0,0 +1,3 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
sshpass -p "$(rbw get iDRAC)" ssh root@192.168.100.11 racadm serveraction graceshutdown
|
||||
3
r730xd/start.sh
Normal file
3
r730xd/start.sh
Normal file
@@ -0,0 +1,3 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
sshpass -p "$(rbw get iDRAC)" ssh root@192.168.100.12 racadm serveraction powerup
|
||||
3
r730xd/status.sh
Normal file
3
r730xd/status.sh
Normal file
@@ -0,0 +1,3 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
sshpass -p "$(rbw get iDRAC)" ssh root@192.168.100.12 racadm serveraction powerstatus
|
||||
3
r730xd/stop.sh
Normal file
3
r730xd/stop.sh
Normal file
@@ -0,0 +1,3 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
sshpass -p "$(rbw get iDRAC)" ssh root@192.168.100.12 racadm serveraction graceshutdown
|
||||
@@ -1,5 +1,5 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
backup=$(date +%s)
|
||||
mkdir "$HOME/backup_tld/$backup"
|
||||
mkdir "$HOME/Nextcloud/Archives/Backups/backup_tld/$backup"
|
||||
cp -R "$HOME/.local/share/Hinterland/TheLongDark/Survival/"* "$HOME/backup_tld/$backup"
|
||||
|
||||
Reference in New Issue
Block a user