3
0

pw_encrypt.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. /* vi: set sw=4 ts=4: */
  2. /*
  3. * Utility routine.
  4. *
  5. * Copyright (C) 1999-2004 by Erik Andersen <andersen@codepoet.org>
  6. *
  7. * This program is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation; either version 2 of the License, or
  10. * (at your option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  20. *
  21. */
  22. #include <string.h>
  23. #include <crypt.h>
  24. #include "libbb.h"
  25. extern char *pw_encrypt(const char *clear, const char *salt)
  26. {
  27. static char cipher[128];
  28. char *cp;
  29. #ifdef CONFIG_FEATURE_SHA1_PASSWORDS
  30. if (strncmp(salt, "$2$", 3) == 0) {
  31. return sha1_crypt(clear);
  32. }
  33. #endif
  34. cp = (char *) crypt(clear, salt);
  35. /* if crypt (a nonstandard crypt) returns a string too large,
  36. truncate it so we don't overrun buffers and hope there is
  37. enough security in what's left */
  38. safe_strncpy(cipher, cp, sizeof(cipher));
  39. return cipher;
  40. }