summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaweł Hajdan <phajdan.jr@gentoo.org>2010-02-12 10:00:24 +0000
committerPaweł Hajdan <phajdan.jr@gentoo.org>2010-02-12 10:00:24 +0000
commitb12d0a9cc7f5cd11a2056d9ec6bc10b49de5277a (patch)
treebb5f192ddf5d46e6c697c4cb412ffcfc07353d43 /sys-auth/tcb/files
parentversion bump (#297289) - dont pre-strip (#297989) (diff)
downloadgentoo-2-b12d0a9cc7f5cd11a2056d9ec6bc10b49de5277a.tar.gz
gentoo-2-b12d0a9cc7f5cd11a2056d9ec6bc10b49de5277a.tar.bz2
gentoo-2-b12d0a9cc7f5cd11a2056d9ec6bc10b49de5277a.zip
Version bump. Remove old. Update the compatibility patch. Drop old patches.
(Portage version: 2.1.7.16/cvs/Linux i686)
Diffstat (limited to 'sys-auth/tcb/files')
-rw-r--r--sys-auth/tcb/files/tcb-1.0.2-build.patch37
-rw-r--r--sys-auth/tcb/files/tcb-gentoo.patch162
-rw-r--r--sys-auth/tcb/files/tcb-xcrypt.patch50
3 files changed, 58 insertions, 191 deletions
diff --git a/sys-auth/tcb/files/tcb-1.0.2-build.patch b/sys-auth/tcb/files/tcb-1.0.2-build.patch
deleted file mode 100644
index 60cc1c519354..000000000000
--- a/sys-auth/tcb/files/tcb-1.0.2-build.patch
+++ /dev/null
@@ -1,37 +0,0 @@
---- tcb-1.0/libs/Makefile
-+++ tcb-1.0/libs/Makefile
-@@ -17,13 +17,13 @@
- $(CC) $(CFLAGS) $(DBGFLAG) -c $< -o $@
-
- $(LIBTCB_LONG): libtcb.o $(LIB_MAP)
-- $(CC) $(DBGFLAG) -shared -o $@ -Wl,-soname,$(LIBTCB) \
-+ $(CC) $(LDFLAGS) $(DBGFLAG) -shared -o $@ -Wl,-soname,$(LIBTCB) \
- -Wl,--version-script=$(LIB_MAP) $< -lc
- ln -sf $@ $(LIBTCB)
- ln -sf $(LIBTCB) libtcb.so
-
- $(LIBNSS): nss.o $(NSS_MAP) $(LIBTCB_LONG)
-- $(CC) $(DBGFLAG) -shared -o $@ -Wl,--version-script=$(NSS_MAP) \
-+ $(CC) $(LDFLAGS) $(DBGFLAG) -shared -o $@ -Wl,-soname,$@ -Wl,--version-script=$(NSS_MAP) \
- $< -L. $(LIBNSL) -ltcb
-
- .c.o:
---- tcb-1.0/progs/Makefile
-+++ tcb-1.0/progs/Makefile
-@@ -7,13 +7,13 @@
- all: $(CONVERT) $(UNCONVERT) $(CHKPWD)
-
- $(CONVERT): $(CONVERT).o
-- $(CC) -o $@ $<
-+ $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $<
-
- $(UNCONVERT): $(UNCONVERT).o
-- $(CC) -o $@ $< -L../libs -ltcb
-+ $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $< -L../libs -ltcb
-
- $(CHKPWD): $(CHKPWD).o
-- $(CC) -o $@ $< -lcrypt
-+ $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $< -lcrypt
-
- .c.o:
- $(CC) $(CFLAGS) -c $< -o $@
diff --git a/sys-auth/tcb/files/tcb-gentoo.patch b/sys-auth/tcb/files/tcb-gentoo.patch
index ee681854f784..3cdab6e25879 100644
--- a/sys-auth/tcb/files/tcb-gentoo.patch
+++ b/sys-auth/tcb/files/tcb-gentoo.patch
@@ -1,121 +1,51 @@
--- pam_tcb/support.c.orig 2010-01-17 12:22:29.000000000 +0100
-+++ pam_tcb/support.c 2010-01-17 15:47:38.000000000 +0100
-@@ -466,6 +466,39 @@
++++ pam_tcb/support.c 2010-02-12 10:47:37.000000000 +0100
+@@ -466,6 +466,44 @@
return retval;
}
-+static char i64c(int i)
-+{
-+ if (i < 0)
-+ return '.';
-+ if (i > 63)
-+ return 'z';
-+
-+ if (i == 0)
-+ return '.';
-+ if (i == 1)
-+ return '/';
-+ if (i >= 2 && i <= 11)
-+ return ('0' - 2 + i);
-+ if (i >= 12 && i <= 37)
-+ return ('A' - 12 + i);
-+ if (i >= 38 && i <= 63)
-+ return ('a' - 38 + i);
-+
-+ return '\0';
-+}
++static unsigned char _crypt_itoa64[64 + 1] =
++ "./0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
+
-+static char *make_salt(const char *prefix, const char *entropy,
-+ int entropy_size)
++static char *crypt_gensalt_ra(const char *prefix, unsigned long count,
++ const char *entropy, int entropy_size)
+{
-+ char salt[64];
++ if (count != 0)
++ return NULL;
++ if (entropy_size < 3)
++ return NULL;
++ char* salt = malloc(strlen(prefix) + entropy_size/3*4 + 1);
++ if (!salt)
++ return NULL;
+ char *sp = stpcpy(salt, prefix);
+ int i;
-+ for (i = 0; i < entropy_size / 2; i++)
-+ *sp++ = i64c(entropy[i] & 077);
++ for (i = 0; entropy_size >= 3 * (i + 1); i++) {
++ unsigned long value =
++ ((unsigned long)(unsigned char)entropy[3 * i]) |
++ ((unsigned long)(unsigned char)entropy[3 * i + 1] << 8) |
++ ((unsigned long)(unsigned char)entropy[3 * i + 2] << 16);
++ *sp++ = _crypt_itoa64[value & 0x3f];
++ *sp++ = _crypt_itoa64[(value >> 6) & 0x3f];
++ *sp++ = _crypt_itoa64[(value >> 12) & 0x3f];
++ *sp++ = _crypt_itoa64[(value >> 18) & 0x3f];
++ }
+ *sp = '\0';
-+ return strdup(salt);
++ return salt;
++}
++
++static char *crypt_ra(const char *key, const char *salt,
++ void **data, int *size)
++{
++ *size = sizeof(struct crypt_data);
++ if (!(*data = calloc(1, *size)))
++ return NULL;
++ return crypt_r(key, salt, *data);
+}
+
static int check_crypt(pam_handle_t *pamh, const char *pass,
const char *stored_hash)
{
-@@ -481,11 +514,11 @@
-
- /* This exists because of timing attacks. */
- memset(input, 0x55, sizeof(input));
-- fake_salt = crypt_gensalt_ra(pam_unix_param.crypt_prefix,
-- pam_unix_param.count, input, sizeof(input));
-+ fake_salt = make_salt(pam_unix_param.crypt_prefix,
-+ input, sizeof(input));
-
- if (!fake_salt) {
-- pam_syslog(pamh, LOG_CRIT, "crypt_gensalt_ra: %m");
-+ pam_syslog(pamh, LOG_CRIT, "make_salt: %m");
- return PAM_BUF_ERR;
- }
-
-@@ -816,22 +849,21 @@
- return PAM_SUCCESS;
- }
-
--static char *crypt_wrapper_ra(pam_handle_t *pamh, const char *key,
-+static char *crypt_wrapper_r(pam_handle_t *pamh, const char *key,
- const char *salt)
- {
-- char *retval;
-- void *data = NULL;
-- int size = 0;
-+ char *retval = NULL;
-+ struct crypt_data *cdata = malloc(sizeof(*cdata));
-
-- retval = crypt_ra(key, salt, &data, &size);
-- if (retval)
-- retval = strdup(retval); /* we return NULL if strdup fails */
-- else
-- pam_syslog(pamh, LOG_CRIT, "crypt_ra: %m");
-- if (data) {
-- memset(data, 0, size);
-- free(data);
-+ if (cdata != NULL) {
-+ cdata->initialized = 0;
-+ retval = strdup(crypt_r(key, salt, cdata));
-+ if (!retval)
-+ pam_syslog(pamh, LOG_CRIT, "crypt_r: %m");
-+ memset(cdata, '\0', sizeof(*cdata));
-+ free(cdata);
- }
-+
- return retval;
- }
-
-@@ -841,7 +873,7 @@
- char *retval;
-
- if (off(UNIX_PLAIN_CRYPT))
-- return crypt_wrapper_ra(pamh, key, salt);
-+ return crypt_wrapper_r(pamh, key, salt);
-
- errno = 0;
- retval = crypt(key, salt);
-@@ -873,13 +905,13 @@
- }
- close(fd);
-
-- salt = crypt_gensalt_ra(pam_unix_param.crypt_prefix,
-- pam_unix_param.count, entropy, sizeof(entropy));
-+ salt = make_salt(pam_unix_param.crypt_prefix,
-+ entropy, sizeof(entropy));
-
- memset(entropy, 0, sizeof(entropy));
-
- if (!salt) {
-- pam_syslog(pamh, LOG_CRIT, "crypt_gensalt_ra: %m");
-+ pam_syslog(pamh, LOG_CRIT, "make_salt: %m");
- return NULL;
- }
-
-@@ -1019,7 +1051,7 @@
+@@ -1019,28 +1057,16 @@
if (!parse_opt(pamh, *argv, the_cmdline_opts))
return 0;
param = get_optval("prefix=", the_cmdline_opts);
@@ -124,3 +54,27 @@
param = get_optval("helper=", the_cmdline_opts);
pam_unix_param.helper = param ?: CHKPWD_HELPER;
+
+ param = get_optval("count=", the_cmdline_opts);
+ if (param) {
+- char *end;
+- /*
+- * SUSv2 says:
+- * Because 0 and ULONG_MAX are returned on error and
+- * are also valid returns on success, an application
+- * wishing to check for error situations should set
+- * errno to 0, then call strtoul(), then check errno.
+- */
+- errno = 0;
+- pam_unix_param.count = strtoul(param, &end, 10);
+- if (errno || !*param || *end) {
+- pam_syslog(pamh, LOG_ERR,
+- "Invalid count= argument: %s", param);
+- return 0;
+- }
++ pam_syslog(pamh, LOG_ERR,
++ "count= parameter is not supported without Openwall libcrypt extensions");
++ return 0;
+ } else
+ pam_unix_param.count = 0;
+
diff --git a/sys-auth/tcb/files/tcb-xcrypt.patch b/sys-auth/tcb/files/tcb-xcrypt.patch
deleted file mode 100644
index ec7f08c0b37b..000000000000
--- a/sys-auth/tcb/files/tcb-xcrypt.patch
+++ /dev/null
@@ -1,50 +0,0 @@
---- pam_tcb/support.c.orig 2009-12-27 16:33:28.000000000 +0100
-+++ pam_tcb/support.c 2009-12-27 16:34:03.000000000 +0100
-@@ -10,7 +10,7 @@
- #include <signal.h>
- #include <pwd.h>
- #include <shadow.h>
--#include <crypt.h>
-+#include <xcrypt.h>
- #include <sys/types.h>
- #include <sys/wait.h>
- #include <rpcsvc/ypclnt.h>
-@@ -481,11 +481,11 @@
-
- /* This exists because of timing attacks. */
- memset(input, 0x55, sizeof(input));
-- fake_salt = crypt_gensalt_ra(pam_unix_param.crypt_prefix,
-+ fake_salt = xcrypt_gensalt_ra(pam_unix_param.crypt_prefix,
- pam_unix_param.count, input, sizeof(input));
-
- if (!fake_salt) {
-- pam_syslog(pamh, LOG_CRIT, "crypt_gensalt_ra: %m");
-+ pam_syslog(pamh, LOG_CRIT, "xcrypt_gensalt_ra: %m");
- return PAM_BUF_ERR;
- }
-
-@@ -823,11 +823,11 @@
- void *data = NULL;
- int size = 0;
-
-- retval = crypt_ra(key, salt, &data, &size);
-+ retval = xcrypt_ra(key, salt, &data, &size);
- if (retval)
- retval = strdup(retval); /* we return NULL if strdup fails */
- else
-- pam_syslog(pamh, LOG_CRIT, "crypt_ra: %m");
-+ pam_syslog(pamh, LOG_CRIT, "xcrypt_ra: %m");
- if (data) {
- memset(data, 0, size);
- free(data);
---- pam_tcb/Makefile.orig 2009-12-27 16:38:53.000000000 +0100
-+++ pam_tcb/Makefile 2009-12-27 16:39:10.000000000 +0100
-@@ -13,7 +13,7 @@
-
- $(PAM_TCB): $(LIBOBJ) $(PAM_MAP)
- $(CC) $(LDFLAGS) -shared -o $@ -Wl,--version-script=$(PAM_MAP) \
-- $(LIBOBJ) -lnsl -lcrypt -lpam -ltcb
-+ $(LIBOBJ) -lnsl -lxcrypt -lpam -ltcb
-
- .c.o:
- $(CC) $(CFLAGS) -fPIC -c $< -o $@