kdc: Check krb5_ret_uint32() in connect loop
This commit is contained in:
		| @@ -621,6 +621,7 @@ handle_vanilla_tcp (krb5_context context, | ||||
| 		    krb5_kdc_configuration *config, | ||||
| 		    struct descr *d) | ||||
| { | ||||
|     krb5_error_code ret; | ||||
|     krb5_storage *sp; | ||||
|     uint32_t len; | ||||
|  | ||||
| @@ -629,7 +630,13 @@ handle_vanilla_tcp (krb5_context context, | ||||
| 	kdc_log (context, config, 1, "krb5_storage_from_mem failed"); | ||||
| 	return -1; | ||||
|     } | ||||
|     krb5_ret_uint32(sp, &len); | ||||
|     if (d->len < 4) | ||||
|         return 0; | ||||
|     ret = krb5_ret_uint32(sp, &len); | ||||
|     if (ret) { | ||||
| 	kdc_log(context, config, 4, "failed to read request length"); | ||||
| 	return -1; | ||||
|     } | ||||
|     krb5_storage_free(sp); | ||||
|     if(d->len - 4 >= len) { | ||||
| 	memmove(d->buf, d->buf + 4, d->len - 4); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Nicolas Williams
					Nicolas Williams