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