MAMADOO chat sux
This commit is contained in:
parent
76002fe2dd
commit
75458e014b
@ -384,7 +384,8 @@ static int read_socket_SSL(connection_t *cn)
|
|||||||
|| err == SSL_ERROR_WANT_ACCEPT)
|
|| err == SSL_ERROR_WANT_ACCEPT)
|
||||||
return 0;
|
return 0;
|
||||||
if (cn_is_connected(cn)) {
|
if (cn_is_connected(cn)) {
|
||||||
mylog(LOG_DEBUG, "fd %d: Connection error",cn->handle);
|
mylog(LOG_DEBUGTOOMUCH, "fd %d: Connection error",
|
||||||
|
cn->handle);
|
||||||
cn->connected = CONN_ERROR;
|
cn->connected = CONN_ERROR;
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
@ -395,7 +396,8 @@ static int read_socket_SSL(connection_t *cn)
|
|||||||
|| err == SSL_ERROR_WANT_ACCEPT)
|
|| err == SSL_ERROR_WANT_ACCEPT)
|
||||||
return 0;*/
|
return 0;*/
|
||||||
if (cn_is_connected(cn)) {
|
if (cn_is_connected(cn)) {
|
||||||
mylog(LOG_DEBUG, "fd %d: Connection lost",cn->handle);
|
mylog(LOG_DEBUGTOOMUCH, "fd %d: Connection lost",
|
||||||
|
cn->handle);
|
||||||
cn->connected = CONN_DISCONN;
|
cn->connected = CONN_DISCONN;
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
@ -420,8 +422,9 @@ static int read_socket(connection_t *cn)
|
|||||||
if (errno == EAGAIN || errno == EINTR || errno == EINPROGRESS)
|
if (errno == EAGAIN || errno == EINTR || errno == EINPROGRESS)
|
||||||
return 0;
|
return 0;
|
||||||
if (cn_is_connected(cn)) {
|
if (cn_is_connected(cn)) {
|
||||||
mylog(LOG_DEBUG, "fd %d: Connection error",cn->handle);
|
mylog(LOG_DEBUG, "fd %d: Connection error",
|
||||||
mylog(LOG_DEBUG, "fd %d: read() %s", cn->handle,
|
cn->handle);
|
||||||
|
mylog(LOG_DEBUGTOOMUCH, "fd %d: read() %s", cn->handle,
|
||||||
strerror(errno));
|
strerror(errno));
|
||||||
cn->connected = CONN_ERROR;
|
cn->connected = CONN_ERROR;
|
||||||
}
|
}
|
||||||
@ -430,7 +433,7 @@ static int read_socket(connection_t *cn)
|
|||||||
if (cn_is_connected(cn)) {
|
if (cn_is_connected(cn)) {
|
||||||
mylog(LOG_DEBUG, "fd %d: Connection lost", cn->handle);
|
mylog(LOG_DEBUG, "fd %d: Connection lost", cn->handle);
|
||||||
cn->connected = CONN_DISCONN;
|
cn->connected = CONN_DISCONN;
|
||||||
mylog(LOG_DEBUG, "fd %d: read() %s", cn->handle,
|
mylog(LOG_DEBUGTOOMUCH, "fd %d: read() %s", cn->handle,
|
||||||
strerror(errno));
|
strerror(errno));
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
@ -533,7 +536,7 @@ static int check_event_except(fd_set *fds, connection_t *cn)
|
|||||||
if (!FD_ISSET(cn->handle, fds))
|
if (!FD_ISSET(cn->handle, fds))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
mylog(LOG_DEBUG,"fd %d is in exceptions list", cn->handle);
|
mylog(LOG_DEBUGTOOMUCH,"fd %d is in exceptions list", cn->handle);
|
||||||
cn->connected = CONN_EXCEPT;
|
cn->connected = CONN_EXCEPT;
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
74
src/irc.c
74
src/irc.c
@ -214,6 +214,9 @@ static int irc_001(struct link_server *server, struct line *line)
|
|||||||
oldircmask = server->irc_mask;
|
oldircmask = server->irc_mask;
|
||||||
server->irc_mask = NULL;
|
server->irc_mask = NULL;
|
||||||
set_ircmask(server, ircmask);
|
set_ircmask(server, ircmask);
|
||||||
|
if (server->nick)
|
||||||
|
free(server->nick);
|
||||||
|
server->nick = nick_from_ircmask(ircmask);
|
||||||
if (server->irc_mask == NULL)
|
if (server->irc_mask == NULL)
|
||||||
server->irc_mask = make_irc_mask(server->nick, "");
|
server->irc_mask = make_irc_mask(server->nick, "");
|
||||||
|
|
||||||
@ -386,6 +389,7 @@ int irc_dispatch_server(struct link_server *server, struct line *line)
|
|||||||
}
|
}
|
||||||
free(server->nick);
|
free(server->nick);
|
||||||
server->nick = newnick;
|
server->nick = newnick;
|
||||||
|
printf("nick2: %s\n", server->nick);
|
||||||
|
|
||||||
WRITE_LINE1(CONN(server), NULL, "NICK", server->nick);
|
WRITE_LINE1(CONN(server), NULL, "NICK", server->nick);
|
||||||
ret = OK_FORGET;
|
ret = OK_FORGET;
|
||||||
@ -656,7 +660,12 @@ static int irc_cli_startup(struct link_client *ic, struct line *line,
|
|||||||
|
|
||||||
TYPE(ic) = IRC_TYPE_CLIENT;
|
TYPE(ic) = IRC_TYPE_CLIENT;
|
||||||
|
|
||||||
initmask = make_irc_mask(init_nick, LINK(ic)->l_server->irc_mask);
|
if (LINK(ic)->l_server)
|
||||||
|
initmask = make_irc_mask(init_nick,
|
||||||
|
LINK(ic)->l_server->irc_mask);
|
||||||
|
else
|
||||||
|
initmask = make_irc_mask(init_nick, LINK(ic)->prev_ircmask);
|
||||||
|
|
||||||
for (list_it_init(&LINK(ic)->init_strings, &it);
|
for (list_it_init(&LINK(ic)->init_strings, &it);
|
||||||
list_it_item(&it); list_it_next(&it))
|
list_it_item(&it); list_it_next(&it))
|
||||||
write_init_string(CONN(ic), list_it_item(&it), init_nick);
|
write_init_string(CONN(ic), list_it_item(&it), init_nick);
|
||||||
@ -680,30 +689,35 @@ static int irc_cli_startup(struct link_client *ic, struct line *line,
|
|||||||
return OK_FORGET;
|
return OK_FORGET;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* join channels, step one, those in conf, in order */
|
if (LINK(ic)->l_server) {
|
||||||
list_iterator_t li;
|
/* join channels, step one, those in conf, in order */
|
||||||
for (list_it_init(&LINK(ic)->chan_infos_order, &li);
|
list_iterator_t li;
|
||||||
list_it_item(&li); list_it_next(&li)) {
|
for (list_it_init(&LINK(ic)->chan_infos_order, &li);
|
||||||
struct chan_info *ci = (struct chan_info *)list_it_item(&li);
|
list_it_item(&li); list_it_next(&li)) {
|
||||||
struct channel *chan;
|
struct chan_info *ci = (struct chan_info *)
|
||||||
if ((chan = hash_get(&LINK(ic)->l_server->channels, ci->name)))
|
list_it_item(&li);
|
||||||
irc_send_join(ic, chan);
|
struct channel *chan;
|
||||||
}
|
if ((chan = hash_get(&LINK(ic)->l_server->channels,
|
||||||
|
ci->name)))
|
||||||
|
irc_send_join(ic, chan);
|
||||||
|
}
|
||||||
|
|
||||||
/* step two, those not in conf */
|
/* step two, those not in conf */
|
||||||
hash_iterator_t hi;
|
hash_iterator_t hi;
|
||||||
for (hash_it_init(&LINK(ic)->l_server->channels, &hi);
|
for (hash_it_init(&LINK(ic)->l_server->channels, &hi);
|
||||||
hash_it_item(&hi); hash_it_next(&hi)) {
|
hash_it_item(&hi); hash_it_next(&hi)) {
|
||||||
struct channel *chan = (struct channel *)hash_it_item(&hi);
|
struct channel *chan = (struct channel *)
|
||||||
if (!hash_get(&LINK(ic)->chan_infos, chan->name))
|
hash_it_item(&hi);
|
||||||
irc_send_join(ic, chan);
|
if (!hash_get(&LINK(ic)->chan_infos, chan->name))
|
||||||
}
|
irc_send_join(ic, chan);
|
||||||
|
}
|
||||||
|
|
||||||
/* backlog privates */
|
/* backlog privates */
|
||||||
char *str;
|
char *str;
|
||||||
while ((str = log_backread(LINK(ic)->log, S_PRIVATES))) {
|
while ((str = log_backread(LINK(ic)->log, S_PRIVATES))) {
|
||||||
write_line(CONN(ic), str);
|
write_line(CONN(ic), str);
|
||||||
free(str);
|
free(str);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
log_client_connected(LINK(ic)->log);
|
log_client_connected(LINK(ic)->log);
|
||||||
@ -946,6 +960,11 @@ static int irc_dispatch_client(struct link_client *ic, struct line *line)
|
|||||||
return ERR_PROTOCOL;
|
return ERR_PROTOCOL;
|
||||||
WRITE_LINE1(CONN(ic), LINK(ic)->name, "PONG", line->elemv[1]);
|
WRITE_LINE1(CONN(ic), LINK(ic)->name, "PONG", line->elemv[1]);
|
||||||
r = OK_FORGET;
|
r = OK_FORGET;
|
||||||
|
} else if (LINK(ic)->s_state != IRCS_CONNECTED) {
|
||||||
|
write_line_fast(CONN(ic), ":irc.bip.net NOTICE pouet "
|
||||||
|
":ERROR Proxy not connected, please wait "
|
||||||
|
"before sending commands\r\n");
|
||||||
|
r = OK_FORGET;
|
||||||
} else if (strcasecmp(line->elemv[0], "BIP") == 0) {
|
} else if (strcasecmp(line->elemv[0], "BIP") == 0) {
|
||||||
r = irc_cli_bip(ic, line);
|
r = irc_cli_bip(ic, line);
|
||||||
} else if (strcmp(line->elemv[0], "JOIN") == 0) {
|
} else if (strcmp(line->elemv[0], "JOIN") == 0) {
|
||||||
@ -1584,6 +1603,7 @@ static int irc_nick(struct link_server *server, struct line *line)
|
|||||||
char *nim;
|
char *nim;
|
||||||
free(server->nick);
|
free(server->nick);
|
||||||
server->nick = strdup(line->elemv[1]);
|
server->nick = strdup(line->elemv[1]);
|
||||||
|
printf("nick3: %s\n", server->nick);
|
||||||
|
|
||||||
/* How the hell do we handle that crap cleanly ? */
|
/* How the hell do we handle that crap cleanly ? */
|
||||||
nim = make_irc_mask(line->elemv[1], server->irc_mask);
|
nim = make_irc_mask(line->elemv[1], server->irc_mask);
|
||||||
@ -1668,6 +1688,7 @@ static void irc_server_startup(struct link_server *ircs)
|
|||||||
}
|
}
|
||||||
|
|
||||||
ircs->nick = nick;
|
ircs->nick = nick;
|
||||||
|
printf("nick1: %s\n", ircs->nick);
|
||||||
WRITE_LINE1(CONN(ircs), NULL, "NICK", ircs->nick);
|
WRITE_LINE1(CONN(ircs), NULL, "NICK", ircs->nick);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1724,6 +1745,7 @@ void server_cleanup(struct link_server *server)
|
|||||||
CONN(server) = NULL;
|
CONN(server) = NULL;
|
||||||
}
|
}
|
||||||
irc_lag_init(server);
|
irc_lag_init(server);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void irc_client_close(struct link_client *ic)
|
void irc_client_close(struct link_client *ic)
|
||||||
@ -1769,9 +1791,9 @@ static void irc_close(struct link_any *l)
|
|||||||
mylog(LOG_ERROR, "%s dead, reconnecting in %d seconds",
|
mylog(LOG_ERROR, "%s dead, reconnecting in %d seconds",
|
||||||
LINK(l)->name, timer);
|
LINK(l)->name, timer);
|
||||||
LINK(is)->recon_timer = timer;
|
LINK(is)->recon_timer = timer;
|
||||||
LINK(is)->l_server = NULL;
|
|
||||||
|
|
||||||
irc_server_free((struct link_server *)is);
|
irc_server_free((struct link_server *)is);
|
||||||
|
LINK(is)->l_server = NULL;
|
||||||
} else {
|
} else {
|
||||||
irc_client_close((struct link_client *)l);
|
irc_client_close((struct link_client *)l);
|
||||||
}
|
}
|
||||||
@ -1853,6 +1875,10 @@ void irc_server_shutdown(struct link_server *s)
|
|||||||
if (LINK(s)->prev_nick)
|
if (LINK(s)->prev_nick)
|
||||||
free(LINK(s)->prev_nick);
|
free(LINK(s)->prev_nick);
|
||||||
LINK(s)->prev_nick = strdup(s->nick);
|
LINK(s)->prev_nick = strdup(s->nick);
|
||||||
|
|
||||||
|
if (LINK(s)->prev_ircmask)
|
||||||
|
free(LINK(s)->prev_ircmask);
|
||||||
|
LINK(s)->prev_ircmask = strdup(s->irc_mask);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -65,6 +65,7 @@ struct link {
|
|||||||
/* server related live stuff */
|
/* server related live stuff */
|
||||||
int s_state;
|
int s_state;
|
||||||
char *prev_nick;
|
char *prev_nick;
|
||||||
|
char *prev_ircmask;
|
||||||
list_t init_strings;
|
list_t init_strings;
|
||||||
|
|
||||||
/* connection state (reconnecting, was_connected ...) */
|
/* connection state (reconnecting, was_connected ...) */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user