catch error from as.*printf

This commit is contained in:
Love Hornquist Astrand
2010-05-30 13:44:41 -07:00
parent 077357c848
commit 2b1645aa08
9 changed files with 50 additions and 39 deletions

View File

@@ -55,10 +55,10 @@ _gsskrb5_register_acceptor_identity (const char *identity)
if (identity == NULL) { if (identity == NULL) {
ret = krb5_kt_default(context, &_gsskrb5_keytab); ret = krb5_kt_default(context, &_gsskrb5_keytab);
} else { } else {
char *p; char *p = NULL;
asprintf(&p, "FILE:%s", identity); ret = asprintf(&p, "FILE:%s", identity);
if(p == NULL) { if(ret < 0 || p == NULL) {
HEIMDAL_MUTEX_unlock(&gssapi_keytab_mutex); HEIMDAL_MUTEX_unlock(&gssapi_keytab_mutex);
return GSS_S_FAILURE; return GSS_S_FAILURE;
} }

View File

@@ -155,7 +155,7 @@ OM_uint32 _gsskrb5_add_cred (
if (cred->ccache) { if (cred->ccache) {
const char *type, *name; const char *type, *name;
char *type_name; char *type_name = NULL;
ret = GSS_S_FAILURE; ret = GSS_S_FAILURE;
@@ -187,8 +187,8 @@ OM_uint32 _gsskrb5_add_cred (
goto failure; goto failure;
} }
asprintf(&type_name, "%s:%s", type, name); kret = asprintf(&type_name, "%s:%s", type, name);
if (type_name == NULL) { if (kret < 0 || type_name == NULL) {
*minor_status = ENOMEM; *minor_status = ENOMEM;
goto failure; goto failure;
} }

View File

@@ -125,14 +125,15 @@ _gsskrb5_set_status (int ret, const char *fmt, ...)
krb5_context context; krb5_context context;
va_list args; va_list args;
char *str; char *str;
int e;
if (_gsskrb5_init (&context) != 0) if (_gsskrb5_init (&context) != 0)
return; return;
va_start(args, fmt); va_start(args, fmt);
vasprintf(&str, fmt, args); e = vasprintf(&str, fmt, args);
va_end(args); va_end(args);
if (str) { if (e >= 0 && str) {
krb5_set_error_message(context, ret, "%s", str); krb5_set_error_message(context, ret, "%s", str);
free(str); free(str);
} }
@@ -147,7 +148,8 @@ OM_uint32 _gsskrb5_display_status
gss_buffer_t status_string) gss_buffer_t status_string)
{ {
krb5_context context; krb5_context context;
char *buf; char *buf = NULL;
int e = 0;
GSSAPI_KRB5_INIT (&context); GSSAPI_KRB5_INIT (&context);
@@ -162,27 +164,27 @@ OM_uint32 _gsskrb5_display_status
if (status_type == GSS_C_GSS_CODE) { if (status_type == GSS_C_GSS_CODE) {
if (GSS_SUPPLEMENTARY_INFO(status_value)) if (GSS_SUPPLEMENTARY_INFO(status_value))
asprintf(&buf, "%s", e = asprintf(&buf, "%s",
supplementary_error(GSS_SUPPLEMENTARY_INFO(status_value))); supplementary_error(GSS_SUPPLEMENTARY_INFO(status_value)));
else else
asprintf (&buf, "%s %s", e = asprintf (&buf, "%s %s",
calling_error(GSS_CALLING_ERROR(status_value)), calling_error(GSS_CALLING_ERROR(status_value)),
routine_error(GSS_ROUTINE_ERROR(status_value))); routine_error(GSS_ROUTINE_ERROR(status_value)));
} else if (status_type == GSS_C_MECH_CODE) { } else if (status_type == GSS_C_MECH_CODE) {
const char *buf2 = krb5_get_error_message(context, status_value); const char *buf2 = krb5_get_error_message(context, status_value);
if (buf2) { if (buf2) {
buf = strdup(buf2); buf = strdup(buf2);
krb5_free_error_message(context, buf2); krb5_free_error_message(context, buf2);
} else { } else {
asprintf(&buf, "unknown mech error-code %u", e = asprintf(&buf, "unknown mech error-code %u",
(unsigned)status_value); (unsigned)status_value);
} }
} else { } else {
*minor_status = EINVAL; *minor_status = EINVAL;
return GSS_S_BAD_STATUS; return GSS_S_BAD_STATUS;
} }
if (buf == NULL) { if (e < 0 || buf == NULL) {
*minor_status = ENOMEM; *minor_status = ENOMEM;
return GSS_S_FAILURE; return GSS_S_FAILURE;
} }

View File

@@ -160,17 +160,18 @@ gss_display_status(OM_uint32 *minor_status,
*minor_status = 0; *minor_status = 0;
switch (status_type) { switch (status_type) {
case GSS_C_GSS_CODE: { case GSS_C_GSS_CODE: {
char *buf; char *buf = NULL;
int e;
if (GSS_SUPPLEMENTARY_INFO(status_value)) if (GSS_SUPPLEMENTARY_INFO(status_value))
asprintf(&buf, "%s", supplementary_error( e = asprintf(&buf, "%s", supplementary_error(
GSS_SUPPLEMENTARY_INFO(status_value))); GSS_SUPPLEMENTARY_INFO(status_value)));
else else
asprintf (&buf, "%s %s", e = asprintf (&buf, "%s %s",
calling_error(GSS_CALLING_ERROR(status_value)), calling_error(GSS_CALLING_ERROR(status_value)),
routine_error(GSS_ROUTINE_ERROR(status_value))); routine_error(GSS_ROUTINE_ERROR(status_value)));
if (buf == NULL) if (e < 0 || buf == NULL)
break; break;
status_string->length = strlen(buf); status_string->length = strlen(buf);
@@ -181,21 +182,22 @@ gss_display_status(OM_uint32 *minor_status,
case GSS_C_MECH_CODE: { case GSS_C_MECH_CODE: {
OM_uint32 maj_junk, min_junk; OM_uint32 maj_junk, min_junk;
gss_buffer_desc oid; gss_buffer_desc oid;
char *buf; char *buf = NULL;
int e;
maj_junk = gss_oid_to_str(&min_junk, mech_type, &oid); maj_junk = gss_oid_to_str(&min_junk, mech_type, &oid);
if (maj_junk != GSS_S_COMPLETE) { if (maj_junk != GSS_S_COMPLETE) {
oid.value = rk_UNCONST("unknown"); oid.value = rk_UNCONST("unknown");
oid.length = 7; oid.length = 7;
} }
asprintf (&buf, "unknown mech-code %lu for mech %.*s", e = asprintf (&buf, "unknown mech-code %lu for mech %.*s",
(unsigned long)status_value, (unsigned long)status_value,
(int)oid.length, (char *)oid.value); (int)oid.length, (char *)oid.value);
if (maj_junk == GSS_S_COMPLETE) if (maj_junk == GSS_S_COMPLETE)
gss_release_buffer(&min_junk, &oid); gss_release_buffer(&min_junk, &oid);
if (buf == NULL) if (e < 0 || buf == NULL)
break; break;
status_string->length = strlen(buf); status_string->length = strlen(buf);

View File

@@ -42,7 +42,7 @@ gss_krb5_copy_ccache(OM_uint32 *minor_status,
krb5_error_code kret; krb5_error_code kret;
krb5_ccache id; krb5_ccache id;
OM_uint32 ret; OM_uint32 ret;
char *str; char *str = NULL;
ret = gss_inquire_cred_by_oid(minor_status, ret = gss_inquire_cred_by_oid(minor_status,
cred, cred,
@@ -67,7 +67,7 @@ gss_krb5_copy_ccache(OM_uint32 *minor_status,
kret = asprintf(&str, "%.*s", (int)data_set->elements[0].length, kret = asprintf(&str, "%.*s", (int)data_set->elements[0].length,
(char *)data_set->elements[0].value); (char *)data_set->elements[0].value);
gss_release_buffer_set(minor_status, &data_set); gss_release_buffer_set(minor_status, &data_set);
if (kret == -1) { if (kret < 0 || str == NULL) {
*minor_status = ENOMEM; *minor_status = ENOMEM;
return GSS_S_FAILURE; return GSS_S_FAILURE;
} }

View File

@@ -47,7 +47,7 @@ OM_uint32 _gss_ntlm_display_name
if (output_name_buffer) { if (output_name_buffer) {
ntlm_name n = (ntlm_name)input_name; ntlm_name n = (ntlm_name)input_name;
char *str; char *str = NULL;
int len; int len;
output_name_buffer->length = 0; output_name_buffer->length = 0;
@@ -59,7 +59,7 @@ OM_uint32 _gss_ntlm_display_name
} }
len = asprintf(&str, "%s@%s", n->user, n->domain); len = asprintf(&str, "%s@%s", n->user, n->domain);
if (str == NULL) { if (len < 0 || str == NULL) {
*minor_status = ENOMEM; *minor_status = ENOMEM;
return GSS_S_FAILURE; return GSS_S_FAILURE;
} }

View File

@@ -372,7 +372,11 @@ select_mech(OM_uint32 *minor_status, MechType *mechType, int verify_p,
*minor_status = errno; *minor_status = errno;
return GSS_S_FAILURE; return GSS_S_FAILURE;
} }
asprintf(&str, "host@%s", hostname); i = asprintf(&str, "host@%s", hostname);
if (i < 0 || str == NULL) {
*minor_status = ENOMEM;
return GSS_S_FAILURE;
}
host = str; host = str;
} }

View File

@@ -56,13 +56,14 @@ gssapi_err(OM_uint32 maj_stat, OM_uint32 min_stat, gss_OID mech)
disp_maj_stat = gss_display_status(&disp_min_stat, min_stat, disp_maj_stat = gss_display_status(&disp_min_stat, min_stat,
GSS_C_MECH_CODE, GSS_C_MECH_CODE,
mech, &msg_ctx, &min_error_message); mech, &msg_ctx, &min_error_message);
asprintf(&ret, "gss-code: %lu %.*s -- mech-code: %lu %.*s", if (asprintf(&ret, "gss-code: %lu %.*s -- mech-code: %lu %.*s",
(unsigned long)maj_stat, (unsigned long)maj_stat,
(int)maj_error_message.length, (int)maj_error_message.length,
(char *)maj_error_message.value, (char *)maj_error_message.value,
(unsigned long)min_stat, (unsigned long)min_stat,
(int)min_error_message.length, (int)min_error_message.length,
(char *)min_error_message.value); (char *)min_error_message.value) < 0 || ret == NULL)
errx(1, "malloc");
gss_release_buffer(&disp_min_stat, &maj_error_message); gss_release_buffer(&disp_min_stat, &maj_error_message);
gss_release_buffer(&disp_min_stat, &min_error_message); gss_release_buffer(&disp_min_stat, &min_error_message);

View File

@@ -129,8 +129,9 @@ main(int argc, char **argv)
* test import/export * test import/export
*/ */
str = NULL;
len = asprintf(&str, "ftp@freeze-arrow.mit.edu"); len = asprintf(&str, "ftp@freeze-arrow.mit.edu");
if (len == -1) if (len < 0 || str == NULL)
errx(1, "asprintf"); errx(1, "asprintf");
name_buffer.value = str; name_buffer.value = str;
@@ -183,8 +184,9 @@ main(int argc, char **argv)
* Dovecot SASL lib does this. * Dovecot SASL lib does this.
*/ */
str = NULL;
len = asprintf(&str, "lha"); len = asprintf(&str, "lha");
if (len == -1) if (len < 0 || str == NULL)
errx(1, "asprintf"); errx(1, "asprintf");
name_buffer.value = str; name_buffer.value = str;