patch-2.4.20 linux-2.4.20/net/khttpd/security.c
Next file: linux-2.4.20/net/khttpd/sysctl.c
Previous file: linux-2.4.20/net/khttpd/main.c
Back to the patch index
Back to the overall index
- Lines: 109
- Date:
Thu Nov 28 15:53:16 2002
- Orig file:
linux-2.4.19/net/khttpd/security.c
- Orig date:
Fri Feb 9 11:29:44 2001
diff -urN linux-2.4.19/net/khttpd/security.c linux-2.4.20/net/khttpd/security.c
@@ -83,22 +83,21 @@
*/
struct file *OpenFileForSecurity(char *Filename)
{
- struct file *filp;
+ struct file *filp = NULL;
struct DynamicString *List;
umode_t permission;
-
-
EnterFunction("OpenFileForSecurity");
if (Filename==NULL)
- return NULL;
+ goto out_error;
- if (strlen(Filename)>=256 ) return NULL; /* Sanity check */
+ if (strlen(Filename)>=256 )
+ goto out_error; /* Sanity check */
/* Rule no. 1 -- No "?" characters */
#ifndef BENCHMARK
if (strchr(Filename,'?')!=NULL)
- return NULL;
+ goto out_error;
/* Intermediate step: decode all %hex sequences */
@@ -106,9 +105,8 @@
/* Rule no. 2 -- Must start with a "/" */
-
if (Filename[0]!='/')
- return NULL;
+ goto out_error;
#endif
/* Rule no. 3 -- Does the file exist ? */
@@ -116,55 +114,44 @@
filp = filp_open(Filename, O_RDONLY, 0);
if (IS_ERR(filp))
- return NULL;
+ goto out_error;
#ifndef BENCHMARK
permission = filp->f_dentry->d_inode->i_mode;
/* Rule no. 4 : must have enough permissions */
-
if ((permission & sysctl_khttpd_permreq)==0)
- {
- if (filp!=NULL)
- fput(filp);
- filp=NULL;
- return NULL;
- }
-
+ goto out_error_put;
+
/* Rule no. 5 : cannot have "forbidden" permission */
-
if ((permission & sysctl_khttpd_permforbid)!=0)
- {
- if (filp!=NULL)
- fput(filp);
- filp=NULL;
- return NULL;
- }
+ goto out_error_put;
/* Rule no. 6 : No string in DynamicList can be a
substring of the filename */
-
List = DynamicList;
-
while (List!=NULL)
{
if (strstr(Filename,List->value)!=NULL)
- {
- if (filp!=NULL)
- fput(filp);
- filp=NULL;
- return NULL;
- }
+ goto out_error_put;
+
List = List->Next;
}
#endif
LeaveFunction("OpenFileForSecurity - success");
-
+out:
return filp;
+
+out_error_put:
+ fput(filp);
+out_error:
+ filp=NULL;
+ LeaveFunction("OpenFileForSecurity - fail");
+ goto out;
}
/*
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)