- djm@cvs.openbsd.org 2008/12/09 02:39:59

[sftp.c]
     Deal correctly with failures in remote stat() operation in sftp,
     correcting fail-on-error behaviour in batchmode. bz#1541 report and
     fix from anedvedicky AT gmail.com; ok markus@
This commit is contained in:
Damien Miller 2008-12-09 14:11:49 +11:00
parent 586b00532f
commit 1be2cc4496
2 changed files with 13 additions and 6 deletions

View File

@ -7,6 +7,11 @@
that requested it. Disable it on slave sessions until such time as it that requested it. Disable it on slave sessions until such time as it
is fixed; bz#1543 report from Adrian Bridgett via Colin Watson is fixed; bz#1543 report from Adrian Bridgett via Colin Watson
ok markus@ ok markus@
- djm@cvs.openbsd.org 2008/12/09 02:39:59
[sftp.c]
Deal correctly with failures in remote stat() operation in sftp,
correcting fail-on-error behaviour in batchmode. bz#1541 report and
fix from anedvedicky AT gmail.com; ok markus@
20081208 20081208
- (djm) [configure.ac] bz#1538: better test for ProPolice/SSP: actually - (djm) [configure.ac] bz#1538: better test for ProPolice/SSP: actually
@ -4974,5 +4979,5 @@
OpenServer 6 and add osr5bigcrypt support so when someone migrates OpenServer 6 and add osr5bigcrypt support so when someone migrates
passwords between UnixWare and OpenServer they will still work. OK dtucker@ passwords between UnixWare and OpenServer they will still work. OK dtucker@
$Id: ChangeLog,v 1.5152 2008/12/09 03:11:32 djm Exp $ $Id: ChangeLog,v 1.5153 2008/12/09 03:11:49 djm Exp $

12
sftp.c
View File

@ -1,4 +1,4 @@
/* $OpenBSD: sftp.c,v 1.103 2008/07/13 22:16:03 djm Exp $ */ /* $OpenBSD: sftp.c,v 1.104 2008/12/09 02:39:59 djm Exp $ */
/* /*
* Copyright (c) 2001-2004 Damien Miller <djm@openbsd.org> * Copyright (c) 2001-2004 Damien Miller <djm@openbsd.org>
* *
@ -1386,17 +1386,19 @@ parse_dispatch_command(struct sftp_conn *conn, const char *cmd, char **pwd,
remote_glob(conn, path1, GLOB_NOCHECK, NULL, &g); remote_glob(conn, path1, GLOB_NOCHECK, NULL, &g);
for (i = 0; g.gl_pathv[i] && !interrupted; i++) { for (i = 0; g.gl_pathv[i] && !interrupted; i++) {
if (!(aa = do_stat(conn, g.gl_pathv[i], 0))) { if (!(aa = do_stat(conn, g.gl_pathv[i], 0))) {
if (err != 0 && err_abort) if (err_abort) {
err = -1;
break; break;
else } else
continue; continue;
} }
if (!(aa->flags & SSH2_FILEXFER_ATTR_UIDGID)) { if (!(aa->flags & SSH2_FILEXFER_ATTR_UIDGID)) {
error("Can't get current ownership of " error("Can't get current ownership of "
"remote file \"%s\"", g.gl_pathv[i]); "remote file \"%s\"", g.gl_pathv[i]);
if (err != 0 && err_abort) if (err_abort) {
err = -1;
break; break;
else } else
continue; continue;
} }
aa->flags &= SSH2_FILEXFER_ATTR_UIDGID; aa->flags &= SSH2_FILEXFER_ATTR_UIDGID;