diff options
author | Greg Hudson <ghudson@mit.edu> | 2010-06-04 18:33:26 +0000 |
---|---|---|
committer | Greg Hudson <ghudson@mit.edu> | 2010-06-04 18:33:26 +0000 |
commit | 91c7788e903744318a70982f50b69187db9a9914 (patch) | |
tree | 4262dabfc86c800616591af7a27dc866d8a8a268 /src/lib/crypto/krb/enctype_util.c | |
parent | ead84caee261c3ef032e9eba713f261c90a91347 (diff) | |
download | krb5-91c7788e903744318a70982f50b69187db9a9914.zip krb5-91c7788e903744318a70982f50b69187db9a9914.tar.gz krb5-91c7788e903744318a70982f50b69187db9a9914.tar.bz2 |
Add krb5_enctype_to_name() API
Add an API to return the input name, or optionally the shortest alias,
of an enctype. Similar to krb5_enctype_to_string() which returns a
description.
ticket: 6736
git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@24117 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src/lib/crypto/krb/enctype_util.c')
-rw-r--r-- | src/lib/crypto/krb/enctype_util.c | 28 |
1 files changed, 26 insertions, 2 deletions
diff --git a/src/lib/crypto/krb/enctype_util.c b/src/lib/crypto/krb/enctype_util.c index dd1a388..1a9caf6 100644 --- a/src/lib/crypto/krb/enctype_util.c +++ b/src/lib/crypto/krb/enctype_util.c @@ -81,8 +81,7 @@ krb5_string_to_enctype(char *string, krb5_enctype *enctypep) *enctypep = ktp->etype; return 0; } -#define MAX_ALIASES (sizeof(ktp->aliases) / sizeof(ktp->aliases[0])) - for (j = 0; j < MAX_ALIASES; j++) { + for (j = 0; j < MAX_ETYPE_ALIASES; j++) { alias = ktp->aliases[j]; if (alias == NULL) break; @@ -108,3 +107,28 @@ krb5_enctype_to_string(krb5_enctype enctype, char *buffer, size_t buflen) return ENOMEM; return 0; } + +krb5_error_code KRB5_CALLCONV +krb5_enctype_to_name(krb5_enctype enctype, krb5_boolean shortest, + char *buffer, size_t buflen) +{ + const struct krb5_keytypes *ktp; + const char *name; + int i; + + ktp = find_enctype(enctype); + if (ktp == NULL) + return EINVAL; + name = ktp->name; + if (shortest) { + for (i = 0; i < MAX_ETYPE_ALIASES; i++) { + if (ktp->aliases[i] == NULL) + break; + if (strlen(ktp->aliases[i]) < strlen(name)) + name = ktp->aliases[i]; + } + } + if (strlcpy(buffer, name, buflen) >= buflen) + return ENOMEM; + return 0; +} |