]>
Commit | Line | Data |
---|---|---|
1dd6d55d | 1 | /* Automatically generated by refactor.pl. |
2 | * | |
3 | * | |
4 | * CMDNAME: userflags | |
5 | * CMDLEVEL: QCMD_AUTHED | |
6 | * CMDARGS: 2 | |
7 | * CMDDESC: Shows or changes user flags. | |
8 | * CMDFUNC: csu_douserflags | |
9 | * CMDPROTO: int csu_douserflags(void *source, int cargc, char **cargv); | |
50cd26d6 | 10 | * CMDHELP: Usage: USERFLAGS <flags> |
11 | * CMDHELP: Changes your current user flags, where: | |
12 | * CMDHELP: flags - changes to apply, in the usual flag letters preceded by +/- format. | |
13 | * CMDHELP: Valid user flags are: | |
14 | * CMDHELP: +n NOTICE - causes the bot to sent you NOTICEs. If this flag is not set the | |
15 | * CMDHELP: bot will communicate using PRIVMSG. | |
1dd6d55d | 16 | */ |
17 | ||
18 | #include "../chanserv.h" | |
19 | #include "../../lib/irc_string.h" | |
20 | #include <stdio.h> | |
21 | #include <string.h> | |
22 | ||
23 | int csu_douserflags(void *source, int cargc, char **cargv) { | |
24 | nick *sender=source; | |
25 | reguser *rup=getreguserfromnick(sender), *target; | |
3294b10b | 26 | authname *anp; |
fbc4d9ed | 27 | int arg=0, wasorisoper; |
8dfd270a | 28 | flag_t flagmask, changemask, oldflags; |
1dd6d55d | 29 | char flagbuf[30]; |
30 | ||
31 | if (!rup) | |
32 | return CMD_ERROR; | |
33 | ||
1482fb78 | 34 | if (cargc>0 && (*cargv[0]!='+' && *cargv[0]!='-')) { |
1dd6d55d | 35 | arg++; |
36 | /* If the first char isn't a "change" character, it must specify a target */ | |
37 | ||
38 | if (!(target=findreguser(sender,cargv[0]))) | |
39 | return CMD_ERROR; | |
40 | ||
41 | if (target!=rup && !cs_privcheck(QPRIV_VIEWUSERFLAGS, sender)) { | |
1482fb78 | 42 | chanservstdmessage(sender, QM_NOACCESSONUSER, "userflags", cargv[0]); |
1dd6d55d | 43 | return CMD_ERROR; |
44 | } | |
45 | } else { | |
46 | target=rup; | |
47 | } | |
48 | ||
49 | if (cargc>arg) { | |
50 | /* OK, now we have a changestring.. */ | |
51 | if (target!=rup && !cs_privcheck(QPRIV_CHANGEUSERFLAGS, sender)) { | |
1482fb78 | 52 | /* Safe to use cargv[0] because if target != rup then first arg must have been the target name */ |
53 | chanservstdmessage(sender, QM_NOACCESSONUSER, "userflags", cargv[0]); | |
1dd6d55d | 54 | return CMD_ERROR; |
55 | } | |
56 | ||
57 | strcpy(flagbuf,printflags(target->flags, ruflags)); | |
8dfd270a | 58 | oldflags=target->flags; |
1dd6d55d | 59 | |
3a744b8f | 60 | changemask=QUFLAG_NOTICE; |
1dd6d55d | 61 | |
62 | if (target==rup) { | |
63 | /* If you're changing yourself, you can give up the "status" flags and add/remove notice */ | |
347686bd | 64 | changemask|=(target->flags & (QUFLAG_OPER | QUFLAG_DEV | QUFLAG_PROTECT | QUFLAG_HELPER | QUFLAG_ADMIN | QUFLAG_STAFF)); |
1dd6d55d | 65 | } |
66 | ||
67 | /* Warning, policy ahead */ | |
68 | ||
69 | if (UHasOperPriv(rup)) | |
f39514a3 | 70 | changemask |= QUFLAG_PROTECT | QUFLAG_TRUST | QCFLAG_NOINFO; |
1dd6d55d | 71 | |
72 | if (UHasAdminPriv(rup)) | |
347686bd | 73 | changemask |= (QUFLAG_OPER | QUFLAG_HELPER | QUFLAG_CLEANUPEXEMPT | QUFLAG_STAFF); |
1dd6d55d | 74 | |
75 | if (UIsDev(rup)) | |
76 | changemask=QUFLAG_ALL; | |
77 | ||
fbc4d9ed | 78 | wasorisoper = UHasOperPriv(target); |
1dd6d55d | 79 | setflags(&target->flags, changemask, cargv[arg], ruflags, REJECT_NONE); |
fbc4d9ed CP |
80 | wasorisoper |= UHasOperPriv(target); |
81 | ||
1dd6d55d | 82 | /* More policy */ |
83 | if (!UHasHelperPriv(target)) { | |
84 | target->flags &= ~QUFLAG_PROTECT; | |
85 | } | |
86 | ||
87 | cs_log(sender,"USERFLAGS #%s %s (%s -> %s)",target->username,cargv[arg],flagbuf,printflags(target->flags, ruflags)); | |
8dfd270a CP |
88 | |
89 | /* only warn about interesting changes */ | |
8907f377 | 90 | if((target->flags ^ oldflags) & ~(QUFLAG_NOTICE | QUFLAG_INFO | QUFLAG_TRUST)) { |
8dfd270a CP |
91 | chanservwallmessage("%s (%s) just used USERFLAGS on %s %s (%s -> %s)",sender->nick,rup->username,target->username,cargv[arg],flagbuf,printflags(target->flags,ruflags)); |
92 | ||
e9f49ea9 | 93 | #ifdef AUTHGATE_WARNINGS |
fbc4d9ed CP |
94 | if(wasorisoper) |
95 | chanservsendmessage(sender, "WARNING FOR PRIVILEGED USERS: you MUST go to https://auth.quakenet.org and attempt to login as %s (with any password) to update the cache, otherwise their old credentials will be preserved in certain circumstances.",target->username); | |
e9f49ea9 CP |
96 | #endif |
97 | } | |
1dd6d55d | 98 | csdb_updateuser(target); |
3294b10b CP |
99 | |
100 | if ((anp=findauthname(rup->ID))) | |
101 | localusersetaccountflags(anp, cs_accountflagmap(target)); | |
102 | ||
1dd6d55d | 103 | chanservstdmessage(sender, QM_DONE); |
104 | } | |
105 | ||
106 | if (cs_privcheck(QPRIV_VIEWUSERFLAGS, sender)) | |
107 | flagmask=QUFLAG_ALL; | |
108 | else | |
347686bd | 109 | flagmask=QUFLAG_INFO | QUFLAG_NOTICE | QUFLAG_OPER | QUFLAG_HELPER | QUFLAG_DEV | QUFLAG_ADMIN | QUFLAG_STAFF; |
1dd6d55d | 110 | |
43583524 | 111 | chanservstdmessage(sender, QM_CURUSERFLAGS, target->username, printflagsornone(target->flags & flagmask, ruflags)); |
1dd6d55d | 112 | |
113 | return CMD_OK; | |
114 | } |