#include <sasl.h>
#include <gssapi/gssapi.h>
+#ifndef KRB5_HEIMDAL
#include <gssapi/gssapi_ext.h>
+#endif
#include "common.h"
void usage(void)
{
- fprintf(stderr, "usage: server [-c] [-h hostname] [-p port] [-s service] [-m mech]\n");
+ fprintf(stderr, "usage: server [-C] [-h hostname] [-p port] [-s service] [-m mech]\n");
exit(EX_USAGE);
}
sasl_conn_t *conn;
int cb_flag = 0;
- while ((c = getopt(argc, argv, "ch:p:s:m:")) != EOF) {
+ while ((c = getopt(argc, argv, "Cch:p:s:m:")) != EOF) {
switch(c) {
+ case 'C':
+ cb_flag = 2; /* channel bindings are critical */
+ break;
+
case 'c':
- cb_flag = 1;
+ cb_flag = 1; /* channel bindings are present */
break;
case 'h':
if (r != SASL_OK) saslfail(r, "allocating connection state");
cb.name = "sasl-sample";
- cb.critical = cb_flag;
+ cb.critical = cb_flag > 1;
cb.data = "this is a test of channel binding";
cb.len = strlen(cb.data);
- sasl_setprop(conn, SASL_CHANNEL_BINDING, &cb);
+ if (cb_flag)
+ sasl_setprop(conn, SASL_CHANNEL_BINDING, &cb);
/* set external properties here
sasl_setprop(conn, SASL_SSF_EXTERNAL, &extprops); */
dumpAttribute(minor, name, &attrs->elements[i], noisy);
}
+#ifndef KRB5_HEIMDAL
gss_release_oid(&tmp, &mech);
+#endif
gss_release_buffer_set(&tmp, &attrs);
return major;