]>
jfr.im git - irc/quakenet/newserv.git/blob - trusts/trusts_policy.c
1 #include "../core/hooks.h"
2 #include "../control/control.h"
3 #include "../lib/irc_string.h"
8 static void policycheck(int hooknum
, void *arg
) {
11 long moving
= (long)args
[1];
12 trusthost
*th
= gettrusthost(np
);
19 if(np
->ipnode
->usercount
> 5)
20 controlwall(NO_OPER
, NL_TRUSTS
, "Hard connection limit exceeded on IP: %s (untrusted) %d connected, 5 max.", IPtostr(np
->p_ipaddr
), np
->ipnode
->usercount
);
26 * the purpose of this logic is to avoid spam like this:
27 * WARNING: tgX exceeded limit: 11 connected vs 10 max
28 * (goes back down to 10)
29 * WARNING: tgX exceeded limit: 11 connected vs 10 max
32 if(hooknum
== HOOK_TRUSTS_NEWNICK
) {
33 if(tg
->count
> tg
->trustedfor
) {
35 if(tg->count > (long)tg->exts[countext]) {
37 tg->exts[countext] = (void *)(long)tg->count;
39 controlwall(NO_OPER
, NL_TRUSTS
, "Hard connection limit exceeded: '%s', %d connected, %d max.", tg
->name
->content
, tg
->count
, tg
->trustedfor
);
44 if((tg
->mode
== 1) && (np
->ident
[0] == '~'))
45 controlwall(NO_OPER
, NL_TRUSTS
, "Ident required: '%s' %s!%s@%s.", tg
->name
->content
, np
->nick
, np
->ident
, np
->host
->name
->content
);
47 if(tg
->maxperident
> 0) {
52 for(th2
=tg
->hosts
;th2
;th2
=th2
->next
) {
53 for(tnp
=th2
->users
;tnp
;tnp
=nextbytrust(tnp
)) {
54 if(!ircd_strcmp(tnp
->ident
, np
->ident
))
59 if(identcount
> tg
->maxperident
)
60 controlwall(NO_OPER
, NL_TRUSTS
, "Hard ident limit exceeded: '%s' %s!%s@%s, %d connected, %d max.", tg
->name
->content
, np
->nick
, np
->ident
, np
->host
->name
->content
, identcount
, tg
->maxperident
);
63 if(tg
->count
< tg
->maxusage
)
64 tg
->exts
[countext
] = (void *)(long)tg
->count
;
69 countext
= registertgext("count");
73 registerhook(HOOK_TRUSTS_NEWNICK
, policycheck
);
74 registerhook(HOOK_TRUSTS_LOSTNICK
, policycheck
);
81 releasetgext(countext
);
83 deregisterhook(HOOK_TRUSTS_NEWNICK
, policycheck
);
84 deregisterhook(HOOK_TRUSTS_LOSTNICK
, policycheck
);