#include "crypto_int.h"
struct {
krb5_enctype etype;
const char *name;
} unsupported_etypes[] = {
{ ENCTYPE_DES_CBC_CRC, "des-cbc-crc" },
{ ENCTYPE_DES_CBC_MD4, "des-cbc-md4" },
{ ENCTYPE_DES_CBC_MD5, "des-cbc-md5" },
{ ENCTYPE_DES_CBC_RAW, "des-cbc-raw" },
{ ENCTYPE_DES_HMAC_SHA1, "des-hmac-sha1" },
{ ENCTYPE_NULL, NULL }
};
krb5_boolean KRB5_CALLCONV
krb5_c_valid_enctype(krb5_enctype etype)
{
return (find_enctype(etype) != NULL);
}
krb5_boolean KRB5_CALLCONV
krb5int_c_weak_enctype(krb5_enctype etype)
{
const struct krb5_keytypes *ktp;
ktp = find_enctype(etype);
return (ktp != NULL && (ktp->flags & ETYPE_WEAK) != 0);
}
krb5_boolean KRB5_CALLCONV
krb5int_c_deprecated_enctype(krb5_enctype etype)
{
const struct krb5_keytypes *ktp = find_enctype(etype);
return ktp == NULL || (ktp->flags & ETYPE_DEPRECATED) != 0;
}
krb5_error_code KRB5_CALLCONV
krb5_c_enctype_compare(krb5_context context, krb5_enctype e1, krb5_enctype e2,
krb5_boolean *similar)
{
const struct krb5_keytypes *ktp1, *ktp2;
ktp1 = find_enctype(e1);
ktp2 = find_enctype(e2);
if (ktp1 == NULL || ktp2 == NULL)
return KRB5_BAD_ENCTYPE;
*similar = (ktp1->enc == ktp2->enc && ktp1->str2key == ktp2->str2key);
return 0;
}
krb5_error_code KRB5_CALLCONV
krb5_string_to_enctype(char *string, krb5_enctype *enctypep)
{
int i;
unsigned int j;
const char *alias;
const struct krb5_keytypes *ktp;
for (i = 0; i < krb5int_enctypes_length; i++) {
ktp = &krb5int_enctypes_list[i];
if (strcasecmp(ktp->name, string) == 0) {
*enctypep = ktp->etype;
return 0;
}
for (j = 0; j < MAX_ETYPE_ALIASES; j++) {
alias = ktp->aliases[j];
if (alias == NULL)
break;
if (strcasecmp(alias, string) == 0) {
*enctypep = ktp->etype;
return 0;
}
}
}
return EINVAL;
}
krb5_error_code KRB5_CALLCONV
krb5_enctype_to_string(krb5_enctype enctype, char *buffer, size_t buflen)
{
const struct krb5_keytypes *ktp;
ktp = find_enctype(enctype);
if (ktp == NULL)
return EINVAL;
if (strlcpy(buffer, ktp->out_string, buflen) >= 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;
for (i = 0; unsupported_etypes[i].etype != ENCTYPE_NULL; i++) {
if (enctype == unsupported_etypes[i].etype) {
if (strlcpy(buffer, unsupported_etypes[i].name, buflen) >= buflen)
return ENOMEM;
return 0;
}
}
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;
}
krb5_error_code
k5_enctype_to_ssf(krb5_enctype enctype, unsigned int *ssf_out)
{
const struct krb5_keytypes *ktp;
*ssf_out = 0;
ktp = find_enctype(enctype);
if (ktp == NULL)
return EINVAL;
*ssf_out = ktp->ssf;
return 0;
}