xref: /openbsd-src/regress/lib/libradius/test11.c (revision 0eaf192d8f98a1706afb2186171b5fb45b160397)
1*0eaf192dSyasuoka #include "incs.h"
2*0eaf192dSyasuoka 
3*0eaf192dSyasuoka #include <openssl/md5.h>
4*0eaf192dSyasuoka 
5*0eaf192dSyasuoka /*
6*0eaf192dSyasuoka  * accounting request authenticator
7*0eaf192dSyasuoka  */
8*0eaf192dSyasuoka 
test11(void)9*0eaf192dSyasuoka void test11(void)
10*0eaf192dSyasuoka {
11*0eaf192dSyasuoka 	RADIUS_PACKET *packet;
12*0eaf192dSyasuoka 	MD5_CTX ctx;
13*0eaf192dSyasuoka 
14*0eaf192dSyasuoka 	uint8_t packetdata[] = {
15*0eaf192dSyasuoka 		RADIUS_CODE_ACCOUNTING_REQUEST, 0x7f, 0, 31,
16*0eaf192dSyasuoka 		0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* auth */
17*0eaf192dSyasuoka 		10, 11, 'f', 'o', 'o', 'b', 'a', 'r', 'b', 'a', 'z',
18*0eaf192dSyasuoka 	};
19*0eaf192dSyasuoka 
20*0eaf192dSyasuoka 	packet = radius_new_request_packet(RADIUS_CODE_ACCOUNTING_REQUEST);
21*0eaf192dSyasuoka 	radius_set_id(packet, 0x7f);
22*0eaf192dSyasuoka 	radius_put_string_attr(packet, 10, "foobarbaz");
23*0eaf192dSyasuoka 	radius_set_accounting_request_authenticator(packet, "sharedsecret");
24*0eaf192dSyasuoka 
25*0eaf192dSyasuoka 	MD5_Init(&ctx);
26*0eaf192dSyasuoka 	MD5_Update(&ctx, packetdata, sizeof(packetdata));
27*0eaf192dSyasuoka 	MD5_Update(&ctx, "sharedsecret", 12);
28*0eaf192dSyasuoka 	MD5_Final(packetdata + 4, &ctx);
29*0eaf192dSyasuoka 
30*0eaf192dSyasuoka 	CHECK(radius_get_length(packet) == sizeof(packetdata));
31*0eaf192dSyasuoka 	CHECK(memcmp(radius_get_data(packet), packetdata, sizeof(packetdata)) == 0);
32*0eaf192dSyasuoka 	CHECK(radius_check_accounting_request_authenticator(packet, "sharedsecret") == 0);
33*0eaf192dSyasuoka 
34*0eaf192dSyasuoka 	radius_set_raw_attr(packet, 10, "zapzapzap", 9);
35*0eaf192dSyasuoka 	CHECK(radius_check_accounting_request_authenticator(packet, "sharedsecret") != 0);
36*0eaf192dSyasuoka }
37*0eaf192dSyasuoka 
38*0eaf192dSyasuoka ADD_TEST(test11)
39