2 * Copyright 2000, International Business Machines Corporation and others.
5 * This software has been released under the terms of the IBM Public
6 * License. For details, see the LICENSE file in the top-level source
7 * directory or online at http://www.openafs.org/dl/license10.html
13 Interface to the routines used by the FileServer to manipulate the cell/server database
14 for the Cellular Andrew system, along with an operation to determine the name of the
15 local cell. Included are a string variable used to hold the local cell name, definitions for
16 the database file format and routines for:
17 1) Acquiring the local cell name.
18 2) Reading in the cell/server database from disk.
19 3) Reporting the set of servers associated with a given cell name.
20 4) Printing out the contents of the cell/server database.
21 5) Reclaiming the space used by an in-memory database.
26 --------------------------------------------------------------------------------------------------------------*/
28 #ifndef __CELLCONFIG_AFS_INCL_
29 #define __CELLCONFIG_AFS_INCL_ 1
36 #include <sys/types.h>
37 #include <netinet/in.h>
41 #define MAXCELLCHARS 64
42 #define MAXHOSTCHARS 64
43 #define MAXHOSTSPERCELL 8
48 #define AFSCONF_SUCCESS 0 /* worked */
50 #define AFSCONF_FAILURE 1 /* mysterious failure */
51 #define AFSCONF_NOTFOUND 2 /* could not find entry */
52 #define AFSCONF_UNKNOWN 3 /* do not know that information */
53 #define AFSCONF_NOCELL 4 /* line appears before a cell has been defined */
54 #define AFSCONF_SYNTAX 5 /* syntax error */
55 #define AFSCONF_NODB 6 /* a database file is missing */
56 #define AFSCONF_FULL 7 /* no more entries */
60 * Complete server info for one cell.
63 char name[MAXCELLCHARS]; /*Cell name*/
64 short numServers; /*Num active servers for the cell*/
65 short flags; /* useful flags */
66 struct sockaddr_in hostAddr[MAXHOSTSPERCELL]; /*IP addresses for cell's servers*/
67 char hostName[MAXHOSTSPERCELL][MAXHOSTCHARS]; /*Names for cell's servers*/
68 char *linkedCell; /* Linked cell name, if any */
71 struct afsconf_entry {
72 struct afsconf_entry *next; /* next guy in afsconf_dir */
73 struct afsconf_cell cellInfo; /* info for this cell */
77 char *name; /* pointer to dir prefix */
78 char *cellName; /* cell name, if any, we're in */
79 struct afsconf_entry *entries; /* list of cell entries */
80 struct afsconf_keys *keystr; /* structure containing keys */
81 afs_int32 timeRead; /* time stamp of file last read */
84 extern struct afsconf_dir *afsconf_Open();
85 extern afs_int32 afsconf_Authenticate();
87 struct afsconf_servPair {
93 /* some well-known ports and their names; new additions to table in cellconfig.c, too */
94 #define AFSCONF_FILESERVICE "afs"
95 #define AFSCONF_FILEPORT 7000
96 #define AFSCONF_CALLBACKSERVICE "afscb"
97 #define AFSCONF_CALLBACKPORT 7001
98 #define AFSCONF_PROTSERVICE "afsprot"
99 #define AFSCONF_PROTPORT 7002
100 #define AFSCONF_VLDBSERVICE "afsvldb"
101 #define AFSCONF_VLDBPORT 7003
102 #define AFSCONF_KAUTHSERVICE "afskauth"
103 #define AFSCONF_KAUTHPORT 7004
104 #define AFSCONF_VOLUMESERVICE "afsvol"
105 #define AFSCONF_VOLUMEPORT 7005
106 #define AFSCONF_ERRORSERVICE "afserror"
107 #define AFSCONF_ERRORPORT 7006
108 #define AFSCONF_NANNYSERVICE "afsnanny"
109 #define AFSCONF_NANNYPORT 7007
110 #define AFSCONF_UPDATESERVICE "afsupdate"
111 #define AFSCONF_UPDATEPORT 7008
112 #define AFSCONF_RMTSYSSERVICE "afsrmtsys"
113 #define AFSCONF_RMTSYSPORT 7009
115 #endif /* __CELLCONFIG_AFS_INCL_ */