blob: 1c67b64766383fdd55ae415453ab47e3bfb2018b [file] [log] [blame]
Darren Tuckerbf5fec12010-12-05 10:34:08 +11001# $OpenBSD: sftp-cmds.sh,v 1.11 2010/12/04 00:21:19 djm Exp $
Damien Miller8b9cde72003-01-22 17:53:16 +11002# Placed in the Public Domain.
3
4# XXX - TODO:
Damien Miller8b9cde72003-01-22 17:53:16 +11005# - chmod / chown / chgrp
6# - -p flag for get & put
7
8tid="sftp commands"
9
Darren Tuckerc2c42232003-09-04 14:54:39 +100010DATA=/bin/ls${EXEEXT}
Damien Miller8b9cde72003-01-22 17:53:16 +110011COPY=${OBJ}/copy
Darren Tucker933e4f12003-09-04 14:26:31 +100012# test that these files are readable!
13for i in `(cd /bin;echo l*)`
14do
15 if [ -r $i ]; then
16 GLOBFILES="$GLOBFILES $i"
17 fi
18done
19
Tim Rice23ee3592003-09-11 22:32:17 -070020if have_prog uname
Darren Tuckere7f75802003-09-07 09:32:58 +100021then
22 case `uname` in
23 CYGWIN*)
24 os=cygwin
25 ;;
26 *)
27 os=`uname`
28 ;;
29 esac
30else
31 os="unknown"
32fi
33
Darren Tuckercca1bdb2003-07-19 20:11:54 +100034# Path with embedded quote
35QUOTECOPY=${COPY}".\"blah\""
36QUOTECOPY_ARG=${COPY}'.\"blah\"'
Damien Millerce0e60e2007-10-26 14:54:12 +100037# File with spaces
38SPACECOPY="${COPY} this has spaces.txt"
39SPACECOPY_ARG="${COPY}\ this\ has\ spaces.txt"
40# File with glob metacharacters
41GLOBMETACOPY="${COPY} [metachar].txt"
Darren Tuckercca1bdb2003-07-19 20:11:54 +100042
Darren Tuckered6b0c52009-10-07 10:43:57 +110043rm -rf ${COPY} ${COPY}.1 ${COPY}.2 ${COPY}.dd ${COPY}.dd2 ${BATCH}.*
Darren Tuckerc43362c2003-06-18 22:41:41 +100044mkdir ${COPY}.dd
Damien Miller8b9cde72003-01-22 17:53:16 +110045
46verbose "$tid: lls"
Darren Tuckered6b0c52009-10-07 10:43:57 +110047(echo "lcd ${OBJ}" ; echo "lls") | ${SFTP} -D ${SFTPSERVER} 2>&1 | \
Tim Ricedce65cf2008-03-13 18:21:06 -070048 grep copy.dd >/dev/null 2>&1 || fail "lls failed"
Damien Miller4cd5fba2008-03-12 23:59:43 +110049
50verbose "$tid: lls w/path"
Darren Tuckered6b0c52009-10-07 10:43:57 +110051echo "lls ${OBJ}" | ${SFTP} -D ${SFTPSERVER} 2>&1 | \
Tim Ricedce65cf2008-03-13 18:21:06 -070052 grep copy.dd >/dev/null 2>&1 || fail "lls w/path failed"
Damien Miller8b9cde72003-01-22 17:53:16 +110053
54verbose "$tid: ls"
Darren Tuckered6b0c52009-10-07 10:43:57 +110055echo "ls ${OBJ}" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Miller8b9cde72003-01-22 17:53:16 +110056 || fail "ls failed"
57# XXX always successful
58
59verbose "$tid: shell"
Darren Tuckered6b0c52009-10-07 10:43:57 +110060echo "!echo hi there" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Miller8b9cde72003-01-22 17:53:16 +110061 || fail "shell failed"
62# XXX always successful
63
64verbose "$tid: pwd"
Darren Tuckered6b0c52009-10-07 10:43:57 +110065echo "pwd" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Miller8b9cde72003-01-22 17:53:16 +110066 || fail "pwd failed"
67# XXX always successful
68
69verbose "$tid: lpwd"
Darren Tuckered6b0c52009-10-07 10:43:57 +110070echo "lpwd" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Miller8b9cde72003-01-22 17:53:16 +110071 || fail "lpwd failed"
72# XXX always successful
73
74verbose "$tid: quit"
Darren Tuckered6b0c52009-10-07 10:43:57 +110075echo "quit" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Miller8b9cde72003-01-22 17:53:16 +110076 || fail "quit failed"
77# XXX always successful
78
79verbose "$tid: help"
Darren Tuckered6b0c52009-10-07 10:43:57 +110080echo "help" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Miller8b9cde72003-01-22 17:53:16 +110081 || fail "help failed"
82# XXX always successful
83
84rm -f ${COPY}
85verbose "$tid: get"
Darren Tuckered6b0c52009-10-07 10:43:57 +110086echo "get $DATA $COPY" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Miller8b9cde72003-01-22 17:53:16 +110087 || fail "get failed"
88cmp $DATA ${COPY} || fail "corrupted copy after get"
89
Darren Tucker0240ff72003-10-08 17:52:10 +100090rm -f ${COPY}
91verbose "$tid: get quoted"
Darren Tuckered6b0c52009-10-07 10:43:57 +110092echo "get \"$DATA\" $COPY" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Darren Tucker0240ff72003-10-08 17:52:10 +100093 || fail "get failed"
94cmp $DATA ${COPY} || fail "corrupted copy after get"
95
Darren Tuckerc99a19b2004-04-16 17:58:28 +100096if [ "$os" != "cygwin" ]; then
Darren Tucker0240ff72003-10-08 17:52:10 +100097rm -f ${QUOTECOPY}
98cp $DATA ${QUOTECOPY}
99verbose "$tid: get filename with quotes"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100100echo "get \"$QUOTECOPY_ARG\" ${COPY}" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
101 || fail "get failed"
Darren Tucker0240ff72003-10-08 17:52:10 +1000102cmp ${COPY} ${QUOTECOPY} || fail "corrupted copy after get with quotes"
103rm -f ${QUOTECOPY} ${COPY}
Darren Tuckerc99a19b2004-04-16 17:58:28 +1000104fi
Darren Tucker0240ff72003-10-08 17:52:10 +1000105
Damien Millerce0e60e2007-10-26 14:54:12 +1000106rm -f "$SPACECOPY" ${COPY}
107cp $DATA "$SPACECOPY"
108verbose "$tid: get filename with spaces"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100109echo "get ${SPACECOPY_ARG} ${COPY}" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Millerce0e60e2007-10-26 14:54:12 +1000110 || fail "get failed"
111cmp ${COPY} "$SPACECOPY" || fail "corrupted copy after get with spaces"
112
113rm -f "$GLOBMETACOPY" ${COPY}
114cp $DATA "$GLOBMETACOPY"
115verbose "$tid: get filename with glob metacharacters"
116echo "get \"${GLOBMETACOPY}\" ${COPY}" | \
Darren Tuckered6b0c52009-10-07 10:43:57 +1100117 ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 || fail "get failed"
Damien Millerce0e60e2007-10-26 14:54:12 +1000118cmp ${COPY} "$GLOBMETACOPY" || \
119 fail "corrupted copy after get with glob metacharacters"
120
Darren Tuckerc43362c2003-06-18 22:41:41 +1000121rm -f ${COPY}.dd/*
122verbose "$tid: get to directory"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100123echo "get $DATA ${COPY}.dd" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Darren Tuckerc43362c2003-06-18 22:41:41 +1000124 || fail "get failed"
Darren Tuckerc2c42232003-09-04 14:54:39 +1000125cmp $DATA ${COPY}.dd/`basename $DATA` || fail "corrupted copy after get"
Darren Tuckerc43362c2003-06-18 22:41:41 +1000126
127rm -f ${COPY}.dd/*
128verbose "$tid: glob get to directory"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100129echo "get /bin/l* ${COPY}.dd" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Darren Tuckerc43362c2003-06-18 22:41:41 +1000130 || fail "get failed"
131for x in $GLOBFILES; do
132 cmp /bin/$x ${COPY}.dd/$x || fail "corrupted copy after get"
133done
134
135rm -f ${COPY}.dd/*
136verbose "$tid: get to local dir"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100137(echo "lcd ${COPY}.dd"; echo "get $DATA" ) | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Darren Tuckerc43362c2003-06-18 22:41:41 +1000138 || fail "get failed"
Darren Tuckerc2c42232003-09-04 14:54:39 +1000139cmp $DATA ${COPY}.dd/`basename $DATA` || fail "corrupted copy after get"
Darren Tuckerc43362c2003-06-18 22:41:41 +1000140
141rm -f ${COPY}.dd/*
142verbose "$tid: glob get to local dir"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100143(echo "lcd ${COPY}.dd"; echo "get /bin/l*") | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Darren Tuckerc43362c2003-06-18 22:41:41 +1000144 || fail "get failed"
145for x in $GLOBFILES; do
146 cmp /bin/$x ${COPY}.dd/$x || fail "corrupted copy after get"
147done
148
Damien Miller8b9cde72003-01-22 17:53:16 +1100149rm -f ${COPY}
150verbose "$tid: put"
Damien Millerce0e60e2007-10-26 14:54:12 +1000151echo "put $DATA $COPY" | \
Darren Tuckered6b0c52009-10-07 10:43:57 +1100152 ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 || fail "put failed"
Damien Miller8b9cde72003-01-22 17:53:16 +1100153cmp $DATA ${COPY} || fail "corrupted copy after put"
154
Darren Tuckere7f75802003-09-07 09:32:58 +1000155if [ "$os" != "cygwin" ]; then
Darren Tuckercca1bdb2003-07-19 20:11:54 +1000156rm -f ${QUOTECOPY}
157verbose "$tid: put filename with quotes"
Damien Millerce0e60e2007-10-26 14:54:12 +1000158echo "put $DATA \"$QUOTECOPY_ARG\"" | \
Darren Tuckered6b0c52009-10-07 10:43:57 +1100159 ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 || fail "put failed"
Darren Tuckercca1bdb2003-07-19 20:11:54 +1000160cmp $DATA ${QUOTECOPY} || fail "corrupted copy after put with quotes"
Darren Tuckere7f75802003-09-07 09:32:58 +1000161fi
Darren Tuckercca1bdb2003-07-19 20:11:54 +1000162
Damien Millerce0e60e2007-10-26 14:54:12 +1000163rm -f "$SPACECOPY"
164verbose "$tid: put filename with spaces"
165echo "put $DATA ${SPACECOPY_ARG}" | \
Darren Tuckered6b0c52009-10-07 10:43:57 +1100166 ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 || fail "put failed"
Damien Millerce0e60e2007-10-26 14:54:12 +1000167cmp $DATA "$SPACECOPY" || fail "corrupted copy after put with spaces"
168
Darren Tuckerc43362c2003-06-18 22:41:41 +1000169rm -f ${COPY}.dd/*
170verbose "$tid: put to directory"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100171echo "put $DATA ${COPY}.dd" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Darren Tuckerc43362c2003-06-18 22:41:41 +1000172 || fail "put failed"
Darren Tuckerc2c42232003-09-04 14:54:39 +1000173cmp $DATA ${COPY}.dd/`basename $DATA` || fail "corrupted copy after put"
Darren Tuckerc43362c2003-06-18 22:41:41 +1000174
175rm -f ${COPY}.dd/*
176verbose "$tid: glob put to directory"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100177echo "put /bin/l? ${COPY}.dd" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Darren Tuckerc43362c2003-06-18 22:41:41 +1000178 || fail "put failed"
179for x in $GLOBFILES; do
180 cmp /bin/$x ${COPY}.dd/$x || fail "corrupted copy after put"
181done
182
183rm -f ${COPY}.dd/*
184verbose "$tid: put to local dir"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100185(echo "cd ${COPY}.dd"; echo "put $DATA") | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Darren Tuckerc43362c2003-06-18 22:41:41 +1000186 || fail "put failed"
Darren Tuckerc2c42232003-09-04 14:54:39 +1000187cmp $DATA ${COPY}.dd/`basename $DATA` || fail "corrupted copy after put"
Darren Tuckerc43362c2003-06-18 22:41:41 +1000188
189rm -f ${COPY}.dd/*
190verbose "$tid: glob put to local dir"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100191(echo "cd ${COPY}.dd"; echo "put /bin/l?") | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Darren Tuckerc43362c2003-06-18 22:41:41 +1000192 || fail "put failed"
193for x in $GLOBFILES; do
194 cmp /bin/$x ${COPY}.dd/$x || fail "corrupted copy after put"
195done
196
Damien Miller8b9cde72003-01-22 17:53:16 +1100197verbose "$tid: rename"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100198echo "rename $COPY ${COPY}.1" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Miller8b9cde72003-01-22 17:53:16 +1100199 || fail "rename failed"
200test -f ${COPY}.1 || fail "missing file after rename"
201cmp $DATA ${COPY}.1 >/dev/null 2>&1 || fail "corrupted copy after rename"
202
Darren Tuckera4040f52003-06-18 22:35:11 +1000203verbose "$tid: rename directory"
Damien Millerce0e60e2007-10-26 14:54:12 +1000204echo "rename ${COPY}.dd ${COPY}.dd2" | \
Darren Tuckered6b0c52009-10-07 10:43:57 +1100205 ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 || \
Damien Millerce0e60e2007-10-26 14:54:12 +1000206 fail "rename directory failed"
Darren Tuckera4040f52003-06-18 22:35:11 +1000207test -d ${COPY}.dd && fail "oldname exists after rename directory"
208test -d ${COPY}.dd2 || fail "missing newname after rename directory"
209
Damien Miller8b9cde72003-01-22 17:53:16 +1100210verbose "$tid: ln"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100211echo "ln ${COPY}.1 ${COPY}.2" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 || fail "ln failed"
Darren Tucker4288c532010-12-05 09:45:50 +1100212test -f ${COPY}.2 || fail "missing file after ln"
213cmp ${COPY}.1 ${COPY}.2 || fail "created file is not equal after ln"
214
215verbose "$tid: ln -s"
216rm -f ${COPY}.2
217echo "ln -s ${COPY}.1 ${COPY}.2" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 || fail "ln -s failed"
218test -h ${COPY}.2 || fail "missing file after ln -s"
Damien Miller8b9cde72003-01-22 17:53:16 +1100219
220verbose "$tid: mkdir"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100221echo "mkdir ${COPY}.dd" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Miller8b9cde72003-01-22 17:53:16 +1100222 || fail "mkdir failed"
223test -d ${COPY}.dd || fail "missing directory after mkdir"
224
225# XXX do more here
226verbose "$tid: chdir"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100227echo "chdir ${COPY}.dd" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Miller8b9cde72003-01-22 17:53:16 +1100228 || fail "chdir failed"
229
230verbose "$tid: rmdir"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100231echo "rmdir ${COPY}.dd" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Miller8b9cde72003-01-22 17:53:16 +1100232 || fail "rmdir failed"
233test -d ${COPY}.1 && fail "present directory after rmdir"
234
235verbose "$tid: lmkdir"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100236echo "lmkdir ${COPY}.dd" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Miller8b9cde72003-01-22 17:53:16 +1100237 || fail "lmkdir failed"
238test -d ${COPY}.dd || fail "missing directory after lmkdir"
239
240# XXX do more here
241verbose "$tid: lchdir"
Darren Tuckered6b0c52009-10-07 10:43:57 +1100242echo "lchdir ${COPY}.dd" | ${SFTP} -D ${SFTPSERVER} >/dev/null 2>&1 \
Damien Miller8b9cde72003-01-22 17:53:16 +1100243 || fail "lchdir failed"
244
Darren Tuckered6b0c52009-10-07 10:43:57 +1100245rm -rf ${COPY} ${COPY}.1 ${COPY}.2 ${COPY}.dd ${COPY}.dd2 ${BATCH}.*
Damien Millerce0e60e2007-10-26 14:54:12 +1000246rm -rf ${QUOTECOPY} "$SPACECOPY" "$GLOBMETACOPY"
Damien Miller8b9cde72003-01-22 17:53:16 +1100247
Darren Tuckered6b0c52009-10-07 10:43:57 +1100248