- djm@cvs.openbsd.org 2008/01/20 00:38:30
[sftp.c] When uploading, correctly handle the case of an unquoted filename with glob metacharacters that match a file exactly but not as a glob, e.g. a file called "[abcd]". report and test cases from duncan2nd AT gmx.de
This commit is contained in:
parent
3dff176ed9
commit
aec5cf8a30
|
@ -44,6 +44,11 @@
|
||||||
[readconf.c readconf.h sshconnect2.c]
|
[readconf.c readconf.h sshconnect2.c]
|
||||||
promote rekeylimit to a int64 so it can hold the maximum useful limit
|
promote rekeylimit to a int64 so it can hold the maximum useful limit
|
||||||
of 2^32; report and patch from Jan.Pechanec AT Sun.COM, ok dtucker@
|
of 2^32; report and patch from Jan.Pechanec AT Sun.COM, ok dtucker@
|
||||||
|
- djm@cvs.openbsd.org 2008/01/20 00:38:30
|
||||||
|
[sftp.c]
|
||||||
|
When uploading, correctly handle the case of an unquoted filename with
|
||||||
|
glob metacharacters that match a file exactly but not as a glob, e.g. a
|
||||||
|
file called "[abcd]". report and test cases from duncan2nd AT gmx.de
|
||||||
|
|
||||||
20080119
|
20080119
|
||||||
- (djm) Silence noice from expr in ssh-copy-id; patch from
|
- (djm) Silence noice from expr in ssh-copy-id; patch from
|
||||||
|
@ -3572,4 +3577,4 @@
|
||||||
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.4828 2008/02/10 11:25:52 djm Exp $
|
$Id: ChangeLog,v 1.4829 2008/02/10 11:26:24 djm Exp $
|
||||||
|
|
24
sftp.c
24
sftp.c
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: sftp.c,v 1.98 2007/12/12 05:04:03 djm Exp $ */
|
/* $OpenBSD: sftp.c,v 1.99 2008/01/20 00:38:30 djm Exp $ */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2001-2004 Damien Miller <djm@openbsd.org>
|
* Copyright (c) 2001-2004 Damien Miller <djm@openbsd.org>
|
||||||
*
|
*
|
||||||
|
@ -433,17 +433,6 @@ is_dir(char *path)
|
||||||
return(S_ISDIR(sb.st_mode));
|
return(S_ISDIR(sb.st_mode));
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
|
||||||
is_reg(char *path)
|
|
||||||
{
|
|
||||||
struct stat sb;
|
|
||||||
|
|
||||||
if (stat(path, &sb) == -1)
|
|
||||||
fatal("stat %s: %s", path, strerror(errno));
|
|
||||||
|
|
||||||
return(S_ISREG(sb.st_mode));
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
remote_is_dir(struct sftp_conn *conn, char *path)
|
remote_is_dir(struct sftp_conn *conn, char *path)
|
||||||
{
|
{
|
||||||
|
@ -532,6 +521,7 @@ process_put(struct sftp_conn *conn, char *src, char *dst, char *pwd, int pflag)
|
||||||
glob_t g;
|
glob_t g;
|
||||||
int err = 0;
|
int err = 0;
|
||||||
int i;
|
int i;
|
||||||
|
struct stat sb;
|
||||||
|
|
||||||
if (dst) {
|
if (dst) {
|
||||||
tmp_dst = xstrdup(dst);
|
tmp_dst = xstrdup(dst);
|
||||||
|
@ -540,7 +530,7 @@ process_put(struct sftp_conn *conn, char *src, char *dst, char *pwd, int pflag)
|
||||||
|
|
||||||
memset(&g, 0, sizeof(g));
|
memset(&g, 0, sizeof(g));
|
||||||
debug3("Looking up %s", src);
|
debug3("Looking up %s", src);
|
||||||
if (glob(src, 0, NULL, &g)) {
|
if (glob(src, GLOB_NOCHECK, NULL, &g)) {
|
||||||
error("File \"%s\" not found.", src);
|
error("File \"%s\" not found.", src);
|
||||||
err = -1;
|
err = -1;
|
||||||
goto out;
|
goto out;
|
||||||
|
@ -555,7 +545,13 @@ process_put(struct sftp_conn *conn, char *src, char *dst, char *pwd, int pflag)
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; g.gl_pathv[i] && !interrupted; i++) {
|
for (i = 0; g.gl_pathv[i] && !interrupted; i++) {
|
||||||
if (!is_reg(g.gl_pathv[i])) {
|
if (stat(g.gl_pathv[i], &sb) == -1) {
|
||||||
|
err = -1;
|
||||||
|
error("stat %s: %s", g.gl_pathv[i], strerror(errno));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!S_ISREG(sb.st_mode)) {
|
||||||
error("skipping non-regular file %s",
|
error("skipping non-regular file %s",
|
||||||
g.gl_pathv[i]);
|
g.gl_pathv[i]);
|
||||||
continue;
|
continue;
|
||||||
|
|
Loading…
Reference in New Issue