]>
jfr.im git - irc/quakenet/newserv.git/blob - chanserv/chanservprivs.c
4 #include "../nick/nick.h"
5 #include "../lib/irc_string.h"
9 int cs_privcheck(int privnum
, nick
*np
) {
13 rup
=getreguserfromnick(np
);
16 case QPRIV_SUSPENDBYPASS
:
17 case QPRIV_VIEWCHANFLAGS
:
18 case QPRIV_VIEWFULLCHANLEV
:
19 case QPRIV_VIEWFULLWHOIS
:
20 case QPRIV_VIEWCHANMODES
:
21 case QPRIV_VIEWAUTOLIMIT
:
22 case QPRIV_VIEWBANTIMER
:
23 case QPRIV_VIEWUSERFLAGS
:
24 case QPRIV_VIEWCHANSUSPENSION
:
25 return (rup
&& UHasHelperPriv(rup
));
27 case QPRIV_VIEWCOMMENTS
:
29 case QPRIV_CHANGECHANLEV
:
30 case QPRIV_CHANGECHANFLAGS
:
31 case QPRIV_CHANGECHANMODES
:
32 case QPRIV_CHANGEAUTOLIMIT
:
33 case QPRIV_CHANGEBANTIMER
:
34 case QPRIV_CHANGEUSERFLAGS
:
35 case QPRIV_VIEWSUSPENDEDBY
:
36 case QPRIV_VIEWWALLMESSAGE
: /* if you change VIEWWALLMESSAGE alter chanservwallmessage too */
37 return (np
&& rup
&& IsOper(np
) && UHasOperPriv(rup
));
39 default: /* By default opers can override anything */
40 return (np
&& rup
&& IsOper(np
) && UHasOperPriv(rup
));
44 /* Generic access check function.
45 * Note that the chanindex is returned for success, this
46 * can be used to avoid duplicate hash lookups */
48 chanindex
*cs_checkaccess(nick
*np
, const char *chan
, unsigned int flags
,
49 chanindex
*cip
, const char *cmdname
, int priv
, int quiet
) {
50 reguser
*rup
=getreguserfromnick(np
);
52 regchanuser
*rcup
=NULL
;
55 if ((flags
& CA_AUTHED
) && !rup
)
58 if (!cip
&& !(cip
=findchanindex(chan
))) {
59 if (!quiet
) chanservstdmessage(np
, QM_UNKNOWNCHAN
, chan
);
63 if (!(rcp
=cip
->exts
[chanservext
])) {
64 if (!quiet
) chanservstdmessage(np
, QM_UNKNOWNCHAN
, cip
->name
->content
);
69 if (CIsSuspended(rcp
)) {
70 if (cs_privcheck(QPRIV_SUSPENDBYPASS
, np
)) {
71 if (!quiet
) chanservstdmessage(np
, QM_BYPASSINGSUSPEND
, cip
->name
->content
);
73 if (!quiet
) chanservstdmessage(np
, QM_UNKNOWNCHAN
, cip
->name
->content
);
79 rcup
=findreguseronchannel(rcp
, rup
);
81 if (!cs_privcheck(priv
,np
)) {
82 if ((flags
& CA_VOICEPRIV
) &&
83 !(rcp
&& CIsVoiceAll(rcp
) && !(rcup
&& CUIsQuiet(rcup
)) &&
84 !(cip
->channel
&& (nickbanned(np
, cip
->channel
, 1) || IsInviteOnly(cip
->channel
)))) &&
85 !(rcup
&& CUHasVoicePriv(rcup
))) {
86 if (!quiet
) chanservstdmessage(np
, QM_NOACCESSONCHAN
, cip
->name
->content
, cmdname
);
90 if ((flags
& CA_NEEDKNOWN
) && !rup
) {
91 if (!quiet
) chanservstdmessage(np
, QM_NOACCESSONCHAN
, cip
->name
->content
, cmdname
);
95 if ((flags
& CA_NEEDKNOWN
) && (!rcup
|| !CUKnown(rcup
))) {
96 if (!quiet
) chanservstdmessage(np
, QM_NOACCESSONCHAN
, cip
->name
->content
, cmdname
);
100 if (((flags
& CA_OPPRIV
) && !CUHasOpPriv(rcup
)) ||
101 ((flags
& CA_MASTERPRIV
) && !CUHasMasterPriv(rcup
)) ||
102 ((flags
& CA_OWNERPRIV
) && !CUIsOwner(rcup
)) ||
103 ((flags
& CA_TOPICPRIV
) && !CUHasTopicPriv(rcup
))) {
104 if (!quiet
) chanservstdmessage(np
, QM_NOACCESSONCHAN
, cip
->name
->content
, cmdname
);
109 if ((flags
& CA_ONCHANREQ
) && !(cip
->channel
)) {
110 if (!quiet
) chanservstdmessage(np
, QM_NOTONCHAN
, cip
->name
->content
);
115 lp
=getnumerichandlefromchanhash(cip
->channel
->users
, np
->numeric
);
117 if ((flags
& CA_ONCHANREQ
) && !lp
) {
118 if (!quiet
) chanservstdmessage(np
, QM_NOTONCHAN
, cip
->name
->content
);
122 if ((flags
& CA_OPPED
) && !(*lp
& CUMODE_OP
)) {
123 if (!quiet
) chanservstdmessage(np
, QM_NOTOPPED
, cip
->name
->content
);
127 if ((flags
& CA_DEOPPED
) && (*lp
& CUMODE_OP
)) {
128 if (!quiet
) chanservstdmessage(np
, QM_ALREADYOPPED
, cip
->name
->content
);
132 if ((flags
& CA_VOICED
) && !(*lp
& CUMODE_VOICE
)) {
133 if (!quiet
) chanservstdmessage(np
, QM_NOTVOICED
, cip
->name
->content
);
137 if ((flags
& CA_DEVOICED
) && (*lp
& CUMODE_VOICE
)) {
138 if (!quiet
) chanservstdmessage(np
, QM_ALREADYVOICED
, cip
->name
->content
);
142 if ((flags
& CA_OFFCHAN
) && lp
) {
143 if (!quiet
) chanservstdmessage(np
, QM_ALREADYONCHAN
, cip
->name
->content
);