2023-09-08 07:50:57 +02:00
|
|
|
# $OpenBSD: scp.sh,v 1.19 2023/09/08 05:50:57 djm Exp $
|
2004-06-16 12:15:59 +02:00
|
|
|
# Placed in the Public Domain.
|
|
|
|
|
|
|
|
tid="scp"
|
|
|
|
|
|
|
|
#set -x
|
|
|
|
|
|
|
|
COPY2=${OBJ}/copy2
|
|
|
|
DIR=${COPY}.dd
|
|
|
|
DIR2=${COPY}.dd2
|
2022-10-24 23:52:50 +02:00
|
|
|
COPY3=${OBJ}/copy.glob[123]
|
|
|
|
DIR3=${COPY}.dd.glob[456]
|
2022-10-30 19:42:07 +01:00
|
|
|
DIFFOPT="-rN"
|
|
|
|
|
|
|
|
# Figure out if diff does not understand "-N"
|
|
|
|
if ! diff -N ${SRC}/scp.sh ${SRC}/scp.sh 2>/dev/null; then
|
|
|
|
DIFFOPT="-r"
|
|
|
|
fi
|
2004-06-16 12:15:59 +02:00
|
|
|
|
2023-01-13 05:47:34 +01:00
|
|
|
maybe_add_scp_path_to_sshd
|
|
|
|
|
2004-06-16 12:15:59 +02:00
|
|
|
SRC=`dirname ${SCRIPT}`
|
2004-08-29 11:39:09 +02:00
|
|
|
cp ${SRC}/scp-ssh-wrapper.sh ${OBJ}/scp-ssh-wrapper.scp
|
|
|
|
chmod 755 ${OBJ}/scp-ssh-wrapper.scp
|
2014-01-24 04:27:04 +01:00
|
|
|
export SCP # used in scp-ssh-wrapper.scp
|
2004-06-16 12:15:59 +02:00
|
|
|
|
|
|
|
scpclean() {
|
2022-10-24 23:52:50 +02:00
|
|
|
rm -rf ${COPY} ${COPY2} ${DIR} ${DIR2} ${COPY3} ${DIR3}
|
|
|
|
mkdir ${DIR} ${DIR2} ${DIR3}
|
|
|
|
chmod 755 ${DIR} ${DIR2} ${DIR3}
|
2004-06-16 12:15:59 +02:00
|
|
|
}
|
|
|
|
|
2023-09-08 07:50:57 +02:00
|
|
|
# Create directory structure for recursive copy tests.
|
|
|
|
forest() {
|
|
|
|
scpclean
|
|
|
|
rm -rf ${DIR2}
|
|
|
|
cp ${DATA} ${DIR}/copy
|
|
|
|
ln -s ${DIR}/copy ${DIR}/copy-sym
|
|
|
|
mkdir ${DIR}/subdir
|
|
|
|
cp ${DATA} ${DIR}/subdir/copy
|
|
|
|
ln -s ${DIR}/subdir ${DIR}/subdir-sym
|
|
|
|
}
|
|
|
|
|
2021-08-03 03:05:24 +02:00
|
|
|
for mode in scp sftp ; do
|
2021-08-10 05:35:45 +02:00
|
|
|
tag="$tid: $mode mode"
|
2021-08-03 03:05:24 +02:00
|
|
|
if test $mode = scp ; then
|
2021-08-10 05:35:45 +02:00
|
|
|
scpopts="-O -q -S ${OBJ}/scp-ssh-wrapper.scp"
|
2021-08-03 03:05:24 +02:00
|
|
|
else
|
2023-09-08 07:50:57 +02:00
|
|
|
scpopts="-qs -D ${SFTPSERVER}"
|
2021-08-03 03:05:24 +02:00
|
|
|
fi
|
2023-09-08 07:50:57 +02:00
|
|
|
|
2023-01-06 08:18:18 +01:00
|
|
|
verbose "$tag: simple copy local file to local file"
|
2021-08-03 03:05:24 +02:00
|
|
|
scpclean
|
|
|
|
$SCP $scpopts ${DATA} ${COPY} || fail "copy failed"
|
|
|
|
cmp ${DATA} ${COPY} || fail "corrupted copy"
|
2004-06-16 12:15:59 +02:00
|
|
|
|
2021-08-03 03:05:24 +02:00
|
|
|
verbose "$tag: simple copy local file to remote file"
|
|
|
|
scpclean
|
|
|
|
$SCP $scpopts ${DATA} somehost:${COPY} || fail "copy failed"
|
|
|
|
cmp ${DATA} ${COPY} || fail "corrupted copy"
|
2004-06-16 12:15:59 +02:00
|
|
|
|
2021-08-03 03:05:24 +02:00
|
|
|
verbose "$tag: simple copy remote file to local file"
|
|
|
|
scpclean
|
|
|
|
$SCP $scpopts somehost:${DATA} ${COPY} || fail "copy failed"
|
|
|
|
cmp ${DATA} ${COPY} || fail "corrupted copy"
|
2006-01-31 12:05:23 +01:00
|
|
|
|
2022-05-16 01:48:07 +02:00
|
|
|
verbose "$tag: copy local file to remote file in place"
|
|
|
|
scpclean
|
|
|
|
cp ${DATA} ${COPY}
|
|
|
|
$SCP $scpopts ${COPY} somehost:${COPY} || fail "copy failed"
|
|
|
|
cmp ${DATA} ${COPY} || fail "corrupted copy"
|
|
|
|
|
|
|
|
verbose "$tag: copy remote file to local file in place"
|
|
|
|
scpclean
|
|
|
|
cp ${DATA} ${COPY}
|
|
|
|
$SCP $scpopts somehost:${COPY} ${COPY} || fail "copy failed"
|
|
|
|
cmp ${DATA} ${COPY} || fail "corrupted copy"
|
|
|
|
|
|
|
|
verbose "$tag: copy local file to remote file clobber"
|
|
|
|
scpclean
|
|
|
|
cat ${DATA} ${DATA} > ${COPY}
|
|
|
|
$SCP $scpopts ${DATA} somehost:${COPY} || fail "copy failed"
|
|
|
|
ls -l $DATA $COPY
|
|
|
|
cmp ${DATA} ${COPY} || fail "corrupted copy"
|
|
|
|
|
|
|
|
verbose "$tag: copy remote file to local file clobber"
|
|
|
|
scpclean
|
|
|
|
cat ${DATA} ${DATA} > ${COPY}
|
|
|
|
$SCP $scpopts somehost:${DATA} ${COPY} || fail "copy failed"
|
|
|
|
cmp ${DATA} ${COPY} || fail "corrupted copy"
|
|
|
|
|
2021-08-03 03:05:24 +02:00
|
|
|
verbose "$tag: simple copy local file to remote dir"
|
|
|
|
scpclean
|
|
|
|
cp ${DATA} ${COPY}
|
|
|
|
$SCP $scpopts ${COPY} somehost:${DIR} || fail "copy failed"
|
|
|
|
cmp ${COPY} ${DIR}/copy || fail "corrupted copy"
|
2004-06-16 12:15:59 +02:00
|
|
|
|
2021-08-03 03:05:24 +02:00
|
|
|
verbose "$tag: simple copy local file to local dir"
|
|
|
|
scpclean
|
|
|
|
cp ${DATA} ${COPY}
|
|
|
|
$SCP $scpopts ${COPY} ${DIR} || fail "copy failed"
|
|
|
|
cmp ${COPY} ${DIR}/copy || fail "corrupted copy"
|
2006-01-31 12:06:14 +01:00
|
|
|
|
2021-08-03 03:05:24 +02:00
|
|
|
verbose "$tag: simple copy remote file to local dir"
|
2004-12-06 13:03:27 +01:00
|
|
|
scpclean
|
2021-08-03 03:05:24 +02:00
|
|
|
cp ${DATA} ${COPY}
|
|
|
|
$SCP $scpopts somehost:${COPY} ${DIR} || fail "copy failed"
|
|
|
|
cmp ${COPY} ${DIR}/copy || fail "corrupted copy"
|
2004-12-06 13:03:27 +01:00
|
|
|
|
2021-08-03 03:05:24 +02:00
|
|
|
verbose "$tag: recursive local dir to remote dir"
|
2023-09-08 07:50:57 +02:00
|
|
|
forest
|
2021-08-03 03:05:24 +02:00
|
|
|
$SCP $scpopts -r ${DIR} somehost:${DIR2} || fail "copy failed"
|
|
|
|
diff ${DIFFOPT} ${DIR} ${DIR2} || fail "corrupted copy"
|
2004-06-16 12:15:59 +02:00
|
|
|
|
2021-08-03 03:05:24 +02:00
|
|
|
verbose "$tag: recursive local dir to local dir"
|
2023-09-08 07:50:57 +02:00
|
|
|
forest
|
2021-08-03 03:05:24 +02:00
|
|
|
rm -rf ${DIR2}
|
|
|
|
cp ${DATA} ${DIR}/copy
|
|
|
|
$SCP $scpopts -r ${DIR} ${DIR2} || fail "copy failed"
|
|
|
|
diff ${DIFFOPT} ${DIR} ${DIR2} || fail "corrupted copy"
|
2019-07-19 05:45:44 +02:00
|
|
|
|
2021-08-03 03:05:24 +02:00
|
|
|
verbose "$tag: recursive remote dir to local dir"
|
2023-09-08 07:50:57 +02:00
|
|
|
forest
|
2021-08-03 03:05:24 +02:00
|
|
|
rm -rf ${DIR2}
|
|
|
|
cp ${DATA} ${DIR}/copy
|
|
|
|
$SCP $scpopts -r somehost:${DIR} ${DIR2} || fail "copy failed"
|
|
|
|
diff ${DIFFOPT} ${DIR} ${DIR2} || fail "corrupted copy"
|
2019-07-19 05:45:44 +02:00
|
|
|
|
2022-10-24 23:52:50 +02:00
|
|
|
verbose "$tag: unmatched glob file local->remote"
|
|
|
|
scpclean
|
|
|
|
$SCP $scpopts ${DATA} somehost:${COPY3} || fail "copy failed"
|
|
|
|
cmp ${DATA} ${COPY3} || fail "corrupted copy"
|
|
|
|
|
|
|
|
verbose "$tag: unmatched glob file remote->local"
|
|
|
|
# NB. no clean
|
|
|
|
$SCP $scpopts somehost:${COPY3} ${COPY2} || fail "copy failed"
|
|
|
|
cmp ${DATA} ${COPY2} || fail "corrupted copy"
|
|
|
|
|
|
|
|
verbose "$tag: unmatched glob dir recursive local->remote"
|
|
|
|
scpclean
|
|
|
|
rm -rf ${DIR3}
|
|
|
|
cp ${DATA} ${DIR}/copy
|
|
|
|
cp ${DATA} ${DIR}/copy.glob[1234]
|
|
|
|
$SCP $scpopts -r ${DIR} somehost:${DIR3} || fail "copy failed"
|
2022-10-30 19:42:07 +01:00
|
|
|
diff ${DIFFOPT} ${DIR} ${DIR3} || fail "corrupted copy"
|
2022-10-24 23:52:50 +02:00
|
|
|
|
|
|
|
verbose "$tag: unmatched glob dir recursive remote->local"
|
|
|
|
# NB. no clean
|
|
|
|
rm -rf ${DIR2}
|
|
|
|
$SCP $scpopts -r somehost:${DIR3} ${DIR2} || fail "copy failed"
|
2022-10-30 19:42:07 +01:00
|
|
|
diff ${DIFFOPT} ${DIR} ${DIR2} || fail "corrupted copy"
|
2022-10-24 23:52:50 +02:00
|
|
|
|
2021-08-03 03:05:24 +02:00
|
|
|
verbose "$tag: shell metacharacters"
|
2019-07-19 05:45:44 +02:00
|
|
|
scpclean
|
2021-08-03 03:05:24 +02:00
|
|
|
(cd ${DIR} && \
|
|
|
|
touch '`touch metachartest`' && \
|
|
|
|
$SCP $scpopts *metachar* ${DIR2} 2>/dev/null; \
|
|
|
|
[ ! -f metachartest ] ) || fail "shell metacharacters"
|
|
|
|
|
|
|
|
if [ ! -z "$SUDO" ]; then
|
|
|
|
verbose "$tag: skipped file after scp -p with failed chown+utimes"
|
|
|
|
scpclean
|
|
|
|
cp -p ${DATA} ${DIR}/copy
|
|
|
|
cp -p ${DATA} ${DIR}/copy2
|
|
|
|
cp ${DATA} ${DIR2}/copy
|
|
|
|
chmod 660 ${DIR2}/copy
|
|
|
|
$SUDO chown root ${DIR2}/copy
|
|
|
|
$SCP -p $scpopts somehost:${DIR}/\* ${DIR2} >/dev/null 2>&1
|
|
|
|
$SUDO diff ${DIFFOPT} ${DIR} ${DIR2} || fail "corrupted copy"
|
|
|
|
$SUDO rm ${DIR2}/copy
|
|
|
|
fi
|
|
|
|
|
|
|
|
for i in 0 1 2 3 4 5 6 7; do
|
|
|
|
verbose "$tag: disallow bad server #$i"
|
|
|
|
SCPTESTMODE=badserver_$i
|
|
|
|
export DIR SCPTESTMODE
|
|
|
|
scpclean
|
|
|
|
$SCP $scpopts somehost:${DATA} ${DIR} >/dev/null 2>/dev/null
|
|
|
|
[ -d {$DIR}/rootpathdir ] && fail "allows dir relative to root dir"
|
|
|
|
[ -d ${DIR}/dotpathdir ] && fail "allows dir creation in non-recursive mode"
|
|
|
|
|
|
|
|
scpclean
|
|
|
|
$SCP -r $scpopts somehost:${DATA} ${DIR2} >/dev/null 2>/dev/null
|
|
|
|
[ -d ${DIR}/dotpathdir ] && fail "allows dir creation outside of subdir"
|
|
|
|
|
|
|
|
scpclean
|
|
|
|
$SCP -pr $scpopts somehost:${DATA} ${DIR2} >/dev/null 2>/dev/null
|
|
|
|
[ ! -w ${DIR2} ] && fail "allows target root attribute change"
|
|
|
|
|
|
|
|
scpclean
|
|
|
|
$SCP $scpopts somehost:${DATA} ${DIR2} >/dev/null 2>/dev/null
|
|
|
|
[ -e ${DIR2}/extrafile ] && fail "allows unauth object creation"
|
|
|
|
rm -f ${DIR2}/extrafile
|
|
|
|
done
|
|
|
|
|
|
|
|
verbose "$tag: detect non-directory target"
|
|
|
|
scpclean
|
|
|
|
echo a > ${COPY}
|
|
|
|
echo b > ${COPY2}
|
|
|
|
$SCP $scpopts ${DATA} ${COPY} ${COPY2}
|
|
|
|
cmp ${COPY} ${COPY2} >/dev/null && fail "corrupt target"
|
2004-06-16 12:15:59 +02:00
|
|
|
done
|
|
|
|
|
|
|
|
scpclean
|
2004-08-29 11:39:09 +02:00
|
|
|
rm -f ${OBJ}/scp-ssh-wrapper.scp
|