]> jfr.im git - irc/quakenet/newserv.git/blobdiff - trusts/trusts.h
NOPERSERV: clarify +h noticeflag help text.
[irc/quakenet/newserv.git] / trusts / trusts.h
index 43afd6cc5484e0580da3afc1a90ea60332fa86bc..fbec7025cb334cc2b59260c6ea9dd0f46c325a63 100644 (file)
@@ -2,30 +2,51 @@
 #define __TRUSTS_H
 
 #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 CREATEDBYLEN NICKLEN + 1
+
+#define MAXTGEXTS 5
+
+#define MAXTRUSTEDFOR 50000
+#define MAXDURATION 365 * 86400 * 20
+#define MAXPERIDENT 1000
+
+#define TABLES_REGULAR 0
+#define TABLES_MIGRATION 1
+#define TABLES_REPLICATION 2
 
 struct trustmigration;
 
-typedef void (*TrustMigrationGroup)(void *, unsigned int, char *, unsigned int, unsigned int, unsigned int, unsigned int, time_t, time_t, time_t, char *, char *, char *);
-typedef void (*TrustMigrationHost)(void *, unsigned int, char *, unsigned int, time_t);
-typedef void (*TrustMigrationFini)(void *, int);
+struct trusthost;
 
-typedef struct trustmigration {
-  int count, cur;
-  void *schedule;
-  void *tag;
+typedef struct trusthost {
+  unsigned int id;
 
-  TrustMigrationGroup group;
-  TrustMigrationHost host;
-  TrustMigrationFini fini;
-} trustmigration;
+  uint32_t ip, mask;
+  unsigned int maxusage;
+  time_t lastseen;
 
-typedef void (*TrustDBMigrationCallback)(int, void *);
+  nick *users;
+  struct trustgroup *group;
+
+  unsigned int count;
+
+  struct trusthost *parent, *children;
+  unsigned int marker;
+
+  struct trusthost *nextbychild;
+  struct trusthost *next;
+} trusthost;
 
 typedef struct trustgroup {
   unsigned int id;
@@ -34,23 +55,103 @@ typedef struct trustgroup {
   unsigned int trustedfor;
   int mode;
   unsigned int maxperident;
+  unsigned int maxusage;
   time_t expires;
-  time_t latseeen;
-  time_t lastmaxuserreset;
-
+  time_t lastseen;
+  time_t lastmaxusereset;
   sstring *createdby, *contact, *comment;
 
+  trusthost *hosts;
+  unsigned int count;
+
+  unsigned int marker;
+
   struct trustgroup *next;
+
+  void *exts[MAXTGEXTS];
 } trustgroup;
 
-typedef struct trusthost {
-  unsigned int id;
+#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);
+int trusts_fullyonline(void);
+
+/* formats.c */
+char *trusts_timetostr(time_t);
+int trusts_parsecidr(const char *, uint32_t *, short *);
+int trusts_str2cidr(const char *, uint32_t *, uint32_t *);
+char *trusts_cidr2str(uint32_t, uint32_t);
+char *dumpth(trusthost *, int);
+char *dumptg(trustgroup *, int);
+int parseth(char *, trusthost *, unsigned int *, int);
+int parsetg(char *, trustgroup *, int);
+char *rtrim(char *);
+
+/* data.c */
+extern trustgroup *tglist;
+trustgroup *tg_getbyid(unsigned int);
+void th_free(trusthost *);
+trusthost *th_add(trusthost *);
+void tg_free(trustgroup *, int);
+trustgroup *tg_add(trustgroup *);
+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);
+trusthost *th_getbyid(unsigned int);
+int tg_modify(trustgroup *, trustgroup *);
+
+/* migration.c */
+typedef void (*TrustMigrationGroup)(void *, trustgroup *);
+typedef void (*TrustMigrationHost)(void *, trusthost *, unsigned int);
+typedef void (*TrustMigrationFini)(void *, int);
 
-  sstring *mask;
-  unsigned int max;
-  time_t lastseen;
+/* trusts_db.c */
+extern int trustsdbloaded;
+int trusts_loaddb(void);
+void trusts_closedb(int);
+trustgroup *tg_new(trustgroup *);
+trusthost *th_new(trustgroup *, char *);
+void trustsdb_insertth(char *, trusthost *, unsigned int);
+void trustsdb_inserttg(char *, trustgroup *);
+trustgroup *tg_copy(trustgroup *);
+trusthost *th_copy(trusthost *);
+void tg_update(trustgroup *);
+void tg_delete(trustgroup *);
+void th_delete(trusthost *);
 
-  struct trusthost *next;
-} trusthost;
+typedef struct trustmigration {
+  int count, cur;
+  void *schedule;
+  void *tag;
+
+  TrustMigrationGroup group;
+  TrustMigrationHost host;
+  TrustMigrationFini fini;
+} trustmigration;
+
+/* db-migration.c */
+typedef void (*TrustDBMigrationCallback)(int, void *);
+
+/* events.c */
+void trusts_newnick(nick *, int);
+void trusts_lostnick(nick *, int);
+
+/* trusts_api.c */
+int istrusted(nick *);
 
 #endif