X-Git-Url: https://jfr.im/git/irc/evilnet/x3.git/blobdiff_plain/2f61d1d75ac52f239e760ecea02332eedc4682bd..2a4ca4f5366334e265a218563985abd4860b5d02:/src/hash.c diff --git a/src/hash.c b/src/hash.c index dd35e06..e0ce1f9 100644 --- a/src/hash.c +++ b/src/hash.c @@ -3,9 +3,9 @@ * * This file is part of x3. * - * srvx is free software; you can redistribute it and/or modify + * x3 is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or + * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, @@ -23,6 +23,14 @@ #include "hash.h" #include "log.h" +#if defined(HAVE_LIBGEOIP)&&defined(HAVE_GEOIP_H)&&defined(HAVE_GEOIPCITY_H) +#include +#include + +GeoIP * gi = NULL; +GeoIP * cgi = NULL; +#endif + struct server *self; dict_t channels; dict_t clients; @@ -189,6 +197,40 @@ NickChange(struct userNode* user, const char *new_nick, int no_announce) free(old_nick); } +void +SVSNickChange(struct userNode* user, const char *new_nick) +{ + char *old_nick; + unsigned int nn; + + /* don't do anything if there's no change */ + old_nick = user->nick; + if (!strncmp(new_nick, old_nick, NICKLEN)) + return; + + /* remove old entry from clients dictionary */ + dict_remove(clients, old_nick); +#if !defined(WITH_PROTOCOL_P10) + /* Remove from uplink's clients dict */ + dict_remove(user->uplink->users, old_nick); +#endif + /* and reinsert */ + user->nick = strdup(new_nick); + dict_insert(clients, user->nick, user); +#if !defined(WITH_PROTOCOL_P10) + dict_insert(user->uplink->users, user->nick, user); +#endif + + /* Make callbacks for nick changes. Do this with new nick in + * place because that is slightly more useful. + */ + for (nn=0; nntimestamp = now; + + free(old_nick); +} + struct userNode * GetUserH(const char *nick) { @@ -246,6 +288,57 @@ assign_fakehost(struct userNode *user, const char *host, int announce) irc_fakehost(user, host); } +void +set_geoip_info(struct userNode *user) +{ + if(IsLocal(user)) + return; +/* Need the libs and the headers if this is going to compile properly */ +#if defined(HAVE_LIBGEOIP)&&defined(HAVE_GEOIP_H)&&defined(HAVE_GEOIPCITY_H) + GeoIPRecord * gir; + const char *geoip_data_file = NULL; + const char *geoip_city_file = NULL; + + geoip_data_file = conf_get_data("services/opserv/geoip_data_file", RECDB_QSTRING); + geoip_city_file = conf_get_data("services/opserv/geoip_city_data_file", RECDB_QSTRING); + + if ((!geoip_data_file && !geoip_city_file)) + return; /* Admin doesnt want to use geoip functions */ + + if (geoip_data_file && !gi) + gi = GeoIP_open(geoip_data_file, GEOIP_MEMORY_CACHE | GEOIP_CHECK_CACHE); + + if (geoip_city_file && !cgi) + cgi = GeoIP_open(geoip_city_file, GEOIP_MEMORY_CACHE | GEOIP_CHECK_CACHE); + + if (cgi) { + gir = GeoIP_record_by_name(cgi, user->hostname); + if (gir) { + user->country_name = strdup(gir->country_name ? gir->country_name : ""); + user->country_code = strdup(gir->country_code ? gir->country_code : ""); + user->city = strdup(gir->city ? gir->city : ""); + user->region = strdup(gir->region ? gir->region : ""); + user->postal_code = strdup(gir->postal_code ? gir->postal_code : ""); + + user->latitude = gir->latitude ? gir->latitude : 0; + user->longitude = gir->longitude ? gir->longitude : 0; + user->dma_code = gir->dma_code ? gir->dma_code : 0; + user->area_code = gir->area_code ? gir->area_code : 0; + + GeoIPRecord_delete(gir); + } + + return; + } else if (gi) { + const char *country = GeoIP_country_name_by_name(gi, user->hostname); + user->country_name = strdup(country ? country : ""); + return; + } + + return; +#endif +} + static new_channel_func_t *ncf_list; static unsigned int ncf_size = 0, ncf_used = 0; @@ -607,11 +700,21 @@ DelChannelUser(struct userNode* user, struct chanNode* channel, const char *reas DelChannel(channel); } +static kick_func_t *kf_list; +static unsigned int kf_size = 0, kf_used = 0; + void KickChannelUser(struct userNode* target, struct chanNode* channel, struct userNode *kicker, const char *why) { + unsigned int n; + if (!target || !channel || IsService(target) || !GetUserMode(channel, target)) return; + + /* This may break things, but lets see.. -Rubin */ + for (n=0; n