diff options
author | Stefan Metzmacher <metze@samba.org> | 2004-04-29 17:19:42 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 10:51:22 -0500 |
commit | 77182a81f0e370584d37dc9368f0697b8cf69afd (patch) | |
tree | d6e414f018457843b8fdcc927a9da3382efb4e89 | |
parent | 3250a8ab0aa70b1658dbc187af56d20de5c32cc8 (diff) | |
download | samba-77182a81f0e370584d37dc9368f0697b8cf69afd.tar.gz samba-77182a81f0e370584d37dc9368f0697b8cf69afd.tar.bz2 samba-77182a81f0e370584d37dc9368f0697b8cf69afd.zip |
r408: - replace (conn->admin_user != True) with (current_user.uid != 0)
because someone changed it in all other places too
- fix quotas support from windows explorer
we now got the unix file name of a fake_file
metze
(This used to be commit 87e97d7723674e3835578ef080ce554d9c5537ac)
-rw-r--r-- | source3/include/fake_file.h | 4 | ||||
-rw-r--r-- | source3/smbd/fake_file.c | 2 | ||||
-rw-r--r-- | source3/smbd/nttrans.c | 2 | ||||
-rw-r--r-- | source3/smbd/trans2.c | 4 |
4 files changed, 8 insertions, 4 deletions
diff --git a/source3/include/fake_file.h b/source3/include/fake_file.h index 3fe60072e9..cfcd16f683 100644 --- a/source3/include/fake_file.h +++ b/source3/include/fake_file.h @@ -26,7 +26,11 @@ enum FAKE_FILE_TYPE { FAKE_FILE_TYPE_QUOTA }; +/* +we now get the unix name --metze #define FAKE_FILE_NAME_QUOTA "\\$Extend\\$Quota:$Q:$INDEX_ALLOCATION" +*/ +#define FAKE_FILE_NAME_QUOTA "$Extend/$Quota:$Q:$INDEX_ALLOCATION" typedef struct _FAKE_FILE_HANDLE { enum FAKE_FILE_TYPE type; diff --git a/source3/smbd/fake_file.c b/source3/smbd/fake_file.c index 5ccb548ba5..d3660addf1 100644 --- a/source3/smbd/fake_file.c +++ b/source3/smbd/fake_file.c @@ -40,7 +40,7 @@ files_struct *open_fake_file_shared1(enum FAKE_FILE_TYPE fake_file_type, connect } /* access check */ - if (conn->admin_user != True) { + if (current_user.uid != 0) { DEBUG(1,("access_denied to service[%s] file[%s] user[%s]\n", lp_servicename(SNUM(conn)),fname,conn->user)); errno = EACCES; diff --git a/source3/smbd/nttrans.c b/source3/smbd/nttrans.c index 6ba74d5d50..e4ffec339b 100644 --- a/source3/smbd/nttrans.c +++ b/source3/smbd/nttrans.c @@ -2351,7 +2351,7 @@ static int call_nt_transact_set_user_quota(connection_struct *conn, char *inbuf, ZERO_STRUCT(qt); /* access check */ - if (conn->admin_user != True) { + if (current_user.uid != 0) { DEBUG(1,("set_user_quota: access_denied service [%s] user [%s]\n", lp_servicename(SNUM(conn)),conn->user)); return ERROR_DOS(ERRDOS,ERRnoaccess); diff --git a/source3/smbd/trans2.c b/source3/smbd/trans2.c index a1d068e38f..0d84c40065 100644 --- a/source3/smbd/trans2.c +++ b/source3/smbd/trans2.c @@ -2010,7 +2010,7 @@ cBytesSector=%u, cUnitTotal=%u, cUnitAvail=%d\n", (unsigned int)bsize, (unsigned fsp.fd = -1; /* access check */ - if (conn->admin_user != True) { + if (current_user.uid != 0) { DEBUG(0,("set_user_quota: access_denied service [%s] user [%s]\n", lp_servicename(SNUM(conn)),conn->user)); return ERROR_DOS(ERRDOS,ERRnoaccess); @@ -2108,7 +2108,7 @@ static int call_trans2setfsinfo(connection_struct *conn, DEBUG(10,("call_trans2setfsinfo: SET_FS_QUOTA: for service [%s]\n",lp_servicename(SNUM(conn)))); /* access check */ - if ((conn->admin_user != True)||!CAN_WRITE(conn)) { + if ((current_user.uid != 0)||!CAN_WRITE(conn)) { DEBUG(0,("set_user_quota: access_denied service [%s] user [%s]\n", lp_servicename(SNUM(conn)),conn->user)); return ERROR_DOS(ERRSRV,ERRaccess); |