+#include "cmd_neonserv.h"
+
/*
* argv[0] nick|*auth|*!*@mask
* argv[1-*] reason
*/
static USERLIST_CALLBACK(neonserv_cmd_addban_userlist_lookup);
-static void neonserv_cmd_addban_async1(struct ClientSocket *client, struct ClientSocket *textclient, struct UserNode *user, struct ChanNode *chan, char *mas, char *reason);
+static void neonserv_cmd_addban_async1(struct ClientSocket *client, struct ClientSocket *textclient, struct UserNode *user, struct ChanNode *chan, struct Event *event, char *mas, char *reason);
struct neonserv_cmd_addban_cache {
struct ClientSocket *client, *textclient;
struct UserNode *user;
+ struct Event *event;
char *mask;
char *reason;
};
-static CMD_BIND(neonserv_cmd_addban) {
+CMD_BIND(neonserv_cmd_addban) {
struct neonserv_cmd_addban_cache *cache = malloc(sizeof(*cache));
if (!cache) {
perror("malloc() failed");
cache->client = client;
cache->textclient = getTextBot();
cache->user = user;
+ cache->event = event;
cache->mask = strdup(argv[0]);
if(argc > 1) {
cache->reason = strdup(merge_argv(argv, 1, argc));
static USERLIST_CALLBACK(neonserv_cmd_addban_userlist_lookup) {
struct neonserv_cmd_addban_cache *cache = data;
- neonserv_cmd_addban_async1(cache->client, cache->textclient, cache->user, chan, cache->mask, (cache->reason ? cache->reason : "Bye."));
+ neonserv_cmd_addban_async1(cache->client, cache->textclient, cache->user, chan, cache->event, cache->mask, (cache->reason ? cache->reason : "Bye."));
free(cache->mask);
if(cache->reason)
free(cache->reason);
free(cache);
}
-static void neonserv_cmd_addban_async1(struct ClientSocket *client, struct ClientSocket *textclient, struct UserNode *user, struct ChanNode *chan, char *mask, char *reason) {
+static void neonserv_cmd_addban_async1(struct ClientSocket *client, struct ClientSocket *textclient, struct UserNode *user, struct ChanNode *chan, struct Event *event, char *mask, char *reason) {
int match_count = 0;
char hostmask_buffer[NICKLEN+USERLEN+HOSTLEN+3];
char usermask[NICKLEN+USERLEN+HOSTLEN+3];
}
}
reply(textclient, user, "NS_ADDBAN_DONE", mask, chan->name, match_count);
+ logEvent(event);
}