Some systems seem to only accept a ntcreate&x with a unicode filename
authorTim Potter <tpot@samba.org>
Thu, 21 Dec 2000 05:28:39 +0000 (05:28 +0000)
committerTim Potter <tpot@samba.org>
Thu, 21 Dec 2000 05:28:39 +0000 (05:28 +0000)
despite samba negotiating ascii filenames.  Retry with unicode pathnames
if the ascii version fails.

Convert all forward slashes to backslashes in the filename argument.
(This used to be commit 935b77573ec82bece6211a9f61c800ef1c8c9aa4)

source3/utils/smbcacls.c

index bff80e7e5f6817ab9b9165e03f904d1ff5bb7675..d73699264f562ece39a387d79194f8b1c16147d3 100644 (file)
@@ -436,6 +436,29 @@ static void sec_desc_print(FILE *f, SEC_DESC *sd)
 
 }
 
+/* Some systems seem to require unicode pathnames for the ntcreate&x call
+   despite Samba negotiating ascii filenames.  Try with unicode pathname if
+   the ascii version fails. */
+
+int do_cli_nt_create(struct cli_state *cli, char *fname, uint32 DesiredAccess)
+{
+       int result;
+
+       result = cli_nt_create(cli, fname, DesiredAccess);
+
+       if (result == -1) {
+               uint32 errnum, nt_rpc_error;
+               uint8 errclass;
+
+               cli_error(cli, &errclass, &errnum, &nt_rpc_error);
+
+               if (errclass == ERRDOS && errnum == ERRbadpath) {
+                       result = cli_nt_create_uni(cli, fname, DesiredAccess);
+               }
+       }
+
+       return result;
+}
 
 /***************************************************** 
 dump the acls for a file
@@ -447,7 +470,7 @@ static void cacl_dump(struct cli_state *cli, char *filename)
 
        if (test_args) return;
 
-       fnum = cli_nt_create(cli, filename, 0x20000);
+       fnum = do_cli_nt_create(cli, filename, 0x20000);
        if (fnum == -1) {
                printf("Failed to open %s: %s\n", filename, cli_errstr(cli));
                return;
@@ -479,7 +502,10 @@ static void owner_set(struct cli_state *cli, enum chown_mode change_mode, char *
        SEC_DESC *sd, *old;
        size_t sd_size;
 
-       fnum = cli_nt_create(cli, filename, READ_CONTROL_ACCESS|WRITE_DAC_ACCESS|WRITE_OWNER_ACCESS);
+       fnum = do_cli_nt_create(cli, filename, 
+                               READ_CONTROL_ACCESS | WRITE_DAC_ACCESS
+                               | WRITE_OWNER_ACCESS);
+
        if (fnum == -1) {
                printf("Failed to open %s: %s\n", filename, cli_errstr(cli));
                return;
@@ -521,9 +547,12 @@ static void cacl_set(struct cli_state *cli, char *filename,
        if (!sd) return;
        if (test_args) return;
 
-       /* the desired access below is the only one I could find that works with
-          NT4, W2KP and Samba */
-       fnum = cli_nt_create(cli, filename, MAXIMUM_ALLOWED_ACCESS | 0x60000);
+       /* The desired access below is the only one I could find that works
+          with NT4, W2KP and Samba */
+
+       fnum = do_cli_nt_create(cli, filename, 
+                               MAXIMUM_ALLOWED_ACCESS | 0x60000);
+
        if (fnum == -1) {
                printf("Failed to open %s: %s\n", filename, cli_errstr(cli));
                return;
@@ -861,6 +890,17 @@ You can string acls together with spaces, commas or newlines\n\
                if (!cli) exit(1);
        }
 
+
+       {
+               char *s;
+
+               s = filename;
+               while(*s) {
+                       if (*s == '/') *s = '\\';
+                       s++;
+               }
+       }
+
        /* Perform requested action */
 
        if (change_mode != REQUEST_NONE) {