#!/bin/sh # credentials # Written in 2019-2020 by Lucas # CC0 1.0 Universal/Public domain - No rights reserved # # To the extent possible under law, the author(s) have dedicated all # copyright and related and neighboring rights to this software to the # public domain worldwide. This software is distributed without any # warranty. You should have received a copy of the CC0 Public Domain # Dedication along with this software. If not, see # . usage() { cat - <<. >&2 Usage: ${0##*/} [-2pu] service ${0##*/} -r key . exit 1 } err() { printf "%s: %s\n" "${0##*/}" "$*" >&2 exit 1 } clip() { xclip -q -r -l 1 -sel clip 2>/dev/null } get_user() { printf user sekrit cp "services/$1/user" && printf "\n" } get_pass() { printf pass sekrit cp "services/$1/pass" && printf "\n" } get_2fa() { printf 2fa otpcli_opts= case $1 in isnic) otpcli_opts="-H sha512 -d 8" ;; esac sekrit get "services/$1/2fa" | otpcli $otpcli_opts | clip && printf "\n" } get_service() { service=$1 user=$2 pass=$3 sfa=$4 if [ $user = no ] && [ $pass = no ] && [ $sfa = no ]; then sekrit has "services/$service/pass" || err "unknown service $service" pass=yes sekrit has "services/$service/user" && user=yes sekrit has "services/$service/2fa" && sfa=yes fi if [ $user = check ]; then sekrit has "services/$service/user" || err "service $service has no user" user=yes fi if [ $pass = check ]; then sekrit has "services/$service/pass" || err "service $service has no pass" pass=yes fi if [ $sfa = check ]; then sekrit has "services/$service/2fa" || err "service $service has no 2fa" sfa=yes fi [ $user = yes ] && get_user "$service" [ $pass = yes ] && get_pass "$service" [ $sfa = yes ] && get_2fa "$service" } get_raw() { key=$1 sekrit has "$key" || err "unknown key $key" printf "%s" "$key" sekrit get "$key" | clip && printf "\n" } sfa=no pass=no raw=no user=no while getopts 2pru flag; do case $flag in 2) sfa=check ;; p) pass=check ;; r) raw=yes ;; u) user=check ;; *) usage ;; esac done shift $((OPTIND - 1)) [ $# -eq 1 ] && [ -n "$1" ] || usage key=$1 if [ $raw = yes ]; then if [ $sfa != no ] || [ $pass != no ] || [ $user != no ]; then err "-r is mutually exclusive with -2pu" fi get_raw "$key" else get_service "$key" $user $pass $sfa fi