mirror of
https://github.com/Llewellynvdm/Tomb.git
synced 2025-01-24 15:38:25 +00:00
3eb93acc18
This commit re-organizes all the source distribution contents to present users with the simple script, while moving the rest in extras. Also autoconf/automake scripts were removed, back to minimalism. The rationale of this change is that Tomb really only consists of a script and users with no extra needs should just be presented with it with no need for anything else. Any other thing on top of the Tomb script is an extra and can be even distributed separately or integrated in distributions.
221 lines
6.6 KiB
Bash
Executable File
221 lines
6.6 KiB
Bash
Executable File
#!/bin/zsh
|
|
#
|
|
# Undertaker, auxiliary command for Tomb
|
|
#
|
|
# Tomb is a tool to operate file encryption of private and secret data
|
|
#
|
|
# Undertaker is a tool to retrieve tomb keys from various sources
|
|
#
|
|
# {{{ Copyleft (C) 2012 Dyne.org foundation
|
|
# 2011-2012 Denis Roio <jaromil@dyne.org>
|
|
#
|
|
# This source code is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU Public License as published by
|
|
# the Free Software Foundation; either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This source code is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
# Please refer to the GNU Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Public License along with
|
|
# this source code; if not, write to:
|
|
# Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
# }}}
|
|
|
|
# signal traps (special funcs in Zsh)
|
|
TRAPKILL() die "KILL signal caught, undertaker aborting."
|
|
TRAPSTOP() die "STOP signal caught, undertaker aborting."
|
|
|
|
# first of all source the tomb core functions
|
|
TOMBBIN=$(dirname $(readlink -f $0))/tomb
|
|
if ! [[ -x $TOMBBIN ]]; then
|
|
print "$fg[red][!]$fg[white] Tomb command not found, operation aborted." >&2; exit 1
|
|
fi
|
|
source $TOMBBIN ${tomb_opts[@]} source
|
|
TOMBEXEC=undertaker
|
|
|
|
key_found() {
|
|
# $1 is "url"
|
|
if option_is_set --batch; then
|
|
print -n '[m]' >&2
|
|
fi
|
|
print "$fg[white][found] $1" >&2
|
|
}
|
|
|
|
|
|
|
|
function undertaker_scheme() {
|
|
zparseopts -D -path=print_path
|
|
|
|
local scheme
|
|
scheme=$1
|
|
local keypath
|
|
keypath=$2
|
|
case $scheme in
|
|
|
|
|
|
bluetooth)
|
|
#TODO: support --print-path
|
|
act "access to bluetooth protocol requested"
|
|
which obexftp &> /dev/null
|
|
if [[ $? != 0 ]]; then
|
|
_warning "obexftp not found, needed for bluetooth: operation aborted."
|
|
return 64
|
|
fi
|
|
keytmp=`safe_dir undertaker`
|
|
cd $keytmp
|
|
# fetch key from bluetooth, url format: bluetooth://55:33:44:55:66/file/path
|
|
obexdevpath=${keypath#*//}
|
|
obexdev=${obexdevpath%%/*}
|
|
obexpath=${obexdevpath#*/}
|
|
act "obex device: $obexdev"
|
|
act "obex path: $obexpath"
|
|
obexftp -b $obexdev -g $obexpath
|
|
if [[ $? != 0 ]]; then
|
|
rmdir ${keytmp}
|
|
die "a problem occurred retreiving the key via bluetooth."
|
|
fi
|
|
# print out the key on stdout
|
|
if option_is_set --path; then
|
|
echo $obexpath
|
|
# up to the caller to delete the key
|
|
# TODO: --path should have the directory where to put the key
|
|
# as argument, instead of creating keytmp
|
|
else
|
|
cat `pwd`/$obexpath >&1
|
|
# wipe out the key
|
|
${WIPE[@]} $obexpath
|
|
cd -
|
|
rmdir ${keytmp}
|
|
fi
|
|
|
|
# tombkey="basename $obexpath"
|
|
;;
|
|
|
|
file)
|
|
if ! [[ -f $keypath ]]; then
|
|
_warning "Invalid path $keypath"
|
|
return 1
|
|
fi
|
|
if option_is_set --path; then
|
|
key_found $scheme://$keypath;
|
|
else
|
|
< $keypath
|
|
r=$?
|
|
if [[ $r != 0 ]]; then return 1; fi
|
|
return 0
|
|
fi
|
|
;;
|
|
|
|
mounted)
|
|
for mountpoint in `cut -f2 /etc/mtab -d ' ' | sort -u`; do
|
|
undertaker_scheme ${print_path[@]} file ${mountpoint}/${keypath}
|
|
ret=$?
|
|
if [[ $ret == 0 ]]; then
|
|
return 0
|
|
fi
|
|
done
|
|
;;
|
|
|
|
udisks)
|
|
#It implements automounting using udisks; udisks is a (recently)
|
|
#new technology, so we can't rely on it being present
|
|
if ! which udisks &> /dev/null; then
|
|
_warning 'udisks not found'
|
|
exit 64
|
|
fi
|
|
while true; do
|
|
device=`udisks --monitor|egrep '/sd[a-z][0-9]' -o -m1`
|
|
device=/dev$device
|
|
udisks --mount $device
|
|
###get mountpoint for device
|
|
mountpoint=`egrep "^${device} " /etc/mtab|cut -d ' ' -f2`
|
|
undertaker_scheme ${print_path[@]} file ${mountpoint}/${keypath}
|
|
ret=$?
|
|
udisks --unmount $device
|
|
if [[ $ret == 0 ]]; then
|
|
return 0
|
|
fi
|
|
done
|
|
;;
|
|
|
|
near)
|
|
###Given the path to the tomb, search the key near to that
|
|
undertaker_scheme file ${keypath}.key
|
|
;;
|
|
|
|
|
|
|
|
*)
|
|
if ! which undertaker-$scheme &> /dev/null; then
|
|
_warning "url protocol not recognized: $scheme"
|
|
return 64
|
|
fi
|
|
undertaker-$scheme ${print_path[@]} ${scheme}://$keypath
|
|
return $?
|
|
;;
|
|
esac
|
|
}
|
|
|
|
function main() {
|
|
typeset -A opts
|
|
zparseopts -M -E -D -Aopts -poll -path -batch
|
|
if ! [ $1 ] ; then
|
|
print "[W] an argument is missing, the undertaker is confused" >&2
|
|
print "usage: undertaker [options] url://host:path/to/tomb.key" >&2
|
|
exit 1;
|
|
fi
|
|
local -a tomb_opts
|
|
if [[ -n ${(k)opts[--batch]} ]]; then
|
|
tomb_opts+='--no-color'
|
|
tomb_opts+='--quiet'
|
|
fi
|
|
local -a under_opts
|
|
if [[ -n ${(k)opts[--path]} ]]; then
|
|
under_opts+='--path'
|
|
fi
|
|
local -A backupopts
|
|
for a in ${(k)opts}; do
|
|
backupopts[$a]=${opts[$a]}
|
|
done
|
|
source tomb ${tomb_opts[@]} source
|
|
TOMBEXEC=undertaker
|
|
for a in ${(k)backupopts}; do
|
|
opts[$a]=${backupopts[$a]}
|
|
done
|
|
check_bin
|
|
|
|
_success "Undertaker will look for $1"
|
|
|
|
ARG1=${1}
|
|
scheme=${ARG1%://*}
|
|
keypath=${ARG1#*//}
|
|
|
|
if [[ -n ${(k)opts[--poll]} ]]; then
|
|
while true; do
|
|
progress poll 0 search
|
|
undertaker_scheme ${under_opts[@]} $scheme $keypath
|
|
r=$?
|
|
if [[ $r == 64 ]]; then
|
|
exit 64
|
|
fi
|
|
progress poll 100 done
|
|
sleep 3
|
|
done
|
|
else
|
|
undertaker_scheme ${under_opts[@]} $scheme $keypath
|
|
fi
|
|
}
|
|
main $*
|
|
|
|
### Conventions and other comments:
|
|
#
|
|
# EXIT CODES FOR SCHEME HANDLERS
|
|
# 0 is for everything went fine
|
|
# 64 is for "not supported/the problem won't be solved by polling". This is for things like: unmet dependencies, not supported at all, etc
|
|
# everything else means just "error". Use 1, please. So other codes can be used if needed
|
|
#
|