#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 [-p port] [-s service] [-m mech]\n");
+ fprintf(stderr, "usage: server [-C] [-h hostname] [-p port] [-s service] [-m mech]\n");
exit(EX_USAGE);
}
int c;
char *port = "12345";
char *service = "rcmd";
+ char *hostname = NULL;
int *l, maxfd=0;
int r, i;
sasl_conn_t *conn;
int cb_flag = 0;
- while ((c = getopt(argc, argv, "cp: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':
+ hostname = optarg;
break;
case 'p':
}
snprintf(remoteaddr, sizeof(remoteaddr), "%s;%s", hbuf, pbuf);
- r = gethostname(myhostname, sizeof(myhostname)-1);
- if(r == -1) saslfail(r, "getting hostname");
+ if (hostname == NULL) {
+ r = gethostname(myhostname, sizeof(myhostname)-1);
+ if(r == -1) saslfail(r, "getting hostname");
+ hostname = myhostname;
+ }
- r = sasl_server_new(service, myhostname, NULL, localaddr, remoteaddr,
+ r = sasl_server_new(service, hostname, NULL, localaddr, remoteaddr,
NULL, 0, &conn);
if (r != SASL_OK) saslfail(r, "allocating connection state");
- cb.name = "sasl-sample";
- cb.critical = cb_flag;
- cb.data = "this is a test of channel binding";
- cb.len = strlen(cb.data);
+ cb.name = "sasl-sample";
+ 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;