adm_reply -> bip_notify
This commit is contained in:
parent
dd49be1755
commit
72b028221d
166
src/bip.c
166
src/bip.c
@ -54,7 +54,7 @@ static void conf_die(char *fmt, ...);
|
|||||||
int adm_trust(struct link_client *ic, struct line *line);
|
int adm_trust(struct link_client *ic, struct line *line);
|
||||||
#endif
|
#endif
|
||||||
static char *get_tuple_value(list_t *tuple_l, int lex);
|
static char *get_tuple_value(list_t *tuple_l, int lex);
|
||||||
void adm_reply(struct link_client *ic, char *str);
|
void bip_notify(struct link_client *ic, char *fmt, ...);
|
||||||
void adm_list_connections(struct link_client *ic, struct user *bu);
|
void adm_list_connections(struct link_client *ic, struct user *bu);
|
||||||
|
|
||||||
static void hash_binary(char *hex, unsigned char **password, unsigned int *seed)
|
static void hash_binary(char *hex, unsigned char **password, unsigned int *seed)
|
||||||
@ -273,6 +273,7 @@ void rlimit_cpu_reached(int i)
|
|||||||
{
|
{
|
||||||
mylog(LOG_WARN, "This process has reached the CPU time usage limit. "
|
mylog(LOG_WARN, "This process has reached the CPU time usage limit. "
|
||||||
"It means bip will be killed by the Operating System soon.");
|
"It means bip will be killed by the Operating System soon.");
|
||||||
|
#warning CODEME warn all users via bip_notify
|
||||||
}
|
}
|
||||||
|
|
||||||
void rlimit_bigfile_reached(int i)
|
void rlimit_bigfile_reached(int i)
|
||||||
@ -280,6 +281,7 @@ void rlimit_bigfile_reached(int i)
|
|||||||
mylog(LOG_WARN, "A file has reached the max size this process is "
|
mylog(LOG_WARN, "A file has reached the max size this process is "
|
||||||
"allowed to create. The file will not be written correctly, "
|
"allowed to create. The file will not be written correctly, "
|
||||||
"an error message should follow. This is not fatal.");
|
"an error message should follow. This is not fatal.");
|
||||||
|
#warning CODEME warn all users via bip_notify ?
|
||||||
}
|
}
|
||||||
|
|
||||||
void bad_quit(int i)
|
void bad_quit(int i)
|
||||||
@ -839,7 +841,6 @@ int main(int argc, char **argv)
|
|||||||
signal(SIGQUIT, bad_quit);
|
signal(SIGQUIT, bad_quit);
|
||||||
signal(SIGTERM, bad_quit);
|
signal(SIGTERM, bad_quit);
|
||||||
signal(SIGXFSZ, rlimit_bigfile_reached);
|
signal(SIGXFSZ, rlimit_bigfile_reached);
|
||||||
/* TODO handle SIGXCPU => soft CPU limit reached */
|
|
||||||
signal(SIGXCPU, rlimit_cpu_reached);
|
signal(SIGXCPU, rlimit_cpu_reached);
|
||||||
|
|
||||||
conf_log_root = NULL;
|
conf_log_root = NULL;
|
||||||
@ -990,19 +991,14 @@ void adm_print_connection(struct link_client *ic, struct link *lnk, struct user
|
|||||||
|
|
||||||
if (!bu) {
|
if (!bu) {
|
||||||
bu = lnk->user;
|
bu = lnk->user;
|
||||||
snprintf(buf, 4095, "%s's links:", bu->name);
|
bip_notify(ic, "%s's links:", bu->name);
|
||||||
buf[4095] = 0;
|
|
||||||
adm_reply(ic, buf);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
snprintf(buf, 4095, "* %s to %s as \"%s\" (%s!%s) :",
|
bip_notify(ic, "* %s to %s as \"%s\" (%s!%s) :", lnk->name,
|
||||||
lnk->name, lnk->network->name,
|
lnk->network->name,
|
||||||
(lnk->realname ? lnk->realname : bu->default_realname),
|
(lnk->realname ? lnk->realname : bu->default_realname),
|
||||||
(lnk->connect_nick ? lnk->connect_nick : bu->default_nick),
|
(lnk->connect_nick ? lnk->connect_nick : bu->default_nick),
|
||||||
(lnk->username ? lnk->username : bu->default_username)
|
(lnk->username ? lnk->username : bu->default_username));
|
||||||
);
|
|
||||||
buf[4095] = 0;
|
|
||||||
adm_reply(ic, buf);
|
|
||||||
|
|
||||||
t_wrote += snprintf(buf, 4095, " Options:");
|
t_wrote += snprintf(buf, 4095, " Options:");
|
||||||
if (lnk->follow_nick)
|
if (lnk->follow_nick)
|
||||||
@ -1028,7 +1024,7 @@ void adm_print_connection(struct link_client *ic, struct link *lnk, struct user
|
|||||||
4095 - t_wrote, " bind_port=%u",
|
4095 - t_wrote, " bind_port=%u",
|
||||||
lnk->bind_port);
|
lnk->bind_port);
|
||||||
buf[4095] = 0;
|
buf[4095] = 0;
|
||||||
adm_reply(ic, buf);
|
bip_notify(ic, buf);
|
||||||
|
|
||||||
// TODO: on_connect_send
|
// TODO: on_connect_send
|
||||||
|
|
||||||
@ -1047,12 +1043,12 @@ void adm_print_connection(struct link_client *ic, struct link *lnk, struct user
|
|||||||
}
|
}
|
||||||
if (t_wrote > t_max_len) {
|
if (t_wrote > t_max_len) {
|
||||||
buf[4095] = 0;
|
buf[4095] = 0;
|
||||||
adm_reply(ic, buf);
|
bip_notify(ic, buf);
|
||||||
t_wrote = 0;
|
t_wrote = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
buf[4095] = 0;
|
buf[4095] = 0;
|
||||||
adm_reply(ic, buf);
|
bip_notify(ic, buf);
|
||||||
|
|
||||||
t_wrote = snprintf(buf, 4095, " Status: ");
|
t_wrote = snprintf(buf, 4095, " Status: ");
|
||||||
switch (lnk->s_state) {
|
switch (lnk->s_state) {
|
||||||
@ -1095,7 +1091,7 @@ void adm_print_connection(struct link_client *ic, struct link *lnk, struct user
|
|||||||
// s_conn_attempt recon_timer last_connection_attempt
|
// s_conn_attempt recon_timer last_connection_attempt
|
||||||
}
|
}
|
||||||
buf[4095] = 0;
|
buf[4095] = 0;
|
||||||
adm_reply(ic, buf);
|
bip_notify(ic, buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
void adm_list_all_links(struct link_client *ic)
|
void adm_list_all_links(struct link_client *ic)
|
||||||
@ -1128,13 +1124,13 @@ void adm_info_user(struct link_client *ic, char *name)
|
|||||||
|
|
||||||
u = hash_get(&_bip->users, name);
|
u = hash_get(&_bip->users, name);
|
||||||
if (!u) {
|
if (!u) {
|
||||||
adm_reply(ic, "Unknown user");
|
bip_notify(ic, "Unknown user");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
//t_wrote += snprintf(buf + t_wrote, 4095 - t_wrote, "");
|
//t_wrote += snprintf(buf + t_wrote, 4095 - t_wrote, "");
|
||||||
//buf[4095] = 0;
|
//buf[4095] = 0;
|
||||||
//adm_reply(ic, buf);
|
//bip_notify(ic, buf);
|
||||||
//t_wrote = 0;
|
//t_wrote = 0;
|
||||||
|
|
||||||
t_wrote += snprintf(buf + t_wrote, 4095 - t_wrote, "user: %s", u->name);
|
t_wrote += snprintf(buf + t_wrote, 4095 - t_wrote, "user: %s", u->name);
|
||||||
@ -1142,33 +1138,25 @@ void adm_info_user(struct link_client *ic, char *name)
|
|||||||
t_wrote += snprintf(buf + t_wrote, 4095 - t_wrote, ", is bip admin");
|
t_wrote += snprintf(buf + t_wrote, 4095 - t_wrote, ", is bip admin");
|
||||||
|
|
||||||
buf[4095] = 0;
|
buf[4095] = 0;
|
||||||
adm_reply(ic, buf);
|
bip_notify(ic, buf);
|
||||||
t_wrote = 0;
|
t_wrote = 0;
|
||||||
|
|
||||||
#ifdef HAVE_LIBSSL
|
#ifdef HAVE_LIBSSL
|
||||||
snprintf(buf, 4095, "SSL check mode '%s', stored into '%s'",
|
bip_notify(ic, "SSL check mode '%s', stored into '%s'",
|
||||||
checkmode2text(u->ssl_check_mode), u->ssl_check_store);
|
checkmode2text(u->ssl_check_mode), u->ssl_check_store);
|
||||||
buf[4095] = 0;
|
|
||||||
adm_reply(ic, buf);
|
|
||||||
#endif
|
#endif
|
||||||
snprintf(buf, 4095, "Defaults nick: %s, user: %s, realname: %s",
|
bip_notify(ic, "Defaults nick: %s, user: %s, realname: %s",
|
||||||
u->default_nick, u->default_username, u->default_realname);
|
u->default_nick, u->default_username, u->default_realname);
|
||||||
buf[4095] = 0;
|
|
||||||
adm_reply(ic, buf);
|
|
||||||
if (u->backlog) {
|
if (u->backlog) {
|
||||||
snprintf(buf, 4095, "Backlog enabled, lines: %d, no timestamp: "
|
bip_notify(ic, "Backlog enabled, lines: %d, no timestamp: %s,"
|
||||||
"%s, messages only: %s", u->backlog_lines,
|
" messages only: %s", u->backlog_lines,
|
||||||
bool2text(u->backlog_no_timestamp),
|
bool2text(u->backlog_no_timestamp),
|
||||||
bool2text(u->bl_msg_only));
|
bool2text(u->bl_msg_only));
|
||||||
buf[4095] = 0;
|
bip_notify(ic, "always backlog: %s, reset on talk: %s",
|
||||||
adm_reply(ic, buf);
|
|
||||||
snprintf(buf, 4095, "always backlog: %s, reset on talk: %s",
|
|
||||||
bool2text(u->always_backlog),
|
bool2text(u->always_backlog),
|
||||||
bool2text(u->blreset_on_talk));
|
bool2text(u->blreset_on_talk));
|
||||||
buf[4095] = 0;
|
|
||||||
adm_reply(ic, buf);
|
|
||||||
} else {
|
} else {
|
||||||
adm_reply(ic, "Backlog disabled");
|
bip_notify(ic, "Backlog disabled");
|
||||||
}
|
}
|
||||||
adm_list_connections(ic, u);
|
adm_list_connections(ic, u);
|
||||||
}
|
}
|
||||||
@ -1182,7 +1170,7 @@ void adm_list_users(struct link_client *ic)
|
|||||||
|
|
||||||
c = CONN(ic);
|
c = CONN(ic);
|
||||||
|
|
||||||
adm_reply(ic, "bip user list:");
|
bip_notify(ic, "bip user list:");
|
||||||
for (hash_it_init(&_bip->users, &it); hash_it_item(&it);
|
for (hash_it_init(&_bip->users, &it); hash_it_item(&it);
|
||||||
hash_it_next(&it)) {
|
hash_it_next(&it)) {
|
||||||
struct user *u = hash_it_item(&it);
|
struct user *u = hash_it_item(&it);
|
||||||
@ -1206,14 +1194,14 @@ void adm_list_users(struct link_client *ic)
|
|||||||
" %s", lnk->name);
|
" %s", lnk->name);
|
||||||
if (t_wrote > t_max_len) {
|
if (t_wrote > t_max_len) {
|
||||||
buf[4095] = 0;
|
buf[4095] = 0;
|
||||||
adm_reply(ic, buf);
|
bip_notify(ic, buf);
|
||||||
t_wrote = 0;
|
t_wrote = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
buf[4095] = 0;
|
buf[4095] = 0;
|
||||||
adm_reply(ic, buf);
|
bip_notify(ic, buf);
|
||||||
}
|
}
|
||||||
adm_reply(ic, "End of bip user list");
|
bip_notify(ic, "End of bip user list");
|
||||||
}
|
}
|
||||||
|
|
||||||
void adm_list_networks(struct link_client *ic)
|
void adm_list_networks(struct link_client *ic)
|
||||||
@ -1224,7 +1212,7 @@ void adm_list_networks(struct link_client *ic)
|
|||||||
|
|
||||||
c = CONN(ic);
|
c = CONN(ic);
|
||||||
|
|
||||||
adm_reply(ic, "bip network list (* means SSL):");
|
bip_notify(ic, "bip network list (* means SSL):");
|
||||||
for (hash_it_init(&_bip->networks, &it); hash_it_item(&it);
|
for (hash_it_init(&_bip->networks, &it); hash_it_item(&it);
|
||||||
hash_it_next(&it)) {
|
hash_it_next(&it)) {
|
||||||
struct network *n = hash_it_item(&it);
|
struct network *n = hash_it_item(&it);
|
||||||
@ -1245,30 +1233,27 @@ void adm_list_networks(struct link_client *ic)
|
|||||||
serv->port);
|
serv->port);
|
||||||
if (t_wrote > t_max_len) {
|
if (t_wrote > t_max_len) {
|
||||||
buf[4095] = 0;
|
buf[4095] = 0;
|
||||||
adm_reply(ic, buf);
|
bip_notify(ic, buf);
|
||||||
t_wrote = 0;
|
t_wrote = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
buf[4095] = 0;
|
buf[4095] = 0;
|
||||||
adm_reply(ic, buf);
|
bip_notify(ic, buf);
|
||||||
}
|
}
|
||||||
adm_reply(ic, "End of bip network list");
|
bip_notify(ic, "End of bip network list");
|
||||||
}
|
}
|
||||||
|
|
||||||
void adm_list_connections(struct link_client *ic, struct user *bu)
|
void adm_list_connections(struct link_client *ic, struct user *bu)
|
||||||
{
|
{
|
||||||
hash_iterator_t it;
|
hash_iterator_t it;
|
||||||
char buf[4096];
|
|
||||||
connection_t *c;
|
connection_t *c;
|
||||||
|
|
||||||
c = CONN(ic);
|
c = CONN(ic);
|
||||||
if (!bu) {
|
if (!bu) {
|
||||||
adm_reply(ic, "Your connections:");
|
bip_notify(ic, "Your connections:");
|
||||||
bu = LINK(ic)->user;
|
bu = LINK(ic)->user;
|
||||||
} else {
|
} else {
|
||||||
snprintf(buf, 4095, "%s's connections:", bu->name);
|
bip_notify(ic, "%s's connections:", bu->name);
|
||||||
buf[4095] = 0;
|
|
||||||
adm_reply(ic, buf);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (hash_it_init(&bu->connections, &it); hash_it_item(&it);
|
for (hash_it_init(&bu->connections, &it); hash_it_item(&it);
|
||||||
@ -1276,7 +1261,7 @@ void adm_list_connections(struct link_client *ic, struct user *bu)
|
|||||||
struct link *lnk= hash_it_item(&it);
|
struct link *lnk= hash_it_item(&it);
|
||||||
adm_print_connection(ic, lnk, bu);
|
adm_print_connection(ic, lnk, bu);
|
||||||
}
|
}
|
||||||
adm_reply(ic, "End of bip connection list");
|
bip_notify(ic, "End of bip connection list");
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef HAVE_LIBSSL
|
#ifdef HAVE_LIBSSL
|
||||||
@ -1423,22 +1408,35 @@ int adm_trust(struct link_client *ic, struct line *line)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void adm_reply(struct link_client *ic, char *str)
|
void _bip_notify(struct link_client *ic, char *fmt, va_list ap)
|
||||||
{
|
{
|
||||||
char *nick;
|
char *nick;
|
||||||
|
char str[4096];
|
||||||
|
|
||||||
if (LINK(ic)->l_server)
|
if (LINK(ic)->l_server)
|
||||||
nick = LINK(ic)->l_server->nick;
|
nick = LINK(ic)->l_server->nick;
|
||||||
else
|
else
|
||||||
nick = LINK(ic)->prev_nick;
|
nick = LINK(ic)->prev_nick;
|
||||||
|
|
||||||
|
snprintf(str, 4095, fmt, ap);
|
||||||
|
str[4095] = 0;
|
||||||
WRITE_LINE2(CONN(ic), P_IRCMASK, "PRIVMSG", nick, str);
|
WRITE_LINE2(CONN(ic), P_IRCMASK, "PRIVMSG", nick, str);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void bip_notify(struct link_client *ic, char *fmt, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
|
va_start(ap, fmt);
|
||||||
|
_bip_notify(ic, fmt, ap);
|
||||||
|
va_end(ap);
|
||||||
|
}
|
||||||
|
|
||||||
extern struct link_client *reloading_client;
|
extern struct link_client *reloading_client;
|
||||||
void adm_blreset(struct link_client *ic)
|
void adm_blreset(struct link_client *ic)
|
||||||
{
|
{
|
||||||
log_reinit_all(LINK(ic)->log);
|
log_reinit_all(LINK(ic)->log);
|
||||||
adm_reply(ic, "backlog resetted for this network.");
|
bip_notify(ic, "backlog resetted for this network.");
|
||||||
}
|
}
|
||||||
|
|
||||||
void adm_follow_nick(struct link_client *ic, char *val)
|
void adm_follow_nick(struct link_client *ic, char *val)
|
||||||
@ -1446,10 +1444,10 @@ void adm_follow_nick(struct link_client *ic, char *val)
|
|||||||
struct link *link = LINK(ic);
|
struct link *link = LINK(ic);
|
||||||
if (strncasecmp(val, "TRUE", 4) == 0) {
|
if (strncasecmp(val, "TRUE", 4) == 0) {
|
||||||
link->follow_nick = 1;
|
link->follow_nick = 1;
|
||||||
adm_reply(ic, "follow_nick is now true.");
|
bip_notify(ic, "follow_nick is now true.");
|
||||||
} else {
|
} else {
|
||||||
link->follow_nick = 0;
|
link->follow_nick = 0;
|
||||||
adm_reply(ic, "follow_nick is now false.");
|
bip_notify(ic, "follow_nick is now false.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1458,10 +1456,10 @@ void adm_ignore_first_nick(struct link_client *ic, char *val)
|
|||||||
struct link *link = LINK(ic);
|
struct link *link = LINK(ic);
|
||||||
if (strncasecmp(val, "TRUE", 4) == 0) {
|
if (strncasecmp(val, "TRUE", 4) == 0) {
|
||||||
link->ignore_first_nick = 1;
|
link->ignore_first_nick = 1;
|
||||||
adm_reply(ic, "ignore_first_nick is now true.");
|
bip_notify(ic, "ignore_first_nick is now true.");
|
||||||
} else {
|
} else {
|
||||||
link->ignore_first_nick = 0;
|
link->ignore_first_nick = 0;
|
||||||
adm_reply(ic, "ignore_first_nick is now false.");
|
bip_notify(ic, "ignore_first_nick is now false.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1472,12 +1470,12 @@ void adm_on_connect_send(struct link_client *ic, char *val)
|
|||||||
|
|
||||||
if (val != NULL) {
|
if (val != NULL) {
|
||||||
list_add_last(&link->on_connect_send, strdup(val));
|
list_add_last(&link->on_connect_send, strdup(val));
|
||||||
adm_reply(ic, "added to on_connect_send.");
|
bip_notify(ic, "added to on_connect_send.");
|
||||||
} else {
|
} else {
|
||||||
s = list_remove_last(&link->on_connect_send);
|
s = list_remove_last(&link->on_connect_send);
|
||||||
if (s)
|
if (s)
|
||||||
free(s);
|
free(s);
|
||||||
adm_reply(ic, "on_connect_send cleared.");
|
bip_notify(ic, "on_connect_send cleared.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1490,37 +1488,37 @@ void adm_away_nick(struct link_client *ic, char *val)
|
|||||||
}
|
}
|
||||||
if (val != NULL) {
|
if (val != NULL) {
|
||||||
link->away_nick = strdup(val);
|
link->away_nick = strdup(val);
|
||||||
adm_reply(ic, "away_nick set.");
|
bip_notify(ic, "away_nick set.");
|
||||||
} else {
|
} else {
|
||||||
adm_reply(ic, "away_nick cleared.");
|
bip_notify(ic, "away_nick cleared.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void adm_bip_help(struct link_client *ic, int admin)
|
void adm_bip_help(struct link_client *ic, int admin)
|
||||||
{
|
{
|
||||||
if (admin) {
|
if (admin) {
|
||||||
adm_reply(ic, "/BIP RELOAD # Re-read bip configuration "
|
bip_notify(ic, "/BIP RELOAD # Re-read bip configuration "
|
||||||
"and apply changes. /!\\ VERY UNSTABLE !");
|
"and apply changes. /!\\ VERY UNSTABLE !");
|
||||||
adm_reply(ic, "/BIP INFO user <username> # show a user's "
|
bip_notify(ic, "/BIP INFO user <username> # show a user's "
|
||||||
"configuration");
|
"configuration");
|
||||||
adm_reply(ic, "/BIP LIST networks|users|connections|all_links"
|
bip_notify(ic, "/BIP LIST networks|users|connections|all_links"
|
||||||
"|all_connections");
|
"|all_connections");
|
||||||
} else {
|
} else {
|
||||||
adm_reply(ic, "/BIP LIST networks|connections");
|
bip_notify(ic, "/BIP LIST networks|connections");
|
||||||
}
|
}
|
||||||
adm_reply(ic, "/BIP JUMP # jump to next server (in same network)");
|
bip_notify(ic, "/BIP JUMP # jump to next server (in same network)");
|
||||||
adm_reply(ic, "/BIP BLRESET # reset backlog (this connection only)");
|
bip_notify(ic, "/BIP BLRESET # reset backlog (this connection only)");
|
||||||
#ifdef HAVE_LIBSSL
|
#ifdef HAVE_LIBSSL
|
||||||
adm_reply(ic, "/BIP TRUST # trust this server certificate");
|
bip_notify(ic, "/BIP TRUST # trust this server certificate");
|
||||||
#endif
|
#endif
|
||||||
adm_reply(ic, "/BIP HELP # show this help...");
|
bip_notify(ic, "/BIP HELP # show this help...");
|
||||||
adm_reply(ic, "## Temporary changes for this connection:");
|
bip_notify(ic, "## Temporary changes for this connection:");
|
||||||
adm_reply(ic, "/BIP FOLLOW_NICK|IGNORE_FIRST_NICK TRUE|FALSE");
|
bip_notify(ic, "/BIP FOLLOW_NICK|IGNORE_FIRST_NICK TRUE|FALSE");
|
||||||
adm_reply(ic, "/BIP ON_CONNECT_SEND <str> # Adds a string to "
|
bip_notify(ic, "/BIP ON_CONNECT_SEND <str> # Adds a string to "
|
||||||
"send on connect");
|
"send on connect");
|
||||||
adm_reply(ic, "/BIP ON_CONNECT_SEND # Clears on_connect_send");
|
bip_notify(ic, "/BIP ON_CONNECT_SEND # Clears on_connect_send");
|
||||||
adm_reply(ic, "/BIP AWAY_NICK <nick> # Set away nick");
|
bip_notify(ic, "/BIP AWAY_NICK <nick> # Set away nick");
|
||||||
adm_reply(ic, "/BIP AWAY_NICK # clear away nick");
|
bip_notify(ic, "/BIP AWAY_NICK # clear away nick");
|
||||||
}
|
}
|
||||||
|
|
||||||
int adm_bip(struct link_client *ic, struct line *line, unsigned int privmsg)
|
int adm_bip(struct link_client *ic, struct line *line, unsigned int privmsg)
|
||||||
@ -1534,15 +1532,15 @@ int adm_bip(struct link_client *ic, struct line *line, unsigned int privmsg)
|
|||||||
LINK(ic)->user->name);
|
LINK(ic)->user->name);
|
||||||
if (strcasecmp(line->elemv[privmsg + 1], "RELOAD") == 0) {
|
if (strcasecmp(line->elemv[privmsg + 1], "RELOAD") == 0) {
|
||||||
if (!admin) {
|
if (!admin) {
|
||||||
adm_reply(ic, "You're not allowed to reload bip");
|
bip_notify(ic, "You're not allowed to reload bip");
|
||||||
return OK_FORGET;
|
return OK_FORGET;
|
||||||
}
|
}
|
||||||
adm_reply(ic, "Bip has been set to reload shortly");
|
bip_notify(ic, "Bip has been set to reload shortly");
|
||||||
reloading_client = ic;
|
reloading_client = ic;
|
||||||
sighup = 1;
|
sighup = 1;
|
||||||
} else if (strcasecmp(line->elemv[privmsg + 1], "LIST") == 0) {
|
} else if (strcasecmp(line->elemv[privmsg + 1], "LIST") == 0) {
|
||||||
if (line->elemc != privmsg + 3) {
|
if (line->elemc != privmsg + 3) {
|
||||||
adm_reply(ic, "LIST command needs one argument");
|
bip_notify(ic, "LIST command needs one argument");
|
||||||
return OK_FORGET;
|
return OK_FORGET;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1562,11 +1560,11 @@ int adm_bip(struct link_client *ic, struct line *line, unsigned int privmsg)
|
|||||||
"all_links", 9) == 0) {
|
"all_links", 9) == 0) {
|
||||||
adm_list_all_links(ic);
|
adm_list_all_links(ic);
|
||||||
} else {
|
} else {
|
||||||
adm_reply(ic, "Invalid LIST request");
|
bip_notify(ic, "Invalid LIST request");
|
||||||
}
|
}
|
||||||
} else if (strcasecmp(line->elemv[privmsg + 1], "INFO") == 0) {
|
} else if (strcasecmp(line->elemv[privmsg + 1], "INFO") == 0) {
|
||||||
if (line->elemc < privmsg + 3) {
|
if (line->elemc < privmsg + 3) {
|
||||||
adm_reply(ic, "INFO command needs at least one argument");
|
bip_notify(ic, "INFO command needs at least one argument");
|
||||||
return OK_FORGET;
|
return OK_FORGET;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1575,7 +1573,7 @@ int adm_bip(struct link_client *ic, struct line *line, unsigned int privmsg)
|
|||||||
if (line->elemc == privmsg + 4) {
|
if (line->elemc == privmsg + 4) {
|
||||||
adm_info_user(ic, line->elemv[privmsg + 3]);
|
adm_info_user(ic, line->elemv[privmsg + 3]);
|
||||||
} else {
|
} else {
|
||||||
adm_reply(ic, "/BIP INFO user needs one "
|
bip_notify(ic, "/BIP INFO user needs one "
|
||||||
"argument");
|
"argument");
|
||||||
}
|
}
|
||||||
/*TODO } else if (strncasecmp(line->elemv[privmsg + 2],
|
/*TODO } else if (strncasecmp(line->elemv[privmsg + 2],
|
||||||
@ -1583,11 +1581,11 @@ int adm_bip(struct link_client *ic, struct line *line, unsigned int privmsg)
|
|||||||
if (line->elemc == privmsg + 4) {
|
if (line->elemc == privmsg + 4) {
|
||||||
adm_info_network(ic, line->elemv[privmsg + 3]);
|
adm_info_network(ic, line->elemv[privmsg + 3]);
|
||||||
} else {
|
} else {
|
||||||
adm_reply(ic, "/BIP INFO network needs one "
|
bip_notify(ic, "/BIP INFO network needs one "
|
||||||
"argument");
|
"argument");
|
||||||
}*/
|
}*/
|
||||||
} else {
|
} else {
|
||||||
adm_reply(ic, "Invalid INFO request");
|
bip_notify(ic, "Invalid INFO request");
|
||||||
}
|
}
|
||||||
} else if (strcasecmp(line->elemv[privmsg + 1], "JUMP") == 0) {
|
} else if (strcasecmp(line->elemv[privmsg + 1], "JUMP") == 0) {
|
||||||
if (LINK(ic)->l_server) {
|
if (LINK(ic)->l_server) {
|
||||||
@ -1595,21 +1593,21 @@ int adm_bip(struct link_client *ic, struct line *line, unsigned int privmsg)
|
|||||||
"jumpin' jumpin'");
|
"jumpin' jumpin'");
|
||||||
connection_close(CONN(LINK(ic)->l_server));
|
connection_close(CONN(LINK(ic)->l_server));
|
||||||
}
|
}
|
||||||
adm_reply(ic, "Jumping to next server");
|
bip_notify(ic, "Jumping to next server");
|
||||||
} else if (strcasecmp(line->elemv[privmsg + 1], "BLRESET") == 0) {
|
} else if (strcasecmp(line->elemv[privmsg + 1], "BLRESET") == 0) {
|
||||||
adm_blreset(ic);
|
adm_blreset(ic);
|
||||||
} else if (strcasecmp(line->elemv[privmsg + 1], "HELP") == 0) {
|
} else if (strcasecmp(line->elemv[privmsg + 1], "HELP") == 0) {
|
||||||
adm_bip_help(ic, admin);
|
adm_bip_help(ic, admin);
|
||||||
} else if (strcasecmp(line->elemv[privmsg + 1], "FOLLOW_NICK") == 0) {
|
} else if (strcasecmp(line->elemv[privmsg + 1], "FOLLOW_NICK") == 0) {
|
||||||
if (line->elemc != privmsg + 3) {
|
if (line->elemc != privmsg + 3) {
|
||||||
adm_reply(ic, "FOLLOW_NICK command needs one argument");
|
bip_notify(ic, "FOLLOW_NICK command needs one argument");
|
||||||
return OK_FORGET;
|
return OK_FORGET;
|
||||||
}
|
}
|
||||||
adm_follow_nick(ic, line->elemv[privmsg + 2]);
|
adm_follow_nick(ic, line->elemv[privmsg + 2]);
|
||||||
} else if (strcasecmp(line->elemv[privmsg + 1],
|
} else if (strcasecmp(line->elemv[privmsg + 1],
|
||||||
"IGNORE_FIRST_NICK") == 0) {
|
"IGNORE_FIRST_NICK") == 0) {
|
||||||
if (line->elemc != privmsg + 3) {
|
if (line->elemc != privmsg + 3) {
|
||||||
adm_reply(ic, "IGNORE_FIRST_NICK command needs one argument");
|
bip_notify(ic, "IGNORE_FIRST_NICK command needs one argument");
|
||||||
return OK_FORGET;
|
return OK_FORGET;
|
||||||
}
|
}
|
||||||
adm_ignore_first_nick(ic, line->elemv[privmsg + 2]);
|
adm_ignore_first_nick(ic, line->elemv[privmsg + 2]);
|
||||||
@ -1621,7 +1619,7 @@ int adm_bip(struct link_client *ic, struct line *line, unsigned int privmsg)
|
|||||||
// TODO: on connect send should not be limited to one word
|
// TODO: on connect send should not be limited to one word
|
||||||
adm_on_connect_send(ic, line->elemv[privmsg + 2]);
|
adm_on_connect_send(ic, line->elemv[privmsg + 2]);
|
||||||
} else {
|
} else {
|
||||||
adm_reply(ic, "/BIP ON_CONNECT_SEND needs zero or one "
|
bip_notify(ic, "/BIP ON_CONNECT_SEND needs zero or one "
|
||||||
"argument");
|
"argument");
|
||||||
}
|
}
|
||||||
} else if (strcasecmp(line->elemv[privmsg + 1], "AWAY_NICK") == 0) {
|
} else if (strcasecmp(line->elemv[privmsg + 1], "AWAY_NICK") == 0) {
|
||||||
@ -1630,7 +1628,7 @@ int adm_bip(struct link_client *ic, struct line *line, unsigned int privmsg)
|
|||||||
} else if (line->elemc == privmsg + 3) {
|
} else if (line->elemc == privmsg + 3) {
|
||||||
adm_away_nick(ic, line->elemv[privmsg + 2]);
|
adm_away_nick(ic, line->elemv[privmsg + 2]);
|
||||||
} else {
|
} else {
|
||||||
adm_reply(ic, "/BIP AWAY_NICK needs zero or one "
|
bip_notify(ic, "/BIP AWAY_NICK needs zero or one "
|
||||||
"argument");
|
"argument");
|
||||||
}
|
}
|
||||||
#ifdef HAVE_LIBSSL
|
#ifdef HAVE_LIBSSL
|
||||||
@ -1644,7 +1642,7 @@ int adm_bip(struct link_client *ic, struct line *line, unsigned int privmsg)
|
|||||||
buf[4095] = 0;
|
buf[4095] = 0;
|
||||||
snprintf(buf, 4095, "Unknown command %s",
|
snprintf(buf, 4095, "Unknown command %s",
|
||||||
line->elemv[privmsg + 1]);
|
line->elemv[privmsg + 1]);
|
||||||
adm_reply(ic, buf);
|
bip_notify(ic, buf);
|
||||||
}
|
}
|
||||||
return OK_FORGET;
|
return OK_FORGET;
|
||||||
}
|
}
|
||||||
|
@ -20,5 +20,6 @@ int adm_trust(struct link_client *ic, struct line *line);
|
|||||||
int adm_bip(struct link_client *ic, struct line *line, unsigned int privmsg);
|
int adm_bip(struct link_client *ic, struct line *line, unsigned int privmsg);
|
||||||
int ssl_check_trust(struct link_client *ic);
|
int ssl_check_trust(struct link_client *ic);
|
||||||
void adm_blreset(struct link_client *ic);
|
void adm_blreset(struct link_client *ic);
|
||||||
|
void bip_notify(struct link_client *ic, char *fmt, ...);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -939,8 +939,7 @@ static void irc_notify_disconnection(struct link_server *is)
|
|||||||
c->name, is->nick,
|
c->name, is->nick,
|
||||||
"Server disconnected, reconnecting");
|
"Server disconnected, reconnecting");
|
||||||
}
|
}
|
||||||
WRITE_LINE2(CONN(ic), P_IRCMASK, "PRIVMSG", is->nick,
|
bip_notify(ic, "Server disconnected, reconnecting");
|
||||||
"Server disconnected, reconnecting");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user