diff options
| author | Bob Dunlop <bob.dunlop@xyzzy.org.uk> | 2010-08-17 16:01:16 +0200 |
|---|---|---|
| committer | Denys Vlasenko <vda.linux@googlemail.com> | 2010-08-17 16:01:16 +0200 |
| commit | d71c770f05079e65b2d27d28ce22b0f08e71a207 (patch) | |
| tree | b2535b234106d5b8491f7012c9999c262c92f80b | |
| parent | cda815996b92edec880943a11fe8f9e33c1ad904 (diff) | |
| download | busybox-w32-d71c770f05079e65b2d27d28ce22b0f08e71a207.tar.gz busybox-w32-d71c770f05079e65b2d27d28ce22b0f08e71a207.tar.bz2 busybox-w32-d71c770f05079e65b2d27d28ce22b0f08e71a207.zip | |
libbb: shrink obscure()
function old new delta
string_checker_helper 59 45 -14
string_checker 116 98 -18
obscure 367 204 -163
------------------------------------------------------------------------------
(add/remove: 0/0 grow/shrink: 0/3 up/down: 0/-195) Total: -195 bytes
Signed-off-by: Bob Dunlop <bob.dunlop@xyzzy.org.uk>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
| -rw-r--r-- | libbb/obscure.c | 78 |
1 files changed, 45 insertions, 33 deletions
diff --git a/libbb/obscure.c b/libbb/obscure.c index 22bcb9dec..06f00281a 100644 --- a/libbb/obscure.c +++ b/libbb/obscure.c | |||
| @@ -45,53 +45,59 @@ static int string_checker_helper(const char *p1, const char *p2) __attribute__ ( | |||
| 45 | 45 | ||
| 46 | static int string_checker_helper(const char *p1, const char *p2) | 46 | static int string_checker_helper(const char *p1, const char *p2) |
| 47 | { | 47 | { |
| 48 | /* as-is or capitalized */ | ||
| 49 | if (strcasecmp(p1, p2) == 0 | ||
| 50 | /* as sub-string */ | 48 | /* as sub-string */ |
| 51 | || strcasestr(p2, p1) != NULL | 49 | if (strcasestr(p2, p1) != NULL |
| 52 | /* invert in case haystack is shorter than needle */ | 50 | /* invert in case haystack is shorter than needle */ |
| 53 | || strcasestr(p1, p2) != NULL) | 51 | || strcasestr(p1, p2) != NULL |
| 52 | /* as-is or capitalized */ | ||
| 53 | /* || strcasecmp(p1, p2) == 0 - 1st strcasestr should catch this too */ | ||
| 54 | ) { | ||
| 54 | return 1; | 55 | return 1; |
| 56 | } | ||
| 55 | return 0; | 57 | return 0; |
| 56 | } | 58 | } |
| 57 | 59 | ||
| 58 | static int string_checker(const char *p1, const char *p2) | 60 | static int string_checker(const char *p1, const char *p2) |
| 59 | { | 61 | { |
| 60 | int size; | 62 | int size, i; |
| 61 | /* check string */ | 63 | /* check string */ |
| 62 | int ret = string_checker_helper(p1, p2); | 64 | int ret = string_checker_helper(p1, p2); |
| 63 | /* Make our own copy */ | 65 | /* make our own copy */ |
| 64 | char *p = xstrdup(p1); | 66 | char *p = xstrdup(p1); |
| 65 | /* reverse string */ | ||
| 66 | size = strlen(p); | ||
| 67 | 67 | ||
| 68 | while (size--) { | 68 | /* reverse string */ |
| 69 | *p = p1[size]; | 69 | i = size = strlen(p1); |
| 70 | p++; | 70 | while (--i >= 0) { |
| 71 | *p++ = p1[i]; | ||
| 71 | } | 72 | } |
| 72 | /* restore pointer */ | 73 | p -= size; /* restore pointer */ |
| 73 | p -= strlen(p1); | 74 | |
| 74 | /* check reversed string */ | 75 | /* check reversed string */ |
| 75 | ret |= string_checker_helper(p, p2); | 76 | ret |= string_checker_helper(p, p2); |
| 77 | |||
| 76 | /* clean up */ | 78 | /* clean up */ |
| 77 | memset(p, 0, strlen(p1)); | 79 | memset(p, 0, size); |
| 78 | free(p); | 80 | free(p); |
| 81 | |||
| 79 | return ret; | 82 | return ret; |
| 80 | } | 83 | } |
| 81 | 84 | ||
| 82 | #define LOWERCASE 1 | 85 | #define CATEGORIES 4 |
| 83 | #define UPPERCASE 2 | 86 | |
| 84 | #define NUMBERS 4 | 87 | #define LOWERCASE 1 |
| 85 | #define SPECIAL 8 | 88 | #define UPPERCASE 2 |
| 89 | #define NUMBERS 4 | ||
| 90 | #define SPECIAL 8 | ||
| 91 | |||
| 92 | #define LAST_CAT 8 | ||
| 86 | 93 | ||
| 87 | static const char *obscure_msg(const char *old_p, const char *new_p, const struct passwd *pw) | 94 | static const char *obscure_msg(const char *old_p, const char *new_p, const struct passwd *pw) |
| 88 | { | 95 | { |
| 89 | int i; | 96 | unsigned length; |
| 90 | int c; | 97 | unsigned size; |
| 91 | int length; | 98 | unsigned mixed; |
| 92 | int mixed = 0; | 99 | unsigned c; |
| 93 | /* Add 2 for each type of characters to the minlen of password */ | 100 | unsigned i; |
| 94 | int size = CONFIG_PASSWORD_MINLEN + 8; | ||
| 95 | const char *p; | 101 | const char *p; |
| 96 | char *hostname; | 102 | char *hostname; |
| 97 | 103 | ||
| @@ -104,7 +110,7 @@ static const char *obscure_msg(const char *old_p, const char *new_p, const struc | |||
| 104 | return "similar to username"; | 110 | return "similar to username"; |
| 105 | } | 111 | } |
| 106 | /* no gecos as-is, as sub-string, reversed, capitalized, doubled */ | 112 | /* no gecos as-is, as sub-string, reversed, capitalized, doubled */ |
| 107 | if (*pw->pw_gecos && string_checker(new_p, pw->pw_gecos)) { | 113 | if (pw->pw_gecos[0] && string_checker(new_p, pw->pw_gecos)) { |
| 108 | return "similar to gecos"; | 114 | return "similar to gecos"; |
| 109 | } | 115 | } |
| 110 | /* hostname as-is, as sub-string, reversed, capitalized, doubled */ | 116 | /* hostname as-is, as sub-string, reversed, capitalized, doubled */ |
| @@ -115,6 +121,7 @@ static const char *obscure_msg(const char *old_p, const char *new_p, const struc | |||
| 115 | return "similar to hostname"; | 121 | return "similar to hostname"; |
| 116 | 122 | ||
| 117 | /* Should / Must contain a mix of: */ | 123 | /* Should / Must contain a mix of: */ |
| 124 | mixed = 0; | ||
| 118 | for (i = 0; i < length; i++) { | 125 | for (i = 0; i < length; i++) { |
| 119 | if (islower(new_p[i])) { /* a-z */ | 126 | if (islower(new_p[i])) { /* a-z */ |
| 120 | mixed |= LOWERCASE; | 127 | mixed |= LOWERCASE; |
| @@ -125,7 +132,7 @@ static const char *obscure_msg(const char *old_p, const char *new_p, const struc | |||
| 125 | } else { /* special characters */ | 132 | } else { /* special characters */ |
| 126 | mixed |= SPECIAL; | 133 | mixed |= SPECIAL; |
| 127 | } | 134 | } |
| 128 | /* More than 50% similar characters ? */ | 135 | /* Count i'th char */ |
| 129 | c = 0; | 136 | c = 0; |
| 130 | p = new_p; | 137 | p = new_p; |
| 131 | while (1) { | 138 | while (1) { |
| @@ -134,26 +141,31 @@ static const char *obscure_msg(const char *old_p, const char *new_p, const struc | |||
| 134 | break; | 141 | break; |
| 135 | } | 142 | } |
| 136 | c++; | 143 | c++; |
| 137 | if (!++p) { | 144 | p++; |
| 138 | break; /* move past the matched char if possible */ | 145 | if (!*p) { |
| 146 | break; | ||
| 139 | } | 147 | } |
| 140 | } | 148 | } |
| 141 | 149 | /* More than 50% similar characters ? */ | |
| 142 | if (c >= (length / 2)) { | 150 | if (c*2 >= length) { |
| 143 | return "too many similar characters"; | 151 | return "too many similar characters"; |
| 144 | } | 152 | } |
| 145 | } | 153 | } |
| 146 | for (i=0; i<4; i++) | 154 | |
| 147 | if (mixed & (1<<i)) size -= 2; | 155 | size = CONFIG_PASSWORD_MINLEN + 2*CATEGORIES; |
| 156 | for (i = 0; i <= LAST_CAT; i <<= 1) | ||
| 157 | if (mixed & i) | ||
| 158 | size -= 2; | ||
| 148 | if (length < size) | 159 | if (length < size) |
| 149 | return "too weak"; | 160 | return "too weak"; |
| 150 | 161 | ||
| 151 | if (old_p && old_p[0] != '\0') { | 162 | if (old_p && old_p[0]) { |
| 152 | /* check vs. old password */ | 163 | /* check vs. old password */ |
| 153 | if (string_checker(new_p, old_p)) { | 164 | if (string_checker(new_p, old_p)) { |
| 154 | return "similar to old password"; | 165 | return "similar to old password"; |
| 155 | } | 166 | } |
| 156 | } | 167 | } |
| 168 | |||
| 157 | return NULL; | 169 | return NULL; |
| 158 | } | 170 | } |
| 159 | 171 | ||
