Install -C radlib.h

Don't insist that RAD_USER_PASSWORD is supplied before
calling rad_send_request().  Instead, insist on only one
of RAD_USER_PASSWORD and RAD_CHAP_PASSWORD.

Sponsored by: Internet Business Solutions Ltd., Switzerland
This commit is contained in:
Brian Somers 1999-01-29 22:44:47 +00:00
parent ae908d9cf0
commit d30ad2abf7
3 changed files with 23 additions and 7 deletions

View File

@ -35,7 +35,7 @@ MAN3+= libradius.3
MAN5+= radius.conf.5 MAN5+= radius.conf.5
beforeinstall: beforeinstall:
${INSTALL} ${COPY} -o ${BINOWN} -g ${BINGRP} -m 444 \ ${INSTALL} -C -o ${BINOWN} -g ${BINGRP} -m 444 \
${.CURDIR}/radlib.h ${DESTDIR}/usr/include ${.CURDIR}/radlib.h ${DESTDIR}/usr/include
.include <bsd.lib.mk> .include <bsd.lib.mk>

View File

@ -472,6 +472,7 @@ rad_open(void)
memset(h->pass, 0, sizeof h->pass); memset(h->pass, 0, sizeof h->pass);
h->pass_len = 0; h->pass_len = 0;
h->pass_pos = 0; h->pass_pos = 0;
h->chap_pass = 0;
} }
return h; return h;
} }
@ -485,9 +486,17 @@ rad_put_addr(struct rad_handle *h, int type, struct in_addr addr)
int int
rad_put_attr(struct rad_handle *h, int type, const void *value, size_t len) rad_put_attr(struct rad_handle *h, int type, const void *value, size_t len)
{ {
return type == RAD_USER_PASSWORD ? int result;
put_password_attr(h, type, value, len) :
put_raw_attr(h, type, value, len); if (type == RAD_USER_PASSWORD)
result = put_password_attr(h, type, value, len);
else {
result = put_raw_attr(h, type, value, len);
if (result == 0 && type == RAD_CHAP_PASSWORD)
h->chap_pass = 1;
}
return result;
} }
int int
@ -540,8 +549,13 @@ rad_send_request(struct rad_handle *h)
} }
/* Make sure the user gave us a password */ /* Make sure the user gave us a password */
if (h->pass_pos == 0) { if (h->pass_pos == 0 && !h->chap_pass) {
generr(h, "No User-Password attribute given"); generr(h, "No User or Chap Password attributes given");
return -1;
}
if (h->pass_pos != 0 && h->chap_pass) {
generr(h, "Both User and Chap Password attributes given");
return -1; return -1;
} }
@ -580,7 +594,8 @@ rad_send_request(struct rad_handle *h)
srv = 0; srv = 0;
/* Insert the scrambled password into the request */ /* Insert the scrambled password into the request */
insert_scrambled_password(h, srv); if (h->pass_pos != 0)
insert_scrambled_password(h, srv);
/* Send the request */ /* Send the request */
n = sendto(h->fd, h->request, h->req_len, 0, n = sendto(h->fd, h->request, h->req_len, 0,

View File

@ -74,6 +74,7 @@ struct rad_handle {
char pass[PASSSIZE]; /* Cleartext password */ char pass[PASSSIZE]; /* Cleartext password */
int pass_len; /* Length of cleartext password */ int pass_len; /* Length of cleartext password */
int pass_pos; /* Position of scrambled password */ int pass_pos; /* Position of scrambled password */
unsigned chap_pass : 1; /* Have we got a CHAP_PASSWORD ? */
unsigned char response[MSGSIZE]; /* Response received */ unsigned char response[MSGSIZE]; /* Response received */
int resp_len; /* Length of response */ int resp_len; /* Length of response */
int resp_pos; /* Current position scanning attrs */ int resp_pos; /* Current position scanning attrs */