]>
jfr.im git - solanum.git/blob - src/monitor.c
2 * ircd-ratbox: an advanced Internet Relay Chat Daemon(ircd).
3 * monitor.c - Code for server-side notify lists
5 * Copyright (C) 2005 Lee Hardy <lee -at- leeh.co.uk>
6 * Copyright (C) 2005 ircd-ratbox development team
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions are
12 * 1.Redistributions of source code must retain the above copyright notice,
13 * this list of conditions and the following disclaimer.
14 * 2.Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 * 3.The name of the author may not be used to endorse or promote products
18 * derived from this software without specific prior written permission.
20 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
21 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
22 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
23 * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
24 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
25 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
26 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
28 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
29 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30 * POSSIBILITY OF SUCH DAMAGE.
32 * $Id: monitor.c 3520 2007-06-30 22:15:35Z jilles $
40 static struct monitor
*monitorTable
[MONITOR_HASH_SIZE
];
41 BlockHeap
*monitor_heap
;
43 static void cleanup_monitor(void *unused
);
48 monitor_heap
= BlockHeapCreate(sizeof(struct monitor
), MONITOR_HEAP_SIZE
);
49 eventAddIsh("cleanup_monitor", cleanup_monitor
, NULL
, 3600);
52 static inline unsigned int
53 hash_monitor_nick(const char *name
)
55 return fnv_hash_upper((const unsigned char *) name
, MONITOR_HASH_BITS
);
59 find_monitor(const char *name
, int add
)
61 struct monitor
*monptr
;
63 unsigned int hashv
= hash_monitor_nick(name
);
65 for(monptr
= monitorTable
[hashv
]; monptr
; monptr
= monptr
->hnext
)
67 if(!irccmp(monptr
->name
, name
))
73 monptr
= BlockHeapAlloc(monitor_heap
);
74 strlcpy(monptr
->name
, name
, sizeof(monptr
->name
));
76 monptr
->hnext
= monitorTable
[hashv
];
77 monitorTable
[hashv
] = monptr
;
87 * inputs - client who has just connected
89 * side effects - notifies any clients monitoring this nickname that it has
90 * connected to the network
93 monitor_signon(struct Client
*client_p
)
95 char buf
[USERHOST_REPLYLEN
];
96 struct monitor
*monptr
= find_monitor(client_p
->name
, 0);
98 /* noones watching this nick */
102 rb_snprintf(buf
, sizeof(buf
), "%s!%s@%s",
103 client_p
->name
, client_p
->username
, client_p
->host
);
105 sendto_monitor(monptr
, form_str(RPL_MONONLINE
), me
.name
, "*", buf
);
110 * inputs - client who is exiting
112 * side effects - notifies any clients monitoring this nickname that it has
116 monitor_signoff(struct Client
*client_p
)
118 struct monitor
*monptr
= find_monitor(client_p
->name
, 0);
120 /* noones watching this nick */
124 sendto_monitor(monptr
, form_str(RPL_MONOFFLINE
), me
.name
, "*",
129 clear_monitor(struct Client
*client_p
)
131 struct monitor
*monptr
;
132 rb_dlink_node
*ptr
, *next_ptr
;
134 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, client_p
->localClient
->monitor_list
.head
)
138 /* we leave the actual entry around with no users, itll be
139 * cleaned up periodically by cleanup_monitor() --anfl
141 rb_dlinkFindDestroy(client_p
, &monptr
->users
);
142 free_rb_dlink_node(ptr
);
145 client_p
->localClient
->monitor_list
.head
= client_p
->localClient
->monitor_list
.tail
= NULL
;
146 client_p
->localClient
->monitor_list
.length
= 0;
150 cleanup_monitor(void *unused
)
152 struct monitor
*last_ptr
= NULL
;
153 struct monitor
*next_ptr
, *ptr
;
156 for(i
= 0; i
< MONITOR_HASH_SIZE
; i
++)
159 for(ptr
= monitorTable
[i
]; ptr
; ptr
= next_ptr
)
161 next_ptr
= ptr
->hnext
;
163 if(!rb_dlink_list_length(&ptr
->users
))
166 last_ptr
->hnext
= next_ptr
;
168 monitorTable
[i
] = next_ptr
;
170 BlockHeapFree(monitor_heap
, ptr
);