]>
jfr.im git - irc/quakenet/newserv.git/blob - trusts/trusts_commands.c
2 #include "../control/control.h"
3 #include "../lib/irc_string.h"
6 int trusts_migration_start ( TrustDBMigrationCallback
, void *);
7 void trusts_migration_stop ( void );
8 static void registercommands ( int , void *);
9 static void deregistercommands ( int , void *);
11 static void migrate_status ( int errcode
, void * tag
) {
12 long sender
= ( long ) tag
;
13 nick
* np
= getnickbynumeric ( sender
);
18 if (! errcode
|| errcode
== MIGRATION_LASTERROR
) {
20 controlreply ( np
, "Migration complete." );
21 controlreply ( np
, "Attempting to reload database. . ." );
23 controlreply ( np
, "An error occured after the database was unloaded, attempting reload. . ." );
26 controlreply ( np
, "Database reloaded successfully." );
28 controlreply ( np
, "An error occured, please reload the module manually." );
31 controlreply ( np
, "Error %d occured during migration, commands reregistered." , errcode
);
32 registercommands ( 0 , NULL
);
36 static int trusts_cmdmigrate ( void * source
, int cargc
, char ** cargv
) {
37 nick
* sender
= source
;
40 /* iffy but temporary */
41 ret
= trusts_migration_start ( migrate_status
, ( void *)( sender
-> numeric
));
43 controlreply ( sender
, "Migration started, commands deregistered." );
44 deregistercommands ( 0 , NULL
);
46 controlreply ( sender
, "Error %d starting migration." , ret
);
52 static int trusts_cmdtrustlist ( void * source
, int cargc
, char ** cargv
) {
53 nick
* sender
= source
;
61 tg
= tg_strtotg ( cargv
[ 0 ]);
63 controlreply ( sender
, "Couldn't find a trustgroup with that id." );
69 controlreply ( sender
, "Name: : %s " , tg
-> name
-> content
);
70 controlreply ( sender
, "Trusted for : %d " , tg
-> trustedfor
);
71 controlreply ( sender
, "Currently using : %d " , tg
-> count
);
72 controlreply ( sender
, "Clients per user : %d ( %s enforcing ident)" , tg
-> maxperident
, tg
-> mode
? "" : "not " );
73 controlreply ( sender
, "Contact: : %s " , tg
-> contact
-> content
);
74 controlreply ( sender
, "Expires in : %s " , ( tg
-> expires
> t
)? longtoduration ( tg
-> expires
- t
, 2 ): "(in the past)" );
75 controlreply ( sender
, "Last changed by : %s " , tg
-> createdby
-> content
);
76 controlreply ( sender
, "Comment: : %s " , tg
-> comment
-> content
);
77 controlreply ( sender
, "ID: : %u " , tg
-> id
);
78 controlreply ( sender
, "Last used : %s " , ( tg
-> count
> 0 )? "(now)" : trusts_timetostr ( tg
-> lastseen
));
79 controlreply ( sender
, "Max usage : %d " , tg
-> maxusage
);
80 controlreply ( sender
, "Last max reset : %s " , tg
-> lastmaxuserreset
? trusts_timetostr ( tg
-> lastmaxuserreset
): "(never)" );
82 controlreply ( sender
, "Host Current Max Last seen" );
84 for ( th
= tg
-> hosts
; th
; th
= th
-> next
)
85 controlreply ( sender
, " %-20s %-10d %-10d %s " , trusts_cidr2str ( th
-> ip
, th
-> mask
), th
-> count
, th
-> maxusage
, ( th
-> count
> 0 )? "(now)" : trusts_timetostr ( th
-> lastseen
));
87 controlreply ( sender
, "End of list." );
92 static int trusts_cmdtrustadd ( void * source
, int cargc
, char ** cargv
) {
94 nick
* sender
= source
;
102 tg
= tg_strtotg ( cargv
[ 0 ]);
104 controlreply ( sender
, "Couldn't look up trustgroup." );
109 if (! trusts_str2cidr ( host
, & ip
, & mask
)) {
110 controlreply ( sender
, "Invalid host." );
114 th
= th_getbyhost ( ip
);
116 if ( mask
== th
-> mask
) {
117 controlreply ( sender
, "This host already exists with the same mask." );
120 if ( mask
> th
-> mask
) {
121 /* this mask is a closer fit */
123 controlreply ( sender
, "Warning: this host will override another ( %s ), as it has smaller prefix (group: %s )." , trusts_cidr2str ( th
-> ip
, th
-> mask
), th
-> group
-> name
-> content
);
124 controlreply ( sender
, "Adding anyway..." );
127 th
= th_getsupersetbyhost ( ip
, mask
);
129 controlreply ( sender
, "Warning: this host is already covered by a smaller prefix ( %s ), which will remain part of that group: %s " , trusts_cidr2str ( th
-> ip
, th
-> mask
), th
-> group
-> name
-> content
);
130 controlreply ( sender
, "Adding anyway..." );
134 th
= th_new ( tg
, host
);
136 controlreply ( sender
, "An error occured adding the host to the group." );
140 controlreply ( sender
, "Host added." );
141 /* TODO: controlwall */
146 static int trusts_cmdtrustgroupadd ( void * source
, int cargc
, char ** cargv
) {
147 nick
* sender
= source
;
148 char * name
, * contact
, * comment
, createdby
[ ACCOUNTLEN
+ 2 ];
149 unsigned int howmany
, maxperident
, enforceident
;
157 howmany
= strtoul ( cargv
[ 1 ], NULL
, 10 );
158 if (! howmany
|| ( howmany
> 50000 )) {
159 controlreply ( sender
, "Bad value maximum number of clients." );
163 howlong
= durationtolong ( cargv
[ 2 ]);
164 if (( howlong
<= 0 ) || ( howlong
> 365 * 86400 * 20 )) {
165 controlreply ( sender
, "Invalid duration supplied." );
169 maxperident
= strtoul ( cargv
[ 3 ], NULL
, 10 );
170 if (! howmany
|| ( maxperident
> 1000 )) {
171 controlreply ( sender
, "Bad value for max per ident." );
175 if ( cargv
[ 4 ][ 0 ] != '1' && cargv
[ 4 ][ 0 ] != '0' ) {
176 controlreply ( sender
, "Bad value for enforce ident (use 0 or 1)." );
179 enforceident
= cargv
[ 4 ][ 0 ] == '1' ;
184 comment
= "(no comment)" ;
189 /* don't allow #id or id forms */
190 if (( name
[ 0 ] == '#' ) || strtoul ( name
, NULL
, 10 )) {
191 controlreply ( sender
, "Invalid trustgroup name." );
195 tg
= tg_strtotg ( name
);
197 controlreply ( sender
, "A group with that name already exists" );
201 snprintf ( createdby
, sizeof ( createdby
), "# %s " , sender
-> authname
);
203 tg
= tg_new ( name
, howmany
, enforceident
, maxperident
, howlong
+ time ( NULL
), createdby
, contact
, comment
);
205 controlreply ( sender
, "An error occured adding the trustgroup." );
209 controlreply ( sender
, "Group added." );
210 /* TODO: controlwall */
215 static int commandsregistered
;
217 static void registercommands ( int hooknum
, void * arg
) {
218 if ( commandsregistered
)
220 commandsregistered
= 1 ;
222 registercontrolhelpcmd ( "trustmigrate" , NO_DEVELOPER
, 0 , trusts_cmdmigrate
, "Usage: trustmigrate \n Copies trust data from O and reloads the database." );
223 registercontrolhelpcmd ( "trustlist" , NO_OPER
, 1 , trusts_cmdtrustlist
, "Usage: trustlist <#id|name|id> \n Shows trust data for the specified trust group." );
224 registercontrolhelpcmd ( "trustgroupadd" , NO_OPER
, 6 , trusts_cmdtrustgroupadd
, "Usage: trustgroupadd <name> <howmany> <howlong> <maxperident> <enforceident> <contact> ?comment?" );
225 registercontrolhelpcmd ( "trustadd" , NO_OPER
, 2 , trusts_cmdtrustadd
, "Usage: trustadd <#id|name|id> <host>" );
228 static void deregistercommands ( int hooknum
, void * arg
) {
229 if (! commandsregistered
)
231 commandsregistered
= 0 ;
233 deregistercontrolcmd ( "trustmigrate" , trusts_cmdmigrate
);
234 deregistercontrolcmd ( "trustlist" , trusts_cmdtrustlist
);
235 deregistercontrolcmd ( "trustgroupadd" , trusts_cmdtrustgroupadd
);
236 deregistercontrolcmd ( "trustadd" , trusts_cmdtrustadd
);
240 registerhook ( HOOK_TRUSTS_DB_LOADED
, registercommands
);
241 registerhook ( HOOK_TRUSTS_DB_CLOSED
, deregistercommands
);
244 registercommands ( 0 , NULL
);
248 deregisterhook ( HOOK_TRUSTS_DB_LOADED
, registercommands
);
249 deregisterhook ( HOOK_TRUSTS_DB_CLOSED
, deregistercommands
);
251 trusts_migration_stop ();
253 deregistercommands ( 0 , NULL
);