mirror of
https://github.com/yarrick/iodine.git
synced 2024-11-25 02:55:15 +00:00
Make user.c independent of server for tests, add util.o to testobjs
This commit is contained in:
parent
122e42a5f7
commit
ad4aa69be1
22
src/server.c
22
src/server.c
@ -828,7 +828,7 @@ handle_raw_login(uint8_t *packet, size_t len, struct query *q, int fd, int useri
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (userid < 0 || userid >= created_users ||
|
if (userid < 0 || userid >= created_users ||
|
||||||
check_authenticated_user_and_ip(userid, q) != 0) {
|
check_authenticated_user_and_ip(userid, q, server.check_ip) != 0) {
|
||||||
DEBUG(2, "User %d not authenticated, ignoring raw login!", userid);
|
DEBUG(2, "User %d not authenticated, ignoring raw login!", userid);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -857,7 +857,7 @@ handle_raw_login(uint8_t *packet, size_t len, struct query *q, int fd, int useri
|
|||||||
static void
|
static void
|
||||||
handle_raw_data(uint8_t *packet, size_t len, struct query *q, int userid)
|
handle_raw_data(uint8_t *packet, size_t len, struct query *q, int userid)
|
||||||
{
|
{
|
||||||
if (check_authenticated_user_and_ip(userid, q) != 0) {
|
if (check_authenticated_user_and_ip(userid, q, server.check_ip) != 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!users[userid].authenticated_raw) return;
|
if (!users[userid].authenticated_raw) return;
|
||||||
@ -875,7 +875,7 @@ handle_raw_data(uint8_t *packet, size_t len, struct query *q, int userid)
|
|||||||
static void
|
static void
|
||||||
handle_raw_ping(struct query *q, int dns_fd, int userid)
|
handle_raw_ping(struct query *q, int dns_fd, int userid)
|
||||||
{
|
{
|
||||||
if (check_authenticated_user_and_ip(userid, q) != 0) {
|
if (check_authenticated_user_and_ip(userid, q, server.check_ip) != 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!users[userid].authenticated_raw) return;
|
if (!users[userid].authenticated_raw) return;
|
||||||
@ -1218,7 +1218,7 @@ handle_null_request(int dns_fd, struct query *q, int domain_len)
|
|||||||
userid = unpacked[0];
|
userid = unpacked[0];
|
||||||
DEBUG(2, "Received login request for user %d from %s.",
|
DEBUG(2, "Received login request for user %d from %s.",
|
||||||
userid, format_addr(&q->from, q->fromlen));
|
userid, format_addr(&q->from, q->fromlen));
|
||||||
if (check_user_and_ip(userid, q) != 0) {
|
if (check_user_and_ip(userid, q, server.check_ip) != 0) {
|
||||||
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
||||||
syslog(LOG_WARNING, "dropped login request from user #%d from %s; expected source %s",
|
syslog(LOG_WARNING, "dropped login request from user #%d from %s; expected source %s",
|
||||||
userid, format_addr(&q->from, q->fromlen), format_addr(&users[userid].host, users[userid].hostlen));
|
userid, format_addr(&q->from, q->fromlen), format_addr(&users[userid].host, users[userid].hostlen));
|
||||||
@ -1257,7 +1257,7 @@ handle_null_request(int dns_fd, struct query *q, int domain_len)
|
|||||||
int length;
|
int length;
|
||||||
|
|
||||||
userid = b32_8to5(in[1]);
|
userid = b32_8to5(in[1]);
|
||||||
if (check_authenticated_user_and_ip(userid, q) != 0) {
|
if (check_authenticated_user_and_ip(userid, q, server.check_ip) != 0) {
|
||||||
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
||||||
return; /* illegal id */
|
return; /* illegal id */
|
||||||
}
|
}
|
||||||
@ -1297,7 +1297,7 @@ handle_null_request(int dns_fd, struct query *q, int domain_len)
|
|||||||
|
|
||||||
userid = b32_8to5(in[1]);
|
userid = b32_8to5(in[1]);
|
||||||
|
|
||||||
if (check_authenticated_user_and_ip(userid, q) != 0) {
|
if (check_authenticated_user_and_ip(userid, q, server.check_ip) != 0) {
|
||||||
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
||||||
return; /* illegal id */
|
return; /* illegal id */
|
||||||
}
|
}
|
||||||
@ -1343,7 +1343,7 @@ handle_null_request(int dns_fd, struct query *q, int domain_len)
|
|||||||
|
|
||||||
userid = b32_8to5(in[1]);
|
userid = b32_8to5(in[1]);
|
||||||
|
|
||||||
if (check_authenticated_user_and_ip(userid, q) != 0) {
|
if (check_authenticated_user_and_ip(userid, q, server.check_ip) != 0) {
|
||||||
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
||||||
return; /* illegal id */
|
return; /* illegal id */
|
||||||
}
|
}
|
||||||
@ -1482,7 +1482,7 @@ handle_null_request(int dns_fd, struct query *q, int domain_len)
|
|||||||
read = unpack_data(unpacked, sizeof(unpacked), in + 1, 5, b32);
|
read = unpack_data(unpacked, sizeof(unpacked), in + 1, 5, b32);
|
||||||
|
|
||||||
userid = unpacked[0];
|
userid = unpacked[0];
|
||||||
if (check_authenticated_user_and_ip(userid, q) != 0) {
|
if (check_authenticated_user_and_ip(userid, q, server.check_ip) != 0) {
|
||||||
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
||||||
return; /* illegal id */
|
return; /* illegal id */
|
||||||
}
|
}
|
||||||
@ -1519,7 +1519,7 @@ handle_null_request(int dns_fd, struct query *q, int domain_len)
|
|||||||
|
|
||||||
/* Downstream fragsize packet */
|
/* Downstream fragsize packet */
|
||||||
userid = unpacked[0];
|
userid = unpacked[0];
|
||||||
if (check_authenticated_user_and_ip(userid, q) != 0) {
|
if (check_authenticated_user_and_ip(userid, q, server.check_ip) != 0) {
|
||||||
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
||||||
return; /* illegal id */
|
return; /* illegal id */
|
||||||
}
|
}
|
||||||
@ -1550,7 +1550,7 @@ handle_null_request(int dns_fd, struct query *q, int domain_len)
|
|||||||
|
|
||||||
/* Check userid */
|
/* Check userid */
|
||||||
userid = unpacked[0];
|
userid = unpacked[0];
|
||||||
if (check_authenticated_user_and_ip(userid, q) != 0) {
|
if (check_authenticated_user_and_ip(userid, q, server.check_ip) != 0) {
|
||||||
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
||||||
return; /* illegal id */
|
return; /* illegal id */
|
||||||
}
|
}
|
||||||
@ -1628,7 +1628,7 @@ handle_null_request(int dns_fd, struct query *q, int domain_len)
|
|||||||
|
|
||||||
userid = code;
|
userid = code;
|
||||||
/* Check user and sending IP address */
|
/* Check user and sending IP address */
|
||||||
if (check_authenticated_user_and_ip(userid, q) != 0) {
|
if (check_authenticated_user_and_ip(userid, q, server.check_ip) != 0) {
|
||||||
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
write_dns(dns_fd, q, "BADIP", 5, 'T');
|
||||||
return; /* illegal IP */
|
return; /* illegal IP */
|
||||||
}
|
}
|
||||||
|
14
src/user.c
14
src/user.c
@ -35,7 +35,6 @@
|
|||||||
#include "encoding.h"
|
#include "encoding.h"
|
||||||
#include "user.h"
|
#include "user.h"
|
||||||
#include "window.h"
|
#include "window.h"
|
||||||
#include "server.h"
|
|
||||||
|
|
||||||
struct tun_user *users;
|
struct tun_user *users;
|
||||||
unsigned usercount;
|
unsigned usercount;
|
||||||
@ -78,11 +77,6 @@ init_users(in_addr_t my_ip, int netbits)
|
|||||||
snprintf(newip, sizeof(newip), "0.0.0.%d", i + skip + 1);
|
snprintf(newip, sizeof(newip), "0.0.0.%d", i + skip + 1);
|
||||||
ip = ipstart.s_addr + inet_addr(newip);
|
ip = ipstart.s_addr + inet_addr(newip);
|
||||||
}
|
}
|
||||||
if (server.debug >= 2) {
|
|
||||||
struct in_addr IP;
|
|
||||||
IP.s_addr = ip;
|
|
||||||
DEBUG(2, "User %d: IP %s", i, inet_ntoa(IP));
|
|
||||||
}
|
|
||||||
users[i].tun_ip = ip;
|
users[i].tun_ip = ip;
|
||||||
net.s_addr = ip;
|
net.s_addr = ip;
|
||||||
|
|
||||||
@ -191,7 +185,7 @@ user_set_conn_type(int userid, enum connection c)
|
|||||||
|
|
||||||
/* This will not check that user has passed login challenge */
|
/* This will not check that user has passed login challenge */
|
||||||
int
|
int
|
||||||
check_user_and_ip(int userid, struct query *q)
|
check_user_and_ip(int userid, struct query *q, int check_ip)
|
||||||
{
|
{
|
||||||
/* Note: duplicate in handle_raw_login() except IP-address check */
|
/* Note: duplicate in handle_raw_login() except IP-address check */
|
||||||
|
|
||||||
@ -201,7 +195,7 @@ check_user_and_ip(int userid, struct query *q)
|
|||||||
if (!user_active(userid)) return 1;
|
if (!user_active(userid)) return 1;
|
||||||
|
|
||||||
/* return early if IP checking is disabled */
|
/* return early if IP checking is disabled */
|
||||||
if (!server.check_ip) {
|
if (!check_ip) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -229,11 +223,11 @@ check_user_and_ip(int userid, struct query *q)
|
|||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
check_authenticated_user_and_ip(int userid, struct query *q)
|
check_authenticated_user_and_ip(int userid, struct query *q, int check_ip)
|
||||||
/* This checks that user has passed normal (non-raw) login challenge
|
/* This checks that user has passed normal (non-raw) login challenge
|
||||||
* Returns 0 on success, 1 if user is not authenticated/IP is wrong */
|
* Returns 0 on success, 1 if user is not authenticated/IP is wrong */
|
||||||
{
|
{
|
||||||
int res = check_user_and_ip(userid, q);
|
int res = check_user_and_ip(userid, q, check_ip);
|
||||||
if (res)
|
if (res)
|
||||||
return res;
|
return res;
|
||||||
|
|
||||||
|
@ -54,8 +54,8 @@ extern int created_users;
|
|||||||
int user_sending(int user);
|
int user_sending(int user);
|
||||||
int all_users_waiting_to_send();
|
int all_users_waiting_to_send();
|
||||||
int user_active(int i);
|
int user_active(int i);
|
||||||
int check_authenticated_user_and_ip(int userid, struct query *q);
|
int check_authenticated_user_and_ip(int userid, struct query *q, int check_ip);
|
||||||
int check_user_and_ip(int userid, struct query *q);
|
int check_user_and_ip(int userid, struct query *q, int check_ip);
|
||||||
|
|
||||||
int init_users(in_addr_t, int);
|
int init_users(in_addr_t, int);
|
||||||
const char* users_get_first_ip();
|
const char* users_get_first_ip();
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
TEST = test
|
TEST = test
|
||||||
OBJS = test.o base32.o base64.o common.o read.o dns.o encoding.o login.o user.o fw_query.o window.o
|
OBJS = test.o base32.o base64.o common.o read.o dns.o encoding.o login.o user.o fw_query.o window.o
|
||||||
SRCOBJS = ../src/base32.o ../src/base64.o ../src/window.o ../src/common.o ../src/read.o ../src/dns.o ../src/encoding.o ../src/login.o ../src/md5.o ../src/user.o ../src/fw_query.o
|
SRCOBJS = ../src/base32.o ../src/base64.o ../src/window.o ../src/common.o ../src/read.o ../src/dns.o ../src/encoding.o ../src/login.o ../src/md5.o ../src/user.o ../src/fw_query.o ../src/util.o
|
||||||
|
|
||||||
OS = `uname | tr "a-z" "A-Z"`
|
OS = `uname | tr "a-z" "A-Z"`
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user