summaryrefslogtreecommitdiffstats
path: root/libmisc/obscure.c
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-26 16:18:36 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-26 16:18:36 +0000
commit6c3ea4f47ea280811a7fe53a22f7832e4533c9ec (patch)
tree3d7ed5da23b5dbf6f9e450dfb61642832249c31e /libmisc/obscure.c
parentAdding upstream version 1:4.13+dfsg1. (diff)
downloadshadow-upstream/1%4.15.2.tar.xz
shadow-upstream/1%4.15.2.zip
Adding upstream version 1:4.15.2.upstream/1%4.15.2upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'libmisc/obscure.c')
-rw-r--r--libmisc/obscure.c306
1 files changed, 0 insertions, 306 deletions
diff --git a/libmisc/obscure.c b/libmisc/obscure.c
deleted file mode 100644
index 3daaa95..0000000
--- a/libmisc/obscure.c
+++ /dev/null
@@ -1,306 +0,0 @@
-/*
- * SPDX-FileCopyrightText: 1989 - 1994, Julianne Frances Haugh
- * SPDX-FileCopyrightText: 1996 - 1999, Marek Michałkiewicz
- * SPDX-FileCopyrightText: 2003 - 2005, Tomasz Kłoczko
- * SPDX-FileCopyrightText: 2007 - 2010, Nicolas François
- *
- * SPDX-License-Identifier: BSD-3-Clause
- */
-
-#include <config.h>
-
-#ifndef USE_PAM
-
-#ident "$Id$"
-
-
-/*
- * This version of obscure.c contains modifications to support "cracklib"
- * by Alec Muffet (alec.muffett@uk.sun.com). You must obtain the Cracklib
- * library source code for this function to operate.
- */
-#include <ctype.h>
-#include <stdio.h>
-#include "prototypes.h"
-#include "defines.h"
-#include "getdef.h"
-/*
- * can't be a palindrome - like `R A D A R' or `M A D A M'
- */
-static bool palindrome (unused const char *old, const char *new)
-{
- size_t i, j;
-
- i = strlen (new);
-
- for (j = 0; j < i; j++) {
- if (new[i - j - 1] != new[j]) {
- return false;
- }
- }
-
- return true;
-}
-
-/*
- * more than half of the characters are different ones.
- */
-
-static bool similar (/*@notnull@*/const char *old, /*@notnull@*/const char *new)
-{
- int i, j;
-
- /*
- * XXX - sometimes this fails when changing from a simple password
- * to a really long one (MD5). For now, I just return success if
- * the new password is long enough. Please feel free to suggest
- * something better... --marekm
- */
- if (strlen (new) >= 8) {
- return false;
- }
-
- for (i = j = 0; ('\0' != new[i]) && ('\0' != old[i]); i++) {
- if (strchr (new, old[i]) != NULL) {
- j++;
- }
- }
-
- if (i >= j * 2) {
- return false;
- }
-
- return true;
-}
-
-/*
- * a nice mix of characters.
- */
-
-static bool simple (unused const char *old, const char *new)
-{
- bool digits = false;
- bool uppers = false;
- bool lowers = false;
- bool others = false;
- int size;
- int i;
-
- for (i = 0; '\0' != new[i]; i++) {
- if (isdigit (new[i])) {
- digits = true;
- } else if (isupper (new[i])) {
- uppers = true;
- } else if (islower (new[i])) {
- lowers = true;
- } else {
- others = true;
- }
- }
-
- /*
- * The scam is this - a password of only one character type
- * must be 8 letters long. Two types, 7, and so on.
- */
-
- size = 9;
- if (digits) {
- size--;
- }
- if (uppers) {
- size--;
- }
- if (lowers) {
- size--;
- }
- if (others) {
- size--;
- }
-
- if (size <= i) {
- return false;
- }
-
- return true;
-}
-
-static char *str_lower (/*@returned@*/char *string)
-{
- char *cp;
-
- for (cp = string; '\0' != *cp; cp++) {
- *cp = tolower (*cp);
- }
- return string;
-}
-
-static /*@observer@*//*@null@*/const char *password_check (
- /*@notnull@*/const char *old,
- /*@notnull@*/const char *new,
- /*@notnull@*/const struct passwd *pwdp)
-{
- const char *msg = NULL;
- char *oldmono, *newmono, *wrapped;
-
-#ifdef HAVE_LIBCRACK
- char *dictpath;
-
-#ifdef HAVE_LIBCRACK_PW
- char *FascistCheckPw ();
-#else
- char *FascistCheck ();
-#endif
-#endif
-
- if (strcmp (new, old) == 0) {
- return _("no change");
- }
-
- newmono = str_lower (xstrdup (new));
- oldmono = str_lower (xstrdup (old));
- wrapped = xmalloc (strlen (oldmono) * 2 + 1);
- strcpy (wrapped, oldmono);
- strcat (wrapped, oldmono);
-
- if (palindrome (oldmono, newmono)) {
- msg = _("a palindrome");
- } else if (strcmp (oldmono, newmono) == 0) {
- msg = _("case changes only");
- } else if (similar (oldmono, newmono)) {
- msg = _("too similar");
- } else if (simple (old, new)) {
- msg = _("too simple");
- } else if (strstr (wrapped, newmono) != NULL) {
- msg = _("rotated");
- } else {
-#ifdef HAVE_LIBCRACK
- /*
- * Invoke Alec Muffett's cracklib routines.
- */
-
- dictpath = getdef_str ("CRACKLIB_DICTPATH");
- if (NULL != dictpath) {
-#ifdef HAVE_LIBCRACK_PW
- msg = FascistCheckPw (new, dictpath, pwdp);
-#else
- msg = FascistCheck (new, dictpath);
-#endif
- }
-#endif
- }
- strzero (newmono);
- strzero (oldmono);
- strzero (wrapped);
- free (newmono);
- free (oldmono);
- free (wrapped);
-
- return msg;
-}
-
-static /*@observer@*//*@null@*/const char *obscure_msg (
- /*@notnull@*/const char *old,
- /*@notnull@*/const char *new,
- /*@notnull@*/const struct passwd *pwdp)
-{
- size_t maxlen, oldlen, newlen;
- char *new1, *old1;
- const char *msg;
- const char *result;
-
- oldlen = strlen (old);
- newlen = strlen (new);
-
- if (newlen < (size_t) getdef_num ("PASS_MIN_LEN", 0)) {
- return _("too short");
- }
-
- /*
- * Remaining checks are optional.
- */
- if (!getdef_bool ("OBSCURE_CHECKS_ENAB")) {
- return NULL;
- }
-
- msg = password_check (old, new, pwdp);
- if (NULL != msg) {
- return msg;
- }
-
- result = getdef_str ("ENCRYPT_METHOD");
- if (NULL == result) {
- /* The traditional crypt() truncates passwords to 8 chars. It is
- possible to circumvent the above checks by choosing an easy
- 8-char password and adding some random characters to it...
- Example: "password$%^&*123". So check it again, this time
- truncated to the maximum length. Idea from npasswd. --marekm */
-
- if (getdef_bool ("MD5_CRYPT_ENAB")) {
- return NULL;
- }
-
- } else {
-
- if ( (strcmp (result, "MD5") == 0)
-#ifdef USE_SHA_CRYPT
- || (strcmp (result, "SHA256") == 0)
- || (strcmp (result, "SHA512") == 0)
-#endif
-#ifdef USE_BCRYPT
- || (strcmp (result, "BCRYPT") == 0)
-#endif
-#ifdef USE_YESCRYPT
- || (strcmp (result, "YESCRYPT") == 0)
-#endif
- ) {
- return NULL;
- }
-
- }
- maxlen = (size_t) getdef_num ("PASS_MAX_LEN", 8);
- if ( (oldlen <= maxlen)
- && (newlen <= maxlen)) {
- return NULL;
- }
-
- new1 = xstrdup (new);
- old1 = xstrdup (old);
- if (newlen > maxlen) {
- new1[maxlen] = '\0';
- }
- if (oldlen > maxlen) {
- old1[maxlen] = '\0';
- }
-
- msg = password_check (old1, new1, pwdp);
-
- memzero (new1, newlen);
- memzero (old1, oldlen);
- free (new1);
- free (old1);
-
- return msg;
-}
-
-/*
- * Obscure - see if password is obscure enough.
- *
- * The programmer is encouraged to add as much complexity to this
- * routine as desired. Included are some of my favorite ways to
- * check passwords.
- */
-
-bool obscure (const char *old, const char *new, const struct passwd *pwdp)
-{
- const char *msg = obscure_msg (old, new, pwdp);
-
- if (NULL != msg) {
- printf (_("Bad password: %s. "), msg);
- return false;
- }
- return true;
-}
-
-#else /* !USE_PAM */
-extern int errno; /* warning: ANSI C forbids an empty source file */
-#endif /* !USE_PAM */