mirror of
https://github.com/ivuorinen/dotfiles.git
synced 2026-02-08 10:50:46 +00:00
* fix(ci): replace broad permissions with specific scopes in workflows
Replace read-all/write-all with minimum required permission scopes
across all GitHub Actions workflows to follow the principle of least
privilege (SonarCloud rule githubactions:S8234).
* fix(shell): use [[ instead of [ for conditional tests
Replace single brackets with double brackets in bash conditional
expressions across 14 files (28 changes). All scripts use bash
shebangs so [[ is safe everywhere (SonarCloud rule shelldre:S7688).
* fix(shell): add explicit return statements to functions
Add return 0 as the last statement in ~46 shell functions across
17 files that previously relied on implicit return codes
(SonarCloud rule shelldre:S7682).
* fix(shell): assign positional parameters to local variables
Replace direct $1/$2/$3 usage with named local variables in _log(),
msg(), msg_err(), msg_done(), msg_run(), msg_ok(), and array_diff()
(SonarCloud rule shelldre:S7679).
* fix(python): replace dict() constructor with literal
Use {} instead of dict() for empty dictionary initialization
(SonarCloud rule python:S7498).
* fix(shell): fix husky shebang and tolerate npm outdated exit code
* docs(shell): add function docstring comments
* fix(shell): fix heredoc indentation in x-sonarcloud
* feat(python): add ruff linter and formatter configuration
* fix(ci): align megalinter config with biome, ruff, and shfmt settings
* fix(ci): disable black and yaml-prettier in megalinter config
* chore(ci): update ruff-pre-commit to v0.15.0 and fix hook name
* fix(scripts): check for .git dir before skipping clone in install-fonts
* fix(shell): address code review issues in scripts and shared.sh
- Guard wezterm show-keys failure in create-wezterm-keymaps.sh
- Stop masking git failures with return 0 in install-cheat-purebashbible.sh
- Add missing shared.sh source in install-xcode-cli-tools.sh
- Replace exit 1 with return 1 in sourced shared.sh
* fix(scripts): address code review and security findings
- Guard wezterm show-keys failure in create-wezterm-keymaps.sh
- Stop masking git failures with return 0 in install-cheat-purebashbible.sh
- Add missing shared.sh source in install-xcode-cli-tools.sh
- Replace exit 1 with return 1 in sourced shared.sh
- Remove shell=True subprocess calls in x-git-largest-files.py
* style(shell): apply shfmt formatting and add args to pre-commit hook
* fix(python): suppress bandit false positives in x-git-largest-files
* fix(python): add nosemgrep suppression for check_output call
* feat(format): add prettier for YAML formatting
Install prettier, add .prettierrc.json config (200-char width, 2-space
indent, LF endings), .prettierignore, yarn scripts (lint:prettier,
fix:prettier, format:yaml), and pre-commit hook scoped to YAML files.
* style(yaml): apply prettier formatting
* fix(scripts): address remaining code review findings
- Python: use list comprehension to filter empty strings instead of
slicing off the last element
- create-wezterm-keymaps: write to temp file and mv for atomic updates
- install-xcode-cli-tools: fix shellcheck source directive path
* fix(python): sort imports alphabetically in x-git-largest-files
* fix(lint): disable PYTHON_ISORT in MegaLinter, ruff handles it
* chore(git): add __pycache__ to gitignore
* fix(python): rename ambiguous variable l to line (E741)
* style: remove trailing whitespace and blank lines
* style(fzf): apply shfmt formatting
* style(shell): apply shfmt formatting
* docs(plans): add design documents
* style(docs): add language specifier to fenced code block
* feat(lint): add markdown-table-formatter to dev tooling
Add markdown-table-formatter as a dev dependency with yarn scripts
(lint:md-table, fix:md-table) and a local pre-commit hook to
automatically format markdown tables on commit.
163 lines
3.4 KiB
Bash
Executable File
163 lines
3.4 KiB
Bash
Executable File
#!/usr/bin/env sh
|
|
#
|
|
# Send Pushover messages from cli
|
|
# Based on https://github.com/mrusme/dotfiles/blob/master/usr/local/bin/pushover
|
|
#
|
|
# Modified by Ismo Vuorinen <https://github.com/ivuorinen> 2023
|
|
|
|
# Display usage information for pushover
|
|
__pushover_usage()
|
|
{
|
|
printf "pushover <options> <message>\n"
|
|
printf " -c <callback>\n"
|
|
printf " -d <device>\n"
|
|
printf " -D <timestamp>\n"
|
|
printf " -e <expire>\n"
|
|
printf " -p <priority>\n"
|
|
printf " -r <retry>\n"
|
|
printf " -t <title>\n"
|
|
printf " -T <TOKEN> (required if not in 'PUSHOVER_TOKEN' env)\n"
|
|
printf " -s <sound>\n"
|
|
printf " -u <url>\n"
|
|
printf " -U <USER> (required if not in 'PUSHOVER_USER' env)\n"
|
|
printf " -a <url_title>\n"
|
|
return 1
|
|
}
|
|
|
|
# Format an optional curl form field
|
|
__pushover_opt_field()
|
|
{
|
|
field=$1
|
|
shift
|
|
value="${*}"
|
|
if [ -n "${value}" ]; then
|
|
printf "%s \"%s=%s\"\n" "-F" "$field" "$value"
|
|
fi
|
|
}
|
|
|
|
# Send a pushover notification via curl
|
|
__pushover_send_message()
|
|
{
|
|
device="${1:-}"
|
|
|
|
curl_cmd="\"${CURL}\" -s -S \
|
|
${CURL_OPTS} \
|
|
-F \"token=${TOKEN}\" \
|
|
-F \"user=${USER}\" \
|
|
-F \"message=${message}\" \
|
|
$(__pushover_opt_field device "${device}") \
|
|
$(__pushover_opt_field callback "${callback}") \
|
|
$(__pushover_opt_field timestamp "${timestamp}") \
|
|
$(__pushover_opt_field priority "${priority}") \
|
|
$(__pushover_opt_field retry "${retry}") \
|
|
$(__pushover_opt_field expire "${expire}") \
|
|
$(__pushover_opt_field title "${title}") \
|
|
$(__pushover_opt_field sound "${sound}") \
|
|
$(__pushover_opt_field url "${url}") \
|
|
$(__pushover_opt_field url_title "${url_title}") \
|
|
\"${PUSHOVER_URL}\""
|
|
|
|
response="$(eval "${curl_cmd}")"
|
|
printf "%s\n" "$response"
|
|
|
|
# Parse response status. Expect JSON like: {"status":1,"request":"..."}
|
|
if echo "$response" | grep -q '"status"[[:space:]]*:[[:space:]]*1'; then
|
|
r=0
|
|
else
|
|
r=1
|
|
fi
|
|
|
|
if [ "$r" -ne 0 ]; then
|
|
# Extract possible error message from JSON
|
|
err=$(echo "$response" | grep -o '"errors".*' | sed 's/"errors"[:,\[]//g' | tr -d '[]"')
|
|
[ -n "$err" ] && printf "%s: %s\n" "$0" "$err" >&2
|
|
printf "%s: Failed to send message\n" "$0" >&2
|
|
fi
|
|
|
|
return "$r"
|
|
}
|
|
|
|
CURL="$(command -v curl)"
|
|
PUSHOVER_URL="https://api.pushover.net/1/messages.json"
|
|
TOKEN=$PUSHOVER_TOKEN
|
|
USER=$PUSHOVER_USER
|
|
CURL_OPTS=""
|
|
devices=""
|
|
optstring="c:d:D:e:p:r:t:T:s:u:U:a:h"
|
|
|
|
OPTIND=1
|
|
while getopts ${optstring} c; do
|
|
case ${c} in
|
|
c)
|
|
callback="${OPTARG}"
|
|
;;
|
|
d)
|
|
devices="${devices} ${OPTARG}"
|
|
;;
|
|
D)
|
|
timestamp="${OPTARG}"
|
|
;;
|
|
e)
|
|
expire="${OPTARG}"
|
|
;;
|
|
p)
|
|
priority="${OPTARG}"
|
|
;;
|
|
r)
|
|
retry="${OPTARG}"
|
|
;;
|
|
t)
|
|
title="${OPTARG}"
|
|
;;
|
|
T)
|
|
TOKEN="${OPTARG}"
|
|
;;
|
|
s)
|
|
sound="${OPTARG}"
|
|
;;
|
|
u)
|
|
url="${OPTARG}"
|
|
;;
|
|
U)
|
|
USER="${OPTARG}"
|
|
;;
|
|
a)
|
|
url_title="${OPTARG}"
|
|
;;
|
|
|
|
[h\?])
|
|
__pushover_usage
|
|
exit 1
|
|
;;
|
|
esac
|
|
done
|
|
shift $((OPTIND - 1))
|
|
|
|
if [ "$#" -lt 1 ]; then
|
|
__pushover_usage
|
|
exit 1
|
|
fi
|
|
message="$*"
|
|
|
|
if [ ! -x "${CURL}" ]; then
|
|
printf "CURL is unset, empty, or does not point to curl executable.\n \
|
|
This script requires curl!\n" >&2
|
|
exit 1
|
|
fi
|
|
|
|
devices="$(printf "%s" "${devices}" | xargs -n1 | sort -u)"
|
|
|
|
if [ -z "${devices}" ]; then
|
|
__pushover_send_message
|
|
r=${?}
|
|
else
|
|
for device in ${devices}; do
|
|
__pushover_send_message "${device}"
|
|
r=${?}
|
|
if [ "${r}" -ne 0 ]; then
|
|
break
|
|
fi
|
|
done
|
|
fi
|
|
exit "${r}"
|