Changes to make the default prefix /usr/local/samba - as it was in 1.9.18p10.
[samba.git] / source / utils / testparm.c
1 /* 
2    Unix SMB/Netbios implementation.
3    Version 1.9.
4    Test validity of smb.conf
5    Copyright (C) Karl Auer 1993, 1994-1998
6
7    Extensively modified by Andrew Tridgell, 1995
8    
9    This program is free software; you can redistribute it and/or modify
10    it under the terms of the GNU General Public License as published by
11    the Free Software Foundation; either version 2 of the License, or
12    (at your option) any later version.
13    
14    This program is distributed in the hope that it will be useful,
15    but WITHOUT ANY WARRANTY; without even the implied warranty of
16    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17    GNU General Public License for more details.
18    
19    You should have received a copy of the GNU General Public License
20    along with this program; if not, write to the Free Software
21    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22 */
23
24 /*
25  * Testbed for loadparm.c/params.c
26  *
27  * This module simply loads a specified configuration file and
28  * if successful, dumps it's contents to stdout. Note that the
29  * operation is performed with DEBUGLEVEL at 3.
30  *
31  * Useful for a quick 'syntax check' of a configuration file.
32  *
33  */
34
35 #include "includes.h"
36 #include "smb.h"
37
38 /* these live in util.c */
39 extern FILE *dbf;
40 extern int DEBUGLEVEL;
41 extern pstring myhostname;
42
43 /***********************************************
44  Here we do a set of 'hard coded' checks for bad
45  configuration settings.
46 ************************************************/
47 static void do_global_checks(void)
48 {
49         SMB_STRUCT_STAT st;
50         if (lp_security() > SEC_SHARE && lp_revalidate(-1)) {
51                 printf("WARNING: the 'revalidate' parameter is ignored in all but \
52 'security=share' mode.\n");
53         }
54
55     if (lp_security() == SEC_DOMAIN && !lp_encrypted_passwords()) {
56                 printf("ERROR: in 'security=domain' mode the 'encrypt passwords' parameter must also be set to 'true'.\n");
57         }
58
59         if (lp_wins_support() && *lp_wins_server()) {
60                 printf("ERROR: both 'wins support = true' and 'wins server = <server>' \
61 cannot be set in the smb.conf file. nmbd will abort with this setting.\n");
62         }
63
64         if (!directory_exist(lp_lockdir(), &st)) {
65                 printf("ERROR: lock directory %s does not exist\n",
66                        lp_lockdir());
67         } else if ((st.st_mode & 0777) != 0755) {
68                 printf("WARNING: lock directory %s should have permissions 0755 for browsing to work\n",
69                        lp_lockdir());
70         }
71 }   
72
73  int main(int argc, char *argv[])
74 {
75   pstring configfile;
76   int s;
77
78   TimeInit();
79
80   setup_logging(argv[0],True);
81   
82   charset_initialise();
83
84   if (argc < 2)
85     pstrcpy(configfile,CONFIGFILE);
86   else
87     pstrcpy(configfile,argv[1]);
88
89   dbf = stdout;
90   DEBUGLEVEL = 2;
91
92   printf("Load smb config files from %s\n",configfile);
93
94   if(!get_myname(myhostname,NULL))
95   {
96     printf("Failed to get my hostname.\n");
97     return(1);
98   }
99
100   if (!lp_load(configfile,False,True,False))
101     {
102       printf("Error loading services.\n");
103       return(1);
104     }
105
106
107   printf("Loaded services file OK.\n");
108
109   do_global_checks();
110
111   for (s=0;s<1000;s++)
112     if (VALID_SNUM(s))
113       if (strlen(lp_servicename(s)) > 8) {
114         printf("WARNING: You have some share names that are longer than 8 chars\n");
115         printf("These may give errors while browsing or may not be accessible\nto some older clients\n");
116         break;
117       }
118
119   if (argc < 4)
120     {
121       printf("Press enter to see a dump of your service definitions\n");
122       fflush(stdout);
123       getc(stdin);
124       lp_dump(stdout,True);
125     }
126   
127   if (argc == 4)
128     {
129       char *cname = argv[2];
130       char *caddr = argv[3];
131       
132       /* this is totally ugly, a real `quick' hack */
133       for (s=0;s<1000;s++)
134         if (VALID_SNUM(s))
135           {              
136             if (allow_access(lp_hostsdeny(s),lp_hostsallow(s),cname,caddr))
137               {
138                 printf("Allow connection from %s (%s) to %s\n",
139                        cname,caddr,lp_servicename(s));
140               }
141             else
142               {
143                 printf("Deny connection from %s (%s) to %s\n",
144                        cname,caddr,lp_servicename(s));
145               }
146           }
147     }
148   return(0);
149 }
150
151