]> jfr.im git - irc/quakenet/newserv.git/blobdiff - trusts/trusts.h
ident comparision should use strcmp
[irc/quakenet/newserv.git] / trusts / trusts.h
index 861313a685bfc82981d161001e45526572ec3b8d..000a073245bb6bd2c2e30407cedb82d8ab91baf0 100644 (file)
@@ -3,22 +3,39 @@
 
 #include <time.h>
 #include <stdint.h>
+#include "../nick/nick.h"
 #include "../lib/sstring.h"
 
 #define MIGRATION_STOPPED -1
+#define MIGRATION_LASTERROR -2
 
 #define CONTACTLEN 100
 #define COMMENTLEN 300
 #define TRUSTNAMELEN 100
 #define TRUSTHOSTLEN 100
+#define MAXTGEXTS 5
 
 struct trustmigration;
 
+struct trusthost;
+
 typedef struct trusthost {
+  unsigned int id;
+
   uint32_t ip, mask;
-  unsigned int maxseen;
+  unsigned int maxusage;
   time_t lastseen;
 
+  nick *users;
+  struct trustgroup *group;
+
+  unsigned int count;
+
+
+  struct trusthost *parent, *children;
+  unsigned int marker;
+
+  struct trusthost *nextbychild;
   struct trusthost *next;
 } trusthost;
 
@@ -29,20 +46,39 @@ typedef struct trustgroup {
   unsigned int trustedfor;
   int mode;
   unsigned int maxperident;
-  unsigned int maxseen;
+  unsigned int maxusage;
   time_t expires;
   time_t lastseen;
   time_t lastmaxuserreset;
   sstring *createdby, *contact, *comment;
 
   trusthost *hosts;
+  unsigned int count;
+
+  unsigned int marker;
 
   struct trustgroup *next;
+
+  void *exts[MAXTGEXTS];
 } trustgroup;
 
+#define nextbytrust(x) (nick *)((x)->exts[trusts_nextuserext])
+#define gettrusthost(x) (trusthost *)((x)->exts[trusts_thext])
+#define setnextbytrust(x, y) (x)->exts[trusts_nextuserext] = (y)
+#define settrusthost(x, y) (x)->exts[trusts_thext] = (y)
+
+/* trusts.c */
+extern int trusts_thext, trusts_nextuserext;
+int findtgext(const char *);
+int registertgext(const char *);
+void releasetgext(int);
+
 /* db.c */
 extern int trustsdbloaded;
-void trusts_reloaddb(void);
+int trusts_loaddb(void);
+void trusts_closedb(int);
+trustgroup *tg_new(char *name, unsigned int trustedfor, int mode, unsigned int maxperident, time_t expires, char *createdby, char *contact, char *comment);
+trusthost *th_new(trustgroup *tg, char *host);
 
 /* formats.c */
 char *trusts_timetostr(time_t);
@@ -52,12 +88,22 @@ char *trusts_cidr2str(uint32_t, uint32_t);
 
 /* data.c */
 extern trustgroup *tglist;
-void trusts_freeall(void);
 trustgroup *tg_getbyid(unsigned int);
 void th_free(trusthost *);
-int th_add(trustgroup *, char *, unsigned int, time_t);
+trusthost *th_add(trustgroup *, unsigned int, char *, unsigned int, time_t);
 void tg_free(trustgroup *);
-int tg_add(unsigned int, char *, unsigned int, int, unsigned int, unsigned int, time_t, time_t, time_t, char *, char *, char *);
+trustgroup *tg_add(unsigned int, char *, unsigned int, int, unsigned int, unsigned int, time_t, time_t, time_t, char *, char *, char *);
+trusthost *th_getbyhost(uint32_t);
+trusthost *th_getbyhostandmask(uint32_t, uint32_t);
+trusthost *th_getsmallestsupersetbyhost(uint32_t, uint32_t);
+trustgroup *tg_strtotg(char *);
+void th_adjusthosts(trusthost *th, trusthost *, trusthost *);
+void th_getsuperandsubsets(uint32_t, uint32_t, trusthost **, trusthost **);
+trusthost *th_getsubsetbyhost(uint32_t ip, uint32_t mask);
+trusthost *th_getnextsubsetbyhost(trusthost *th, uint32_t ip, uint32_t mask);
+void th_linktree(void);
+unsigned int nexttgmarker(void);
+unsigned int nextthmarker(void);
 
 /* migration.c */
 typedef void (*TrustMigrationGroup)(void *, unsigned int, char *, unsigned int, unsigned int, unsigned int, unsigned int, time_t, time_t, time_t, char *, char *, char *);
@@ -75,7 +121,10 @@ typedef struct trustmigration {
 } trustmigration;
 
 /* db-migration.c */
-
 typedef void (*TrustDBMigrationCallback)(int, void *);
 
+/* events.c */
+void trusts_newnick(nick *, int);
+void trusts_lostnick(nick *, int);
+
 #endif