Skip to content

Instantly share code, notes, and snippets.

View mgoodness's full-sized avatar

Michael Goodness mgoodness

View GitHub Profile
@mgoodness
mgoodness / openpgp.md
Created December 5, 2022 18:24
Keyoxide Proof

[Verifying my cryptographic key:openpgp4fpr:4C556569AD90DE0419009E974A31C228815AA553]

@mgoodness
mgoodness / _pyenv.zsh
Last active December 24, 2023 15:36
"New" (compsys) zsh completion script for pyenv
#compdef pyenv
# Ref: https://github.com/pyenv/pyenv/pull/1644
if [[ ! -o interactive ]]; then
return
fi
local state line
typeset -A opt_args
#!/usr/bin/env bash
while getopts ":u:" opt; do
case "$opt" in
u)
username="${OPTARG}"
;;
\?)
echo "Invalid option: -${OPTARG}" >&2
return 1
kube-context() {
if [[ -n "$1" ]]; then
context=$1
else
context=$(kubectl config get-contexts \
| fzf --header-lines=1 --no-multi \
| awk '{if ($1!="*") print $1; else print $2 }')
fi
[[ -n ${context} ]] && kubectl config use-context ${context}
docker-rmi() {
docker images \
| fzf --header-lines=1 --multi \
| awk '{print $3}' \
| xargs docker rmi ${1+"$@"}
}
find-replace() {
for m in (ag --files-with-matches -- $1); do
sed -i '' -e "s/$1/$2/g" $m
done
}
k8s-api() {
if [[ "$1" == "1.9" ]]; then
url="https://v1-9.docs.kubernetes.io/docs/api-reference/v1.9/"
else
url="https://kubernetes.io/docs/reference/generated/kubernetes-api/v$1/"
fi
open ${url}
}
git-rebase-preserve-author() {
git rebase --preserve-merges $1
root_dir=(git rev-parse --show-toplevel)
while [[ -f ${root_dir}/.git/rebase-merge/stopped-sha ]]; do
stopped_sha=(cat ${root_dir}/.git/rebase-merge/stopped-sha)
git_author_string=(git show -s --format='%an <%ae>' ${stopped_sha})
for c in (git diff --name-only --diff-filter=U); do
eval ${EDITOR} ${root_dir}/$c
@mgoodness
mgoodness / nginx-ingress-controller-rbac.md
Last active May 28, 2019 15:44
nginx-ingress-controller RBAC setup for K8s v1.8+ (tested on minikube)
kubectl -n kube-system create sa nginx-ingress-controller
kubectl apply -f https://gist.github.com/mgoodness/684d91e5812d383f6cc48d420bdad5b5/raw/8ef6d0623e9273aa93f22ab2b5d5cbb40502a5aa/nginx-ingress-controller-clusterrole.yaml
kubectl -n kube-system apply -f https://gist.github.com/mgoodness/4c5ddf4cc340a7c504a01a8f9ff422cf/raw/421d2032e4a36577739b60c0e673e889c1d1c6e2/nginx-ingress-controller-role.yaml
kubectl create clusterrolebinding nginx-ingress-controller --clusterrole nginx-ingress-controller --serviceaccount=kube-system:nginx-ingress-controller
kubectl -n kube-system create rolebinding nginx-ingress-controller --role nginx-ingress-controller --serviceaccount=kube-system:nginx-ingress-controller
kubectl -n kube-system patch rc/nginx-ingress-controller -p '{"spec": {"template": {"spec": {"serviceAccountName": "nginx-ingress-controller"}}}}'
kubectl -n kube-system delete po -l app=nginx-ingress-controller
@mgoodness
mgoodness / nginx-ingress-controller-role.yaml
Last active May 28, 2019 15:44
nginx-ingress-controller Role
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: Role
metadata:
name: nginx-ingress-controller
rules:
- apiGroups:
- ""
resources:
- configmaps
- pods