Eric Andersen | 27f64e1 | 2002-06-23 04:24:25 +0000 | [diff] [blame] | 1 | /* vi: set sw=4 ts=4: */ |
| 2 | /* |
| 3 | * Utility routine. |
| 4 | * |
Eric Andersen | c7bda1c | 2004-03-15 08:29:22 +0000 | [diff] [blame] | 5 | * Copyright (C) 1999-2004 by Erik Andersen <andersen@codepoet.org> |
Eric Andersen | 27f64e1 | 2002-06-23 04:24:25 +0000 | [diff] [blame] | 6 | * |
"Robert P. J. Day" | 5d8843e | 2006-07-10 11:41:19 +0000 | [diff] [blame] | 7 | * Licensed under GPLv2 or later, see file LICENSE in this tarball for details. |
Eric Andersen | 27f64e1 | 2002-06-23 04:24:25 +0000 | [diff] [blame] | 8 | */ |
| 9 | |
Rob Landley | ea224be | 2006-06-18 20:20:07 +0000 | [diff] [blame] | 10 | #include "libbb.h" |
Eric Andersen | 27f64e1 | 2002-06-23 04:24:25 +0000 | [diff] [blame] | 11 | |
Denis Vlasenko | b4c5bf6 | 2008-06-15 18:35:34 +0000 | [diff] [blame] | 12 | #if ENABLE_USE_BB_CRYPT |
| 13 | |
Denis Vlasenko | 4ea83bf | 2008-06-12 16:55:59 +0000 | [diff] [blame] | 14 | /* |
| 15 | * DES and MD5 crypt implementations are taken from uclibc. |
| 16 | * They were modified to not use static buffers. |
Denis Vlasenko | 4ea83bf | 2008-06-12 16:55:59 +0000 | [diff] [blame] | 17 | */ |
| 18 | /* Common for them */ |
| 19 | static const uint8_t ascii64[] = "./0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; |
| 20 | #include "pw_encrypt_des.c" |
| 21 | #include "pw_encrypt_md5.c" |
| 22 | |
Denis Vlasenko | 30e1ab6 | 2008-11-07 13:36:46 +0000 | [diff] [blame^] | 23 | /* Other advanced crypt ids: */ |
| 24 | /* $2$ or $2a$: Blowfish */ |
| 25 | /* $5$: SHA-256 */ |
| 26 | /* $6$: SHA-512 */ |
| 27 | /* TODO: implement SHA - http://people.redhat.com/drepper/SHA-crypt.txt */ |
Denis Vlasenko | 4ea83bf | 2008-06-12 16:55:59 +0000 | [diff] [blame] | 28 | |
| 29 | static struct const_des_ctx *des_cctx; |
| 30 | static struct des_ctx *des_ctx; |
| 31 | |
| 32 | /* my_crypt returns malloc'ed data */ |
| 33 | static char *my_crypt(const char *key, const char *salt) |
Eric Andersen | 27f64e1 | 2002-06-23 04:24:25 +0000 | [diff] [blame] | 34 | { |
Denis Vlasenko | 4ea83bf | 2008-06-12 16:55:59 +0000 | [diff] [blame] | 35 | /* First, check if we are supposed to be using the MD5 replacement |
| 36 | * instead of DES... */ |
| 37 | if (salt[0] == '$' && salt[1] == '1' && salt[2] == '$') { |
| 38 | return md5_crypt(xzalloc(MD5_OUT_BUFSIZE), (unsigned char*)key, (unsigned char*)salt); |
| 39 | } |
| 40 | |
| 41 | { |
| 42 | if (!des_cctx) |
| 43 | des_cctx = const_des_init(); |
| 44 | des_ctx = des_init(des_ctx, des_cctx); |
| 45 | return des_crypt(des_ctx, xzalloc(DES_OUT_BUFSIZE), (unsigned char*)key, (unsigned char*)salt); |
| 46 | } |
| 47 | } |
| 48 | |
| 49 | /* So far nobody wants to have it public */ |
| 50 | static void my_crypt_cleanup(void) |
| 51 | { |
| 52 | free(des_cctx); |
| 53 | free(des_ctx); |
| 54 | des_cctx = NULL; |
| 55 | des_ctx = NULL; |
| 56 | } |
| 57 | |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 58 | char* FAST_FUNC pw_encrypt(const char *clear, const char *salt, int cleanup) |
Denis Vlasenko | 4ea83bf | 2008-06-12 16:55:59 +0000 | [diff] [blame] | 59 | { |
Denis Vlasenko | fdddab0 | 2008-06-12 16:56:52 +0000 | [diff] [blame] | 60 | char *encrypted; |
Eric Andersen | 27f64e1 | 2002-06-23 04:24:25 +0000 | [diff] [blame] | 61 | |
Denis Vlasenko | fdddab0 | 2008-06-12 16:56:52 +0000 | [diff] [blame] | 62 | encrypted = my_crypt(clear, salt); |
Denis Vlasenko | 4ea83bf | 2008-06-12 16:55:59 +0000 | [diff] [blame] | 63 | |
| 64 | if (cleanup) |
| 65 | my_crypt_cleanup(); |
| 66 | |
Denis Vlasenko | fdddab0 | 2008-06-12 16:56:52 +0000 | [diff] [blame] | 67 | return encrypted; |
Eric Andersen | 27f64e1 | 2002-06-23 04:24:25 +0000 | [diff] [blame] | 68 | } |
Denis Vlasenko | b4c5bf6 | 2008-06-15 18:35:34 +0000 | [diff] [blame] | 69 | |
| 70 | #else /* if !ENABLE_USE_BB_CRYPT */ |
| 71 | |
Denis Vlasenko | defc1ea | 2008-06-27 02:52:20 +0000 | [diff] [blame] | 72 | char* FAST_FUNC pw_encrypt(const char *clear, const char *salt, int cleanup) |
Denis Vlasenko | b4c5bf6 | 2008-06-15 18:35:34 +0000 | [diff] [blame] | 73 | { |
Denis Vlasenko | b4c5bf6 | 2008-06-15 18:35:34 +0000 | [diff] [blame] | 74 | return xstrdup(crypt(clear, salt)); |
| 75 | } |
| 76 | |
| 77 | #endif |