mirror of
https://github.com/samba-team/samba.git
synced 2025-01-14 19:24:43 +03:00
initial support for paramter type P_LIST
it will avoid problems with lists being longer than 1024 bytes just now only ip list parameters have been converted to the new type (hosts allow, hosts deny, ssl hosts, ssl hosts resign) (This used to be commit e1572f85d6247b760db10825b2fa688d7ed50bd3)
This commit is contained in:
parent
567612291e
commit
82970b833c
source3
File diff suppressed because it is too large
Load Diff
@ -735,7 +735,7 @@ struct locking_data {
|
||||
/* the following are used by loadparm for option lists */
|
||||
typedef enum
|
||||
{
|
||||
P_BOOL,P_BOOLREV,P_CHAR,P_INTEGER,P_OCTAL,
|
||||
P_BOOL,P_BOOLREV,P_CHAR,P_INTEGER,P_OCTAL,P_LIST,
|
||||
P_STRING,P_USTRING,P_GSTRING,P_UGSTRING,P_ENUM,P_SEP
|
||||
} parm_type;
|
||||
|
||||
@ -774,6 +774,7 @@ struct parm_struct
|
||||
int ivalue;
|
||||
char *svalue;
|
||||
char cvalue;
|
||||
char **lvalue;
|
||||
} def;
|
||||
};
|
||||
|
||||
|
@ -148,20 +148,11 @@ token '%s' in an allow/deny hosts line.\n", invalid_char, tok ));
|
||||
}
|
||||
|
||||
/* list_match - match an item against a list of tokens with exceptions */
|
||||
/* (All modifications are marked with the initials "jkf") */
|
||||
static int list_match(char *list,char *item, int (*match_fn)(char *, char *))
|
||||
static int list_match(char **list,char *item, int (*match_fn)(char *, char *))
|
||||
{
|
||||
char *tok;
|
||||
char *listcopy; /* jkf */
|
||||
int match = False;
|
||||
|
||||
/*
|
||||
* jkf@soton.ac.uk -- 31 August 1994 -- Stop list_match()
|
||||
* overwriting the list given as its first parameter.
|
||||
*/
|
||||
|
||||
/* jkf -- can get called recursively with NULL list */
|
||||
listcopy = (list == 0) ? (char *)0 : strdup(list);
|
||||
if (!list) return False;
|
||||
|
||||
/*
|
||||
* Process tokens one at a time. We have exhausted all possible matches
|
||||
@ -170,30 +161,30 @@ static int list_match(char *list,char *item, int (*match_fn)(char *, char *))
|
||||
* the match is affected by any exceptions.
|
||||
*/
|
||||
|
||||
for (tok = strtok(listcopy, sep); tok ; tok = strtok(NULL, sep)) {
|
||||
if (strcasecmp(tok, "EXCEPT") == 0) /* EXCEPT: give up */
|
||||
for (; *list ; list++) {
|
||||
if (strcasecmp(*list, "EXCEPT") == 0) /* EXCEPT: give up */
|
||||
break;
|
||||
if ((match = (*match_fn) (tok, item))) /* True or FAIL */
|
||||
if ((match = (*match_fn) (*list, item))) /* True or FAIL */
|
||||
break;
|
||||
}
|
||||
/* Process exceptions to True or FAIL matches. */
|
||||
|
||||
if (match != False) {
|
||||
while ((tok = strtok((char *) 0, sep)) && strcasecmp(tok, "EXCEPT"))
|
||||
/* VOID */ ;
|
||||
if (tok == 0 || list_match((char *) 0, item, match_fn) == False) {
|
||||
if (listcopy != 0) free(listcopy); /* jkf */
|
||||
return (match);
|
||||
while (*list && strcasecmp(*list, "EXCEPT"))
|
||||
list++;
|
||||
|
||||
for (; *list; list++) {
|
||||
if ((*match_fn) (*list, item)) /* Exception Found */
|
||||
return False;
|
||||
}
|
||||
}
|
||||
|
||||
if (listcopy != 0) free(listcopy); /* jkf */
|
||||
return (False);
|
||||
return (match);
|
||||
}
|
||||
|
||||
|
||||
/* return true if access should be allowed */
|
||||
BOOL allow_access(char *deny_list,char *allow_list,
|
||||
BOOL allow_access(char **deny_list,char **allow_list,
|
||||
char *cname,char *caddr)
|
||||
{
|
||||
char *client[2];
|
||||
@ -241,24 +232,22 @@ BOOL allow_access(char *deny_list,char *allow_list,
|
||||
|
||||
/* return true if the char* contains ip addrs only. Used to avoid
|
||||
gethostbyaddr() calls */
|
||||
static BOOL only_ipaddrs_in_list(const char* list)
|
||||
static BOOL only_ipaddrs_in_list(char** list)
|
||||
{
|
||||
BOOL only_ip = True;
|
||||
char *listcopy,
|
||||
*tok;
|
||||
|
||||
listcopy = strdup(list);
|
||||
if (!list) return True;
|
||||
|
||||
for (tok = strtok(listcopy, sep); tok ; tok = strtok(NULL, sep))
|
||||
for (; *list ; list++)
|
||||
{
|
||||
/* factor out the special strings */
|
||||
if (!strcasecmp(tok, "ALL") || !strcasecmp(tok, "FAIL") ||
|
||||
!strcasecmp(tok, "EXCEPT"))
|
||||
if (!strcasecmp(*list, "ALL") || !strcasecmp(*list, "FAIL") ||
|
||||
!strcasecmp(*list, "EXCEPT"))
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
if (!is_ipaddress(tok))
|
||||
if (!is_ipaddress(*list))
|
||||
{
|
||||
char *p;
|
||||
/*
|
||||
@ -266,30 +255,24 @@ static BOOL only_ipaddrs_in_list(const char* list)
|
||||
* was a network/netmask pair. Only network/netmask pairs
|
||||
* have a '/' in them
|
||||
*/
|
||||
if ((p=strchr(tok, '/')) == NULL)
|
||||
if ((p=strchr(*list, '/')) == NULL)
|
||||
{
|
||||
only_ip = False;
|
||||
DEBUG(3,("only_ipaddrs_in_list: list [%s] has non-ip address %s\n", list, tok));
|
||||
DEBUG(3,("only_ipaddrs_in_list: list has non-ip address (%s)\n", *list));
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (listcopy)
|
||||
free (listcopy);
|
||||
|
||||
return only_ip;
|
||||
}
|
||||
|
||||
/* return true if access should be allowed to a service for a socket */
|
||||
BOOL check_access(int sock, char *allow_list, char *deny_list)
|
||||
BOOL check_access(int sock, char **allow_list, char **deny_list)
|
||||
{
|
||||
BOOL ret = False;
|
||||
BOOL only_ip = False;
|
||||
|
||||
if (deny_list) deny_list = strdup(deny_list);
|
||||
if (allow_list) allow_list = strdup(allow_list);
|
||||
|
||||
if ((!deny_list || *deny_list==0) && (!allow_list || *allow_list==0))
|
||||
{
|
||||
ret = True;
|
||||
@ -325,8 +308,5 @@ BOOL check_access(int sock, char *allow_list, char *deny_list)
|
||||
}
|
||||
}
|
||||
|
||||
if (deny_list) free(deny_list);
|
||||
if (allow_list) free(allow_list);
|
||||
|
||||
return(ret);
|
||||
}
|
||||
|
@ -221,8 +221,8 @@ typedef struct
|
||||
#endif /* WITH_LDAP */
|
||||
#ifdef WITH_SSL
|
||||
int sslVersion;
|
||||
char *sslHostsRequire;
|
||||
char *sslHostsResign;
|
||||
char **sslHostsRequire;
|
||||
char **sslHostsResign;
|
||||
char *sslCaCertDir;
|
||||
char *sslCaCertFile;
|
||||
char *sslCert;
|
||||
@ -317,8 +317,8 @@ typedef struct
|
||||
char *szPrinterDriverLocation;
|
||||
char *szDriverFile;
|
||||
char *szDontdescend;
|
||||
char *szHostsallow;
|
||||
char *szHostsdeny;
|
||||
char **szHostsallow;
|
||||
char **szHostsdeny;
|
||||
char *szMagicScript;
|
||||
char *szMagicOutput;
|
||||
char *szMangledMap;
|
||||
@ -738,17 +738,17 @@ static struct parm_struct parm_table[] = {
|
||||
{"public", P_BOOL, P_LOCAL, &sDefault.bGuest_ok, NULL, NULL, 0},
|
||||
|
||||
{"only user", P_BOOL, P_LOCAL, &sDefault.bOnlyUser, NULL, NULL, FLAG_SHARE},
|
||||
{"hosts allow", P_STRING, P_LOCAL, &sDefault.szHostsallow, NULL, NULL, FLAG_GLOBAL | FLAG_BASIC | FLAG_SHARE | FLAG_PRINT},
|
||||
{"allow hosts", P_STRING, P_LOCAL, &sDefault.szHostsallow, NULL, NULL, 0},
|
||||
{"hosts deny", P_STRING, P_LOCAL, &sDefault.szHostsdeny, NULL, NULL, FLAG_GLOBAL | FLAG_BASIC | FLAG_SHARE | FLAG_PRINT},
|
||||
{"deny hosts", P_STRING, P_LOCAL, &sDefault.szHostsdeny, NULL, NULL, 0},
|
||||
{"hosts allow", P_LIST, P_LOCAL, &sDefault.szHostsallow, NULL, NULL, FLAG_GLOBAL | FLAG_BASIC | FLAG_SHARE | FLAG_PRINT},
|
||||
{"allow hosts", P_LIST, P_LOCAL, &sDefault.szHostsallow, NULL, NULL, 0},
|
||||
{"hosts deny", P_LIST, P_LOCAL, &sDefault.szHostsdeny, NULL, NULL, FLAG_GLOBAL | FLAG_BASIC | FLAG_SHARE | FLAG_PRINT},
|
||||
{"deny hosts", P_LIST, P_LOCAL, &sDefault.szHostsdeny, NULL, NULL, 0},
|
||||
|
||||
#ifdef WITH_SSL
|
||||
{"Secure Socket Layer Options", P_SEP, P_SEPARATOR},
|
||||
{"ssl", P_BOOL, P_GLOBAL, &Globals.sslEnabled, NULL, NULL, 0},
|
||||
|
||||
{"ssl hosts", P_STRING, P_GLOBAL, &Globals.sslHostsRequire, NULL, NULL, 0},
|
||||
{"ssl hosts resign", P_STRING, P_GLOBAL, &Globals.sslHostsResign, NULL, NULL, 0},
|
||||
{"ssl hosts", P_LIST, P_GLOBAL, &Globals.sslHostsRequire, NULL, NULL, 0},
|
||||
{"ssl hosts resign", P_LIST, P_GLOBAL, &Globals.sslHostsResign, NULL, NULL, 0},
|
||||
{"ssl CA certDir", P_STRING, P_GLOBAL, &Globals.sslCaCertDir, NULL, NULL, 0},
|
||||
{"ssl CA certFile", P_STRING, P_GLOBAL, &Globals.sslCaCertFile, NULL, NULL, 0},
|
||||
{"ssl server cert", P_STRING, P_GLOBAL, &Globals.sslCert, NULL, NULL, 0},
|
||||
@ -1301,8 +1301,8 @@ static void init_globals(void)
|
||||
|
||||
#ifdef WITH_SSL
|
||||
Globals.sslVersion = SMB_SSL_V23;
|
||||
string_set(&Globals.sslHostsRequire, "");
|
||||
string_set(&Globals.sslHostsResign, "");
|
||||
/* Globals.sslHostsRequire = NULL;
|
||||
Globals.sslHostsResign = NULL; */
|
||||
string_set(&Globals.sslCaCertDir, "");
|
||||
string_set(&Globals.sslCaCertFile, "");
|
||||
string_set(&Globals.sslCert, "");
|
||||
@ -1411,6 +1411,8 @@ static char *lp_string(const char *s)
|
||||
|
||||
#define FN_GLOBAL_STRING(fn_name,ptr) \
|
||||
char *fn_name(void) {return(lp_string(*(char **)(ptr) ? *(char **)(ptr) : ""));}
|
||||
#define FN_GLOBAL_LIST(fn_name,ptr) \
|
||||
char **fn_name(void) {return(*(char ***)(ptr));}
|
||||
#define FN_GLOBAL_BOOL(fn_name,ptr) \
|
||||
BOOL fn_name(void) {return(*(BOOL *)(ptr));}
|
||||
#define FN_GLOBAL_CHAR(fn_name,ptr) \
|
||||
@ -1420,6 +1422,8 @@ static char *lp_string(const char *s)
|
||||
|
||||
#define FN_LOCAL_STRING(fn_name,val) \
|
||||
char *fn_name(int i) {return(lp_string((LP_SNUM_OK(i) && ServicePtrs[(i)]->val) ? ServicePtrs[(i)]->val : sDefault.val));}
|
||||
#define FN_LOCAL_LIST(fn_name,val) \
|
||||
char **fn_name(int i) {return(LP_SNUM_OK(i)? ServicePtrs[(i)]->val : sDefault.val);}
|
||||
#define FN_LOCAL_BOOL(fn_name,val) \
|
||||
BOOL fn_name(int i) {return(LP_SNUM_OK(i)? ServicePtrs[(i)]->val : sDefault.val);}
|
||||
#define FN_LOCAL_CHAR(fn_name,val) \
|
||||
@ -1506,8 +1510,8 @@ FN_GLOBAL_STRING(lp_delete_share_cmd, &Globals.szDeleteShareCommand)
|
||||
|
||||
#ifdef WITH_SSL
|
||||
FN_GLOBAL_INTEGER(lp_ssl_version, &Globals.sslVersion)
|
||||
FN_GLOBAL_STRING(lp_ssl_hosts, &Globals.sslHostsRequire)
|
||||
FN_GLOBAL_STRING(lp_ssl_hosts_resign, &Globals.sslHostsResign)
|
||||
FN_GLOBAL_LIST(lp_ssl_hosts, &Globals.sslHostsRequire)
|
||||
FN_GLOBAL_LIST(lp_ssl_hosts_resign, &Globals.sslHostsResign)
|
||||
FN_GLOBAL_STRING(lp_ssl_cacertdir, &Globals.sslCaCertDir)
|
||||
FN_GLOBAL_STRING(lp_ssl_cacertfile, &Globals.sslCaCertFile)
|
||||
FN_GLOBAL_STRING(lp_ssl_cert, &Globals.sslCert)
|
||||
@ -1618,8 +1622,8 @@ FN_LOCAL_STRING(lp_queueresumecommand, szQueueresumecommand)
|
||||
static FN_LOCAL_STRING(_lp_printername, szPrintername)
|
||||
FN_LOCAL_STRING(lp_driverfile, szDriverFile)
|
||||
FN_LOCAL_STRING(lp_printerdriver, szPrinterDriver)
|
||||
FN_LOCAL_STRING(lp_hostsallow, szHostsallow)
|
||||
FN_LOCAL_STRING(lp_hostsdeny, szHostsdeny)
|
||||
FN_LOCAL_LIST(lp_hostsallow, szHostsallow)
|
||||
FN_LOCAL_LIST(lp_hostsdeny, szHostsdeny)
|
||||
FN_LOCAL_STRING(lp_magicscript, szMagicScript)
|
||||
FN_LOCAL_STRING(lp_magicoutput, szMagicOutput)
|
||||
FN_LOCAL_STRING(lp_comment, comment)
|
||||
@ -1743,12 +1747,20 @@ static void free_service(service * pservice)
|
||||
}
|
||||
|
||||
for (i = 0; parm_table[i].label; i++)
|
||||
{
|
||||
if ((parm_table[i].type == P_STRING ||
|
||||
parm_table[i].type == P_USTRING) &&
|
||||
parm_table[i].class == P_LOCAL)
|
||||
string_free((char **)
|
||||
(((char *)pservice) +
|
||||
PTR_DIFF(parm_table[i].ptr, &sDefault)));
|
||||
else if (parm_table[i].type == P_LIST &&
|
||||
parm_table[i].class == P_LOCAL)
|
||||
lp_list_free(*(char ***)
|
||||
(((char *)pservice) +
|
||||
PTR_DIFF(parm_table[i].ptr, &sDefault)));
|
||||
}
|
||||
|
||||
|
||||
ZERO_STRUCTP(pservice);
|
||||
}
|
||||
@ -2035,6 +2047,9 @@ static void copy_service(service * pserviceDest,
|
||||
*(char **)src_ptr);
|
||||
strupper(*(char **)dest_ptr);
|
||||
break;
|
||||
case P_LIST:
|
||||
lp_list_copy((char ***)dest_ptr, *(char ***)src_ptr);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
@ -2630,6 +2645,10 @@ BOOL lp_do_parameter(int snum, char *pszParmName, char *pszParmValue)
|
||||
sscanf(pszParmValue, "%o", (int *)parm_ptr);
|
||||
break;
|
||||
|
||||
case P_LIST:
|
||||
*(char ***)parm_ptr = lp_list_make(pszParmValue);
|
||||
break;
|
||||
|
||||
case P_STRING:
|
||||
string_set(parm_ptr, pszParmValue);
|
||||
if (parm_table[parmnum].flags & FLAG_DOS_STRING)
|
||||
@ -2733,6 +2752,21 @@ static void print_parameter(struct parm_struct *p, void *ptr, FILE * f, char *(
|
||||
fprintf(f, "%s", octal_string(*(int *)ptr));
|
||||
break;
|
||||
|
||||
case P_LIST:
|
||||
if ((char ***)ptr && *(char ***)ptr) {
|
||||
char **list = *(char ***)ptr;
|
||||
|
||||
if (p->flags & FLAG_DOS_STRING)
|
||||
for (; *list; list++)
|
||||
fprintf(f, "%s%s", dos_to_ext(*list, False),
|
||||
((*(list+1))?", ":""));
|
||||
else
|
||||
for (; *list; list++)
|
||||
fprintf(f, "%s%s", *list,
|
||||
((*(list+1))?", ":""));
|
||||
}
|
||||
break;
|
||||
|
||||
case P_GSTRING:
|
||||
case P_UGSTRING:
|
||||
if ((char *)ptr) {
|
||||
@ -2777,6 +2811,9 @@ static BOOL equal_parameter(parm_type type, void *ptr1, void *ptr2)
|
||||
case P_CHAR:
|
||||
return (*((char *)ptr1) == *((char *)ptr2));
|
||||
|
||||
case P_LIST:
|
||||
return lp_list_compare(*(char ***)ptr1, *(char ***)ptr2);
|
||||
|
||||
case P_GSTRING:
|
||||
case P_UGSTRING:
|
||||
{
|
||||
@ -2875,6 +2912,9 @@ static BOOL is_default(int i)
|
||||
return False;
|
||||
switch (parm_table[i].type)
|
||||
{
|
||||
case P_LIST:
|
||||
return lp_list_compare (parm_table[i].def.lvalue,
|
||||
*(char ***)parm_table[i].ptr);
|
||||
case P_STRING:
|
||||
case P_USTRING:
|
||||
return strequal(parm_table[i].def.svalue,
|
||||
@ -3178,6 +3218,10 @@ static void lp_save_defaults(void)
|
||||
continue;
|
||||
switch (parm_table[i].type)
|
||||
{
|
||||
case P_LIST:
|
||||
lp_list_copy(&(parm_table[i].def.lvalue),
|
||||
*(char ***)parm_table[i].ptr);
|
||||
break;
|
||||
case P_STRING:
|
||||
case P_USTRING:
|
||||
parm_table[i].def.svalue =
|
||||
@ -3622,3 +3666,125 @@ char *lp_printername(int snum)
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
||||
/***********************************************************
|
||||
List Parameters manipulation functions
|
||||
***********************************************************/
|
||||
|
||||
#define P_LIST_ABS 16 /* P_LIST Allocation Block Size */
|
||||
|
||||
char **lp_list_make(char *string)
|
||||
{
|
||||
char **list, **rlist;
|
||||
char *str;
|
||||
char *tok;
|
||||
int num, lsize;
|
||||
|
||||
if (!string || !*string) return NULL;
|
||||
str = strdup(string);
|
||||
if (!str || !*str) return NULL;
|
||||
|
||||
list = (char**)malloc(((sizeof(char**)) * P_LIST_ABS));
|
||||
if (!list) {
|
||||
free (str);
|
||||
return NULL;
|
||||
}
|
||||
memset (list, 0, ((sizeof(char**)) * P_LIST_ABS));
|
||||
lsize = P_LIST_ABS;
|
||||
|
||||
num = 0;
|
||||
|
||||
for (tok = strtok(str, LIST_SEP); tok; tok = strtok(NULL, LIST_SEP))
|
||||
{
|
||||
if (!*tok) continue;
|
||||
|
||||
if ((num +1) == lsize) {
|
||||
lsize += P_LIST_ABS;
|
||||
rlist = (char **)realloc(list, ((sizeof(char **)) * lsize));
|
||||
if (!rlist) {
|
||||
lp_list_free (list);
|
||||
free (str);
|
||||
return NULL;
|
||||
}
|
||||
else list = rlist;
|
||||
memset (&list[num], 0, ((sizeof(char**)) * P_LIST_ABS));
|
||||
}
|
||||
|
||||
list[num] = strdup(tok);
|
||||
if (!list[num]) {
|
||||
lp_list_free (list);
|
||||
free (str);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
num++;
|
||||
}
|
||||
|
||||
free (str);
|
||||
return list;
|
||||
}
|
||||
|
||||
BOOL lp_list_copy(char ***dest, char **src)
|
||||
{
|
||||
char **list, **rlist;
|
||||
char *tok;
|
||||
int num, lsize;
|
||||
|
||||
*dest = NULL;
|
||||
if (!src) return False;
|
||||
|
||||
list = (char**)malloc(((sizeof(char**)) * P_LIST_ABS));
|
||||
if (!list) return False;
|
||||
memset (list, 0, ((sizeof(char**)) * P_LIST_ABS));
|
||||
lsize = P_LIST_ABS;
|
||||
|
||||
for (num = 0; src[num]; num++)
|
||||
{
|
||||
if ((num +1) == lsize) {
|
||||
lsize += P_LIST_ABS;
|
||||
rlist = (char **)realloc(list, ((sizeof(char **)) * lsize));
|
||||
if (!rlist) {
|
||||
lp_list_free (list);
|
||||
return False;
|
||||
}
|
||||
else list = rlist;
|
||||
memset (&list[num], 0, ((sizeof(char**)) * P_LIST_ABS));
|
||||
}
|
||||
|
||||
list[num] = strdup(src[num]);
|
||||
if (!list[num]) {
|
||||
lp_list_free (list);
|
||||
return False;
|
||||
}
|
||||
}
|
||||
|
||||
*dest = list;
|
||||
return True;
|
||||
}
|
||||
|
||||
/* return true if all the elemnts of the list matches exactly */
|
||||
BOOL lp_list_compare(char **list1, char **list2)
|
||||
{
|
||||
int num;
|
||||
|
||||
if (!list1 || !list2) return (list1 == list2);
|
||||
|
||||
for (num = 0; list1[num]; num++) {
|
||||
if (!list2[num]) return False;
|
||||
if (!strcsequal(list1[num], list2[num])) return False;
|
||||
}
|
||||
if (list2[num]) return False; /* if list2 has more elements than list1 fail */
|
||||
|
||||
return True;
|
||||
}
|
||||
|
||||
void lp_list_free(char **list)
|
||||
{
|
||||
char **tlist = list;
|
||||
|
||||
if (!list) return;
|
||||
for(; *tlist; tlist++) free(*tlist);
|
||||
free (list);
|
||||
}
|
||||
|
||||
|
@ -60,6 +60,11 @@ END {
|
||||
printf "BOOL %s(int );\n", a[2]
|
||||
}
|
||||
|
||||
/^FN_LOCAL_LIST/ {
|
||||
split($0,a,"[,()]")
|
||||
printf "char **%s(int );\n", a[2]
|
||||
}
|
||||
|
||||
/^FN_LOCAL_STRING/ {
|
||||
split($0,a,"[,()]")
|
||||
printf "char *%s(int );\n", a[2]
|
||||
@ -80,6 +85,11 @@ END {
|
||||
printf "BOOL %s(void);\n", a[2]
|
||||
}
|
||||
|
||||
/^FN_GLOBAL_LIST/ {
|
||||
split($0,a,"[,()]")
|
||||
printf "char **%s(void);\n", a[2]
|
||||
}
|
||||
|
||||
/^FN_GLOBAL_STRING/ {
|
||||
split($0,a,"[,()]")
|
||||
printf "char *%s(void);\n", a[2]
|
||||
|
@ -237,23 +237,28 @@ int main(int argc, char *argv[])
|
||||
|
||||
for (s=0;s<1000;s++) {
|
||||
if (VALID_SNUM(s)) {
|
||||
char *deny_list = lp_hostsdeny(s);
|
||||
char *allow_list = lp_hostsallow(s);
|
||||
char **deny_list = lp_hostsdeny(s);
|
||||
char **allow_list = lp_hostsallow(s);
|
||||
int i;
|
||||
if(deny_list) {
|
||||
char *hasstar = strchr(deny_list, '*');
|
||||
char *hasquery = strchr(deny_list, '?');
|
||||
for (i=0; deny_list[i]; i++) {
|
||||
char *hasstar = strchr(deny_list[i], '*');
|
||||
char *hasquery = strchr(deny_list[i], '?');
|
||||
if(hasstar || hasquery) {
|
||||
printf("Invalid character %c in hosts deny list %s for service %s.\n",
|
||||
hasstar ? *hasstar : *hasquery, deny_list, lp_servicename(s) );
|
||||
printf("Invalid character %c in hosts deny list (%s) for service %s.\n",
|
||||
hasstar ? *hasstar : *hasquery, deny_list[i], lp_servicename(s) );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if(allow_list) {
|
||||
char *hasstar = strchr(allow_list, '*');
|
||||
char *hasquery = strchr(allow_list, '?');
|
||||
for (i=0; allow_list[i]; i++) {
|
||||
char *hasstar = strchr(allow_list[i], '*');
|
||||
char *hasquery = strchr(allow_list[i], '?');
|
||||
if(hasstar || hasquery) {
|
||||
printf("Invalid character %c in hosts allow list %s for service %s.\n",
|
||||
hasstar ? *hasstar : *hasquery, allow_list, lp_servicename(s) );
|
||||
printf("Invalid character %c in hosts allow list (%s) for service %s.\n",
|
||||
hasstar ? *hasstar : *hasquery, allow_list[i], lp_servicename(s) );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user