aboutsummaryrefslogtreecommitdiff
path: root/src/lib/crypto/krb/enctype_util.c
diff options
context:
space:
mode:
authorGreg Hudson <ghudson@mit.edu>2010-06-04 18:33:26 +0000
committerGreg Hudson <ghudson@mit.edu>2010-06-04 18:33:26 +0000
commit91c7788e903744318a70982f50b69187db9a9914 (patch)
tree4262dabfc86c800616591af7a27dc866d8a8a268 /src/lib/crypto/krb/enctype_util.c
parentead84caee261c3ef032e9eba713f261c90a91347 (diff)
downloadkrb5-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.c28
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;
+}