summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Frysinger <vapier@gentoo.org>2007-08-12 15:39:54 +0000
committerMike Frysinger <vapier@gentoo.org>2007-08-12 15:39:54 +0000
commit130727ec252c99b7c41170447d440a5184515891 (patch)
tree0a362e84d7e5517ccf65302a398983c6d46a7c14 /net-misc/dropbear/files
parentWhite space fixes. (diff)
downloadhistorical-130727ec252c99b7c41170447d440a5184515891.tar.gz
historical-130727ec252c99b7c41170447d440a5184515891.tar.bz2
historical-130727ec252c99b7c41170447d440a5184515891.zip
old
Diffstat (limited to 'net-misc/dropbear/files')
-rw-r--r--net-misc/dropbear/files/digest-dropbear-0.47-r13
-rw-r--r--net-misc/dropbear/files/digest-dropbear-0.48.13
-rw-r--r--net-misc/dropbear/files/digest-dropbear-0.48.1-r13
-rw-r--r--net-misc/dropbear/files/dropbear-0.47-CVE-2006-0225.patch302
4 files changed, 0 insertions, 311 deletions
diff --git a/net-misc/dropbear/files/digest-dropbear-0.47-r1 b/net-misc/dropbear/files/digest-dropbear-0.47-r1
deleted file mode 100644
index c4f853da552f..000000000000
--- a/net-misc/dropbear/files/digest-dropbear-0.47-r1
+++ /dev/null
@@ -1,3 +0,0 @@
-MD5 cf634614d52278d44dfd9c224a438bf2 dropbear-0.47.tar.bz2 1418374
-RMD160 d36aace7586e76bf21c4b62a090147cebaf85b12 dropbear-0.47.tar.bz2 1418374
-SHA256 8888cf99c10936401b4f47a0d20018f1a006b05d09b2ff5f9d74e6303f9f92a8 dropbear-0.47.tar.bz2 1418374
diff --git a/net-misc/dropbear/files/digest-dropbear-0.48.1 b/net-misc/dropbear/files/digest-dropbear-0.48.1
deleted file mode 100644
index 1887eac5c2f4..000000000000
--- a/net-misc/dropbear/files/digest-dropbear-0.48.1
+++ /dev/null
@@ -1,3 +0,0 @@
-MD5 ca8e53a766faec831882831364568421 dropbear-0.48.1.tar.gz 1473114
-RMD160 055740e5978f91ca34d318e6a6f8052d182e8d7c dropbear-0.48.1.tar.gz 1473114
-SHA256 fa6c3567e293fa0aa249db695b9d5e43ef3f8c11bab74a9b42acc9a0a5c96742 dropbear-0.48.1.tar.gz 1473114
diff --git a/net-misc/dropbear/files/digest-dropbear-0.48.1-r1 b/net-misc/dropbear/files/digest-dropbear-0.48.1-r1
deleted file mode 100644
index 1887eac5c2f4..000000000000
--- a/net-misc/dropbear/files/digest-dropbear-0.48.1-r1
+++ /dev/null
@@ -1,3 +0,0 @@
-MD5 ca8e53a766faec831882831364568421 dropbear-0.48.1.tar.gz 1473114
-RMD160 055740e5978f91ca34d318e6a6f8052d182e8d7c dropbear-0.48.1.tar.gz 1473114
-SHA256 fa6c3567e293fa0aa249db695b9d5e43ef3f8c11bab74a9b42acc9a0a5c96742 dropbear-0.48.1.tar.gz 1473114
diff --git a/net-misc/dropbear/files/dropbear-0.47-CVE-2006-0225.patch b/net-misc/dropbear/files/dropbear-0.47-CVE-2006-0225.patch
deleted file mode 100644
index 5608a05a7916..000000000000
--- a/net-misc/dropbear/files/dropbear-0.47-CVE-2006-0225.patch
+++ /dev/null
@@ -1,302 +0,0 @@
-Index: misc.c
-===================================================================
-RCS file: /cvs/src/usr.bin/ssh/misc.c,v
-retrieving revision 1.41
-retrieving revision 1.42
-diff -u -p -r1.41 -r1.42
---- scpmisc.c 5 Jan 2006 23:43:53 -0000 1.41
-+++ scpmisc.c 31 Jan 2006 10:19:02 -0000 1.42
-@@ -383,12 +383,15 @@ void
- addargs(arglist *args, char *fmt, ...)
- {
- va_list ap;
-- char buf[1024];
-+ char *cp;
-- int nalloc;
-+ u_int nalloc;
-+ int r;
-
- va_start(ap, fmt);
-- vsnprintf(buf, sizeof(buf), fmt, ap);
-+ r = vasprintf(&cp, fmt, ap);
- va_end(ap);
-+ if (r == -1)
-+ fatal("addargs: argument too long");
-
- nalloc = args->nalloc;
- if (args->list == NULL) {
-@@ -399,6 +402,40 @@ addargs(arglist *args, char *fmt, ...)
-
- args->list = xrealloc(args->list, nalloc * sizeof(char *));
- args->nalloc = nalloc;
-- args->list[args->num++] = xstrdup(buf);
-+ args->list[args->num++] = cp;
- args->list[args->num] = NULL;
-+}
-+
-+void
-+replacearg(arglist *args, u_int which, char *fmt, ...)
-+{
-+ va_list ap;
-+ char *cp;
-+ int r;
-+
-+ va_start(ap, fmt);
-+ r = vasprintf(&cp, fmt, ap);
-+ va_end(ap);
-+ if (r == -1)
-+ fatal("replacearg: argument too long");
-+
-+ if (which >= args->num)
-+ fatal("replacearg: tried to replace invalid arg %d >= %d",
-+ which, args->num);
-+ xfree(args->list[which]);
-+ args->list[which] = cp;
-+}
-+
-+void
-+freeargs(arglist *args)
-+{
-+ u_int i;
-+
-+ if (args->list != NULL) {
-+ for (i = 0; i < args->num; i++)
-+ xfree(args->list[i]);
-+ xfree(args->list);
-+ args->nalloc = args->num = 0;
-+ args->list = NULL;
-+ }
- }
-Index: misc.h
-===================================================================
-RCS file: /cvs/src/usr.bin/ssh/misc.h,v
-retrieving revision 1.28
-retrieving revision 1.29
-diff -u -p -r1.28 -r1.29
---- scpmisc.h 8 Dec 2005 18:34:11 -0000 1.28
-+++ scpmisc.h 31 Jan 2006 10:19:02 -0000 1.29
-@@ -38,10 +38,20 @@ struct arglist {
- typedef struct arglist arglist;
- struct arglist {
- char **list;
-- int num;
-- int nalloc;
-+ u_int num;
-+ u_int nalloc;
- };
--void addargs(arglist *, char *, ...);
-+void addargs(arglist *, char *, ...)
-+ __attribute__((format(printf, 2, 3)));
-+void replacearg(arglist *, u_int, char *, ...)
-+ __attribute__((format(printf, 3, 4)));
-+void freeargs(arglist *);
-+
-+#define fatal(fmt, args...) \
-+ do { \
-+ fprintf(stderr, fmt, ## args); \
-+ exit (255); \
-+ } while (0)
-
- /* from xmalloc.h */
- void *xmalloc(size_t);
-Index: scp.c
-===================================================================
-RCS file: /cvs/src/usr.bin/ssh/scp.c,v
-retrieving revision 1.128
-retrieving revision 1.129
-diff -u -p -r1.128 -r1.129
---- scp.c 6 Dec 2005 22:38:27 -0000 1.128
-+++ scp.c 31 Jan 2006 10:19:02 -0000 1.129
-@@ -118,6 +118,48 @@ killchild(int signo)
- _exit(1);
- }
-
-+static int
-+do_local_cmd(arglist *a)
-+{
-+ u_int i;
-+ int status;
-+ pid_t pid;
-+
-+ if (a->num == 0)
-+ fatal("do_local_cmd: no arguments");
-+
-+ if (verbose_mode) {
-+ fprintf(stderr, "Executing:");
-+ for (i = 0; i < a->num; i++)
-+ fprintf(stderr, " %s", a->list[i]);
-+ fprintf(stderr, "\n");
-+ }
-+ if ((pid = fork()) == -1)
-+ fatal("do_local_cmd: fork: %s", strerror(errno));
-+
-+ if (pid == 0) {
-+ execvp(a->list[0], a->list);
-+ perror(a->list[0]);
-+ exit(1);
-+ }
-+
-+ do_cmd_pid = pid;
-+ signal(SIGTERM, killchild);
-+ signal(SIGINT, killchild);
-+ signal(SIGHUP, killchild);
-+
-+ while (waitpid(pid, &status, 0) == -1)
-+ if (errno != EINTR)
-+ fatal("do_local_cmd: waitpid: %s", strerror(errno));
-+
-+ do_cmd_pid = -1;
-+
-+ if (!WIFEXITED(status) || WEXITSTATUS(status) != 0)
-+ return (-1);
-+
-+ return (0);
-+}
-+
- /*
- * This function executes the given command as the specified user on the
- * given host. This returns < 0 if execution fails, and >= 0 otherwise. This
-@@ -162,7 +204,7 @@ do_cmd(char *host, char *remuser, char *
- close(pin[0]);
- close(pout[1]);
-
-- args.list[0] = ssh_program;
-+ replacearg(&args, 0, "%s", ssh_program);
- if (remuser != NULL) {
- addargs(&args, "-l");
- addargs(&args, "%s", remuser);
-@@ -225,8 +267,9 @@ main(int argc, char **argv)
- extern char *optarg;
- extern int optind;
-
-+ memset(&args, '\0', sizeof(args));
- args.list = NULL;
-- addargs(&args, "ssh"); /* overwritten with ssh_program */
-+ addargs(&args, "%s", ssh_program);
- addargs(&args, "-x");
- addargs(&args, "-oForwardAgent no");
- addargs(&args, "-oClearAllForwardings yes");
-@@ -363,6 +406,10 @@ toremote(char *targ, int argc, char **ar
- {
- int i, len;
- char *bp, *host, *src, *suser, *thost, *tuser;
-+ arglist alist;
-+
-+ memset(&alist, '\0', sizeof(alist));
-+ alist.list = NULL;
-
- *targ++ = 0;
- if (*targ == 0)
-@@ -380,55 +427,46 @@ toremote(char *targ, int argc, char **ar
- tuser = NULL;
- }
-
-+ if (tuser != NULL && !okname(tuser))
-+ return;
-+
- for (i = 0; i < argc - 1; i++) {
- src = colon(argv[i]);
- if (src) { /* remote to remote */
-- static char *ssh_options =
-- "-x -o'ClearAllForwardings yes'";
-+ freeargs(&alist);
-+ addargs(&alist, "%s", ssh_program);
-+ if (verbose_mode)
-+ addargs(&alist, "-v");
-+ addargs(&alist, "-x");
-+ addargs(&alist, "-oClearAllForwardings yes");
-+ addargs(&alist, "-n");
-+
- *src++ = 0;
- if (*src == 0)
- src = ".";
- host = strrchr(argv[i], '@');
-- len = strlen(ssh_program) + strlen(argv[i]) +
-- strlen(src) + (tuser ? strlen(tuser) : 0) +
-- strlen(thost) + strlen(targ) +
-- strlen(ssh_options) + CMDNEEDS + 20;
-- bp = xmalloc(len);
-+
- if (host) {
- *host++ = 0;
- host = cleanhostname(host);
- suser = argv[i];
- if (*suser == '\0')
- suser = pwd->pw_name;
-- else if (!okname(suser)) {
-- xfree(bp);
-- continue;
-- }
-- if (tuser && !okname(tuser)) {
-- xfree(bp);
-+ else if (!okname(suser))
- continue;
-- }
-- snprintf(bp, len,
-- "%s%s %s -n "
-- "-l %s %s %s %s '%s%s%s:%s'",
-- ssh_program, verbose_mode ? " -v" : "",
-- ssh_options, suser, host, cmd, src,
-- tuser ? tuser : "", tuser ? "@" : "",
-- thost, targ);
-+ addargs(&alist, "-l");
-+ addargs(&alist, "%s", suser);
- } else {
- host = cleanhostname(argv[i]);
-- snprintf(bp, len,
-- "exec %s%s %s -n %s "
-- "%s %s '%s%s%s:%s'",
-- ssh_program, verbose_mode ? " -v" : "",
-- ssh_options, host, cmd, src,
-- tuser ? tuser : "", tuser ? "@" : "",
-- thost, targ);
- }
-- if (verbose_mode)
-- fprintf(stderr, "Executing: %s\n", bp);
-- (void) system(bp);
-+ addargs(&alist, "%s", host);
-+ addargs(&alist, "%s", cmd);
-+ addargs(&alist, "%s", src);
-+ addargs(&alist, "%s%s%s:%s",
-+ tuser ? tuser : "", tuser ? "@" : "",
-+ thost, targ);
-+ if (do_local_cmd(&alist) != 0)
-+ errs = 1;
-- (void) xfree(bp);
- } else { /* local to remote */
- if (remin == -1) {
- len = strlen(targ) + CMDNEEDS + 20;
-@@ -453,20 +492,23 @@ tolocal(int argc, char **argv)
- {
- int i, len;
- char *bp, *host, *src, *suser;
-+ arglist alist;
-+
-+ memset(&alist, '\0', sizeof(alist));
-+ alist.list = NULL;
-
- for (i = 0; i < argc - 1; i++) {
- if (!(src = colon(argv[i]))) { /* Local to local. */
-- len = strlen(_PATH_CP) + strlen(argv[i]) +
-- strlen(argv[argc - 1]) + 20;
-- bp = xmalloc(len);
-- (void) snprintf(bp, len, "exec %s%s%s %s %s", _PATH_CP,
-- iamrecursive ? " -r" : "", pflag ? " -p" : "",
-- argv[i], argv[argc - 1]);
-- if (verbose_mode)
-- fprintf(stderr, "Executing: %s\n", bp);
-- if (system(bp))
-+ freeargs(&alist);
-+ addargs(&alist, "%s", _PATH_CP);
-+ if (iamrecursive)
-+ addargs(&alist, "-r");
-+ if (pflag)
-+ addargs(&alist, "-p");
-+ addargs(&alist, "%s", argv[i]);
-+ addargs(&alist, "%s", argv[argc-1]);
-+ if (do_local_cmd(&alist))
- ++errs;
-- (void) xfree(bp);
- continue;
- }
- *src++ = 0;