diff options
author | Jeremy Allison <jra@samba.org> | 2004-03-10 02:38:39 +0000 |
---|---|---|
committer | Jeremy Allison <jra@samba.org> | 2004-03-10 02:38:39 +0000 |
commit | 2867b9e2a059bed79d1ec7825d625d06e0472b96 (patch) | |
tree | 9d5730ec6449586f7416ee5a055814a9398d1f99 /source3/msdfs | |
parent | ccf93c36d8d838b7bb56cc089ed56e8da4db5528 (diff) | |
download | samba-2867b9e2a059bed79d1ec7825d625d06e0472b96.tar.gz samba-2867b9e2a059bed79d1ec7825d625d06e0472b96.tar.bz2 samba-2867b9e2a059bed79d1ec7825d625d06e0472b96.zip |
Moving towards getting msdfs working again (this looks like it was broken
in 3.0.2a actually). We now send a correct referral back, but the client
refuses to follow it... Not sure why. Will do more tests.. Maybe unicode
character count is wrong (it looks it).
Jeremy.
(This used to be commit e2709f99fc4e603897472d3ba3bf1ca2e7ca728f)
Diffstat (limited to 'source3/msdfs')
-rw-r--r-- | source3/msdfs/msdfs.c | 67 |
1 files changed, 62 insertions, 5 deletions
diff --git a/source3/msdfs/msdfs.c b/source3/msdfs/msdfs.c index 081ce809cf..41f66ecd51 100644 --- a/source3/msdfs/msdfs.c +++ b/source3/msdfs/msdfs.c @@ -50,7 +50,7 @@ static BOOL parse_dfs_path(char* pathname, struct dfs_path* pdp) return False; *p = '\0'; pstrcpy(pdp->hostname,temp); - DEBUG(10,("hostname: %s\n",pdp->hostname)); + DEBUG(10,("parse_dfs_path: hostname: %s\n",pdp->hostname)); /* parse out servicename */ temp = p+1; @@ -62,7 +62,7 @@ static BOOL parse_dfs_path(char* pathname, struct dfs_path* pdp) } *p = '\0'; pstrcpy(pdp->servicename,temp); - DEBUG(10,("servicename: %s\n",pdp->servicename)); + DEBUG(10,("parse_dfs_path: servicename: %s\n",pdp->servicename)); /* rest is reqpath */ pstrcpy(pdp->reqpath, p+1); @@ -71,7 +71,54 @@ static BOOL parse_dfs_path(char* pathname, struct dfs_path* pdp) *p++ = '/'; } - DEBUG(10,("rest of the path: %s\n",pdp->reqpath)); + DEBUG(10,("parse_dfs_path: rest of the path: %s\n",pdp->reqpath)); + return True; +} + +/********************************************************************** + Parse the pathname of the form /hostname/service/reqpath + into the dfs_path structure + **********************************************************************/ + +static BOOL parse_processed_dfs_path(char* pathname, struct dfs_path* pdp) +{ + pstring pathname_local; + char* p,*temp; + + pstrcpy(pathname_local,pathname); + p = temp = pathname_local; + + ZERO_STRUCTP(pdp); + + trim_char(temp,'/','/'); + DEBUG(10,("temp in parse_processed_dfs_path: .%s. after trimming \\'s\n",temp)); + + /* now tokenize */ + /* parse out hostname */ + p = strchr_m(temp,'/'); + if(p == NULL) + return False; + *p = '\0'; + pstrcpy(pdp->hostname,temp); + DEBUG(10,("parse_processed_dfs_path: hostname: %s\n",pdp->hostname)); + + /* parse out servicename */ + temp = p+1; + p = strchr_m(temp,'/'); + if(p == NULL) { + pstrcpy(pdp->servicename,temp); + pdp->reqpath[0] = '\0'; + return True; + } + *p = '\0'; + pstrcpy(pdp->servicename,temp); + DEBUG(10,("parse_processed_dfs_path: servicename: %s\n",pdp->servicename)); + + /* rest is reqpath */ + /* JRA. We should do a check_path_syntax here.... TOFIX ! */ + pstrcpy(pdp->reqpath, p+1); + + DEBUG(10,("parse_processed_dfs_path: rest of the path: %s\n",pdp->reqpath)); return True; } @@ -99,11 +146,20 @@ static BOOL create_conn_struct( connection_struct *conn, int snum, char *path) talloc_destroy( conn->mem_ctx ); return False; } + + /* + * Windows seems to insist on doing trans2getdfsreferral() calls on the IPC$ + * share as the anonymous user. If we try to chdir as that user we will + * fail.... WTF ? JRA. + */ + if (vfs_ChDir(conn,conn->connectpath) != 0) { DEBUG(3,("create_conn_struct: Can't ChDir to new conn path %s. Error was %s\n", conn->connectpath, strerror(errno) )); +#if 0 /* JRATEST ? */ talloc_destroy( conn->mem_ctx ); return False; +#endif } return True; } @@ -113,6 +169,7 @@ static BOOL create_conn_struct( connection_struct *conn, int snum, char *path) Parse the contents of a symlink to verify if it is an msdfs referral A valid referral is of the form: msdfs:server1\share1,server2\share2 **********************************************************************/ + static BOOL parse_symlink(char* buf,struct referral** preflist, int* refcount) { @@ -317,7 +374,7 @@ BOOL dfs_redirect(pstring pathname, connection_struct* conn, if (!conn || !pathname) return False; - parse_dfs_path(pathname, &dp); + parse_processed_dfs_path(pathname, &dp); /* if dfs pathname for a non-dfs share, convert to tcon-relative path and return false */ @@ -768,7 +825,7 @@ static BOOL junction_to_local_path(struct junction_map* jucn, char* path, return True; } -BOOL create_msdfs_link(struct junction_map* jucn, BOOL exists) +BOOL create_msdfs_link(struct junction_map *jucn, BOOL exists) { pstring path; pstring msdfs_link; |