diff options
author | Volker Lendecke <vl@samba.org> | 2011-01-05 14:35:11 +0100 |
---|---|---|
committer | Volker Lendecke <vl@samba.org> | 2011-01-07 13:28:07 +0100 |
commit | dab6a35f4cf6a7e8a3c05319e891e06887d63998 (patch) | |
tree | e97a8aaf88b711b47e46d6eeed173f35d7cbf9e4 /source3 | |
parent | 0cff82e054cea6b473dcfa6de840ece7327ef6ca (diff) | |
download | samba-dab6a35f4cf6a7e8a3c05319e891e06887d63998.tar.gz samba-dab6a35f4cf6a7e8a3c05319e891e06887d63998.tar.bz2 samba-dab6a35f4cf6a7e8a3c05319e891e06887d63998.zip |
s3: Limit the number of unexpected clients to 200
DoS protection like the max winbind clients. Settable by
nmbd:unexpected_clients
Diffstat (limited to 'source3')
-rw-r--r-- | source3/libsmb/unexpected.c | 9 | ||||
-rw-r--r-- | source3/nmbd/nmbd_packets.c | 6 |
2 files changed, 13 insertions, 2 deletions
diff --git a/source3/libsmb/unexpected.c b/source3/libsmb/unexpected.c index 7ec5800e69..4543ffe7c6 100644 --- a/source3/libsmb/unexpected.c +++ b/source3/libsmb/unexpected.c @@ -481,6 +481,15 @@ static void nb_packet_server_listener(struct tevent_context *ev, DLIST_ADD(server->clients, client); server->num_clients += 1; + + if (server->num_clients > server->max_clients) { + DEBUG(10, ("Too many clients, dropping oldest\n")); + + /* + * no TALLOC_FREE here, don't mess with the list structs + */ + talloc_free(server->clients->prev); + } } static ssize_t nb_packet_client_more(uint8_t *buf, size_t buflen, diff --git a/source3/nmbd/nmbd_packets.c b/source3/nmbd/nmbd_packets.c index ec5225a5ec..c2a5204fac 100644 --- a/source3/nmbd/nmbd_packets.c +++ b/source3/nmbd/nmbd_packets.c @@ -37,8 +37,10 @@ bool nmbd_init_packet_server(void) { NTSTATUS status; - status = nb_packet_server_create(NULL, nmbd_event_context(), 0, - &packet_server); + status = nb_packet_server_create( + NULL, nmbd_event_context(), + lp_parm_int(-1, "nmbd", "unexpected_clients", 200), + &packet_server); if (!NT_STATUS_IS_OK(status)) { DEBUG(0, ("ERROR: nb_packet_server_create failed: %s\n", nt_errstr(status))); |