fix dlen
[citadel.git] / citadel / citadel.h
diff --git a/citadel/citadel.h b/citadel/citadel.h
deleted file mode 100644 (file)
index aa108c3..0000000
+++ /dev/null
@@ -1,199 +0,0 @@
-/*
- * Main Citadel header file
- *
- * Copyright (c) 1987-2018 by the citadel.org team
- *
- * This program is open source software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 3.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- */
-
-/* system customizations are in sysconfig.h */
-
-#ifndef CITADEL_H
-#define CITADEL_H
-/* #include <dmalloc.h> uncomment if using dmalloc */
-
-#include "sysdep.h"
-#include <limits.h>
-#include "sysconfig.h"
-#include "typesize.h"
-#include "ipcdef.h"
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/*
- * Text description of this software
- * (We used to define this ourselves, but why bother when
- * the GNU build tools do it for us?)
- */
-#define CITADEL        PACKAGE_STRING
-
-#define REV_LEVEL      921             // This version
-#define REV_MIN                591             // Oldest compatible database
-#define EXPORT_REV_MIN 760             // Oldest compatible export files
-#define LIBCITADEL_MIN 920             // Minimum required version of libcitadel
-
-#define SERVER_TYPE 0                  // zero for stock Citadel; other developers please
-                                       // obtain SERVER_TYPE codes for your implementations
-
-#ifdef LIBCITADEL_VERSION_NUMBER
-#if LIBCITADEL_VERSION_NUMBER < LIBCITADEL_MIN
-#error libcitadel is too old.  Please upgrade it before continuing.
-#endif
-#endif
-
-/* Various length constants */
-
-#define ROOMNAMELEN    128             /* The size of a roomname string */
-#define USERNAME_SIZE  64              /* The size of a username string */
-#define MAX_EDITORS    5               /* number of external editors supported ; must be at least 1 */
-
-/*
- * Message expiration policy stuff
- */
-typedef struct ExpirePolicy ExpirePolicy;
-struct ExpirePolicy {
-       int expire_mode;
-       int expire_value;
-};
-
-#define EXPIRE_NEXTLEVEL       0       // Inherit expiration policy
-#define EXPIRE_MANUAL          1       // Don't expire messages at all
-#define EXPIRE_NUMMSGS         2       // Keep only latest n messages
-#define EXPIRE_AGE             3       // Expire messages after n days
-
-
-/*
- * This struct stores a list of rooms with new messages which the client
- * fetches from the server.  This allows the client to "march" through
- * relevant rooms without having to ask the server each time where to go next.
- */
-typedef struct march march;
-struct march {
-       struct march *next;
-       char march_name[ROOMNAMELEN];
-       unsigned int march_flags;
-       char march_floor;
-       char march_order;
-       unsigned int march_flags2;
-       int march_access;
-};
-
-
-/*
- * User records.
- */
-typedef struct ctdluser ctdluser;
-struct ctdluser {                      // User record
-       int version;                    // Cit vers. which created this rec
-       uid_t uid;                      // Associate with a unix account?
-       char password[32];              // password
-       unsigned flags;                 // See US_ flags below
-       long timescalled;               // Total number of logins
-       long posted;                    // Number of messages ever submitted
-       cit_uint8_t axlevel;            // Access level
-       long usernum;                   // User number (never recycled)
-       time_t lastcall;                // Date/time of most recent login
-       int USuserpurge;                // Purge time (in days) for user
-       char fullname[64];              // Display name (primary identifier)
-       long msgnum_bio;                // msgnum of user's profile (bio)
-       long msgnum_pic;                // msgnum of user's avatar (photo)
-       char emailaddrs[512];           // Internet email addresses
-};
-
-
-/* Bits which may appear in MMflags.
- */
-#define MM_VALID       4               // New users need validating
-
-/*
- * Room records.
- */
-typedef struct ctdlroom ctdlroom;
-struct ctdlroom {
-       char QRname[ROOMNAMELEN];       // Name of room
-       char QRpasswd[10];              // Only valid if it's a private rm
-       long QRroomaide;                // User number of room aide
-       long QRhighest;                 // Highest message NUMBER in room
-       time_t QRgen;                   // Generation number of room
-       unsigned QRflags;               // See flag values below
-       char QRdirname[15];             // Directory name, if applicable
-       long msgnum_info;               // msgnum of room banner (info file)
-       char QRfloor;                   // Which floor this room is on
-       time_t QRmtime;                 // Date/time of last post
-       struct ExpirePolicy QRep;       // Message expiration policy
-       long QRnumber;                  // Globally unique room number
-       char QRorder;                   // Sort key for room listing order
-       unsigned QRflags2;              // Additional flags
-       int QRdefaultview;              // How to display the contents
-       long msgnum_pic;                // msgnum of room picture or icon
-};
-
-/* Private rooms are always flagged with QR_PRIVATE.  If neither QR_PASSWORDED
- * or QR_GUESSNAME is set, then it is invitation-only.  Passworded rooms are
- * flagged with both QR_PRIVATE and QR_PASSWORDED while guess-name rooms are
- * flagged with both QR_PRIVATE and QR_GUESSNAME.  NEVER set all three flags.
- */
-
-/*
- * Miscellaneous
- */
-#define MES_NORMAL     65              // Normal message
-#define MES_ANONONLY   66              // "****" header
-#define MES_ANONOPT    67              // "Anonymous" header
-
-#define MES_ERROR      (-1)            // Can't send message due to bad address
-#define MES_LOCAL      0               // Local message, do no network processing
-#define MES_INTERNET   1               // Convert msg and send as Internet mail
-
-/****************************************************************************/
-
-/*
- * Floor record.  The floor number is implicit in its location in the file.
- */
-typedef struct floor floor;
-struct floor {
-       unsigned short f_flags;         // flags
-       char f_name[256];               // name of floor
-       int f_ref_count;                // reference count
-       struct ExpirePolicy f_ep;       // default expiration policy
-};
-
-#define F_INUSE                1               // floor is in use
-
-
-/*
- * Values used internally for function call returns, etc.
- */
-#define NEWREGISTER    0               // new user to register
-#define REREGISTER     1               // existing user reregistering
-
-/* number of items which may be handled by the CONF command */
-#define NUM_CONFIGS 71
-
-#define TRACE  syslog(LOG_DEBUG, "\033[31mCheckpoint: %s : %d\033[0m", __FILE__, __LINE__)
-
-#ifndef LONG_MAX
-#define LONG_MAX 2147483647L
-#endif
-
-/*
- * Authentication modes
- */
-#define AUTHMODE_NATIVE                0       // Native (self-contained or "black box")
-#define AUTHMODE_HOST          1       // Authenticate against the host OS user database
-#define AUTHMODE_LDAP          2       // Authenticate against an LDAP server with RFC 2307 schema
-#define AUTHMODE_LDAP_AD       3       // Authenticate against non-standard MS Active Directory LDAP
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* CITADEL_H */