The Samba-Bugzilla – Attachment 11129 Details for
Bug 11305
ZIP archives can't be extracted on share with vfs_fruit
Home
|
New
|
Browse
|
Search
|
[?]
|
Reports
|
Requests
|
Help
|
New Account
|
Log In
[x]
|
Forgot Password
Login:
[x]
[patch]
Patch for master
veto.patch (text/plain), 4.11 KB, created by
Ralph Böhme
on 2015-06-08 14:49:05 UTC
(
hide
)
Description:
Patch for master
Filename:
MIME Type:
Creator:
Ralph Böhme
Created:
2015-06-08 14:49:05 UTC
Size:
4.11 KB
patch
obsolete
>From cba6a067011ec1225fb55865e28e6002e52753a6 Mon Sep 17 00:00:00 2001 >From: Ralph Boehme <slow@samba.org> >Date: Sat, 9 May 2015 08:31:24 +0200 >Subject: [PATCH] vfs_fruit: add option veto_appledouble > >vfs_fruit adds a wildcard path "._*" to the vetolist in order to prevent >client access to ._ AppleDouble files created internally by vfs_fruit >for storing the Mac resource fork stream. > >Unfortunately there are legitimite use cases where an OS X client may >want to use such filenames, extracting ZIP archives (where the archive >contains ._ files) being one of them. > >A possible simple solution to this problem would be to not veto ._ files >in the first place, even though that exposes internally created ._ files >which the client shouldn't be able to access. > >Bug: https://bugzilla.samba.org/show_bug.cgi?id=11305 > >Signed-off-by: Ralph Boehme <slow@samba.org> >--- > docs-xml/manpages/vfs_fruit.8.xml | 17 ++++++++++++++ > source3/modules/vfs_fruit.c | 48 +++++++++++++++++++++++---------------- > 2 files changed, 45 insertions(+), 20 deletions(-) > >diff --git a/docs-xml/manpages/vfs_fruit.8.xml b/docs-xml/manpages/vfs_fruit.8.xml >index 4e296a4..e407b54 100644 >--- a/docs-xml/manpages/vfs_fruit.8.xml >+++ b/docs-xml/manpages/vfs_fruit.8.xml >@@ -197,6 +197,23 @@ > </listitem> > </varlistentry> > >+ <varlistentry> >+ <term>fruit:veto_appledouble = yes | no</term> >+ <listitem> >+ <para>Whether ._ AppleDouble files are vetoed which >+ prevents the client from seing and accessing internal >+ AppleDouble files created by vfs_fruit itself for the >+ purpose of storing a Mac resource fork.</para> >+ <para>Vetoing ._ files may break some applications, eg >+ extracting Mac ZIP archives from Mac clients failes, >+ because they contain ._ files. Setting this option to >+ false will fix this, but the abstraction leak of >+ exposing the internally created ._ files may have other >+ unknown side effects.</para> >+ <para>The default is <emphasis>yes</emphasis>.</para> >+ </listitem> >+ </varlistentry> >+ > </variablelist> > </refsect1> > >diff --git a/source3/modules/vfs_fruit.c b/source3/modules/vfs_fruit.c >index 8f582c6..2547838 100644 >--- a/source3/modules/vfs_fruit.c >+++ b/source3/modules/vfs_fruit.c >@@ -126,6 +126,7 @@ struct fruit_config_data { > bool use_aapl; > bool readdir_attr_enabled; > bool unix_info_enabled; >+ bool veto_appledouble; > > /* > * Additional options, all enabled by default, >@@ -1334,6 +1335,11 @@ static int init_fruit_config(vfs_handle_struct *handle) > } > config->encoding = (enum fruit_encoding)enumval; > >+ if (lp_parm_bool(SNUM(handle->conn), >+ FRUIT_PARAM_TYPE_NAME, "veto_appledouble", true)) { >+ config->veto_appledouble = true; >+ } >+ > if (lp_parm_bool(-1, FRUIT_PARAM_TYPE_NAME, "aapl", true)) { > config->use_aapl = true; > } >@@ -2014,26 +2020,6 @@ static int fruit_connect(vfs_handle_struct *handle, > return rc; > } > >- list = lp_veto_files(talloc_tos(), SNUM(handle->conn)); >- >- if (list) { >- if (strstr(list, "/" ADOUBLE_NAME_PREFIX "*/") == NULL) { >- newlist = talloc_asprintf( >- list, >- "%s/" ADOUBLE_NAME_PREFIX "*/", >- list); >- lp_do_parameter(SNUM(handle->conn), >- "veto files", >- newlist); >- } >- } else { >- lp_do_parameter(SNUM(handle->conn), >- "veto files", >- "/" ADOUBLE_NAME_PREFIX "*/"); >- } >- >- TALLOC_FREE(list); >- > rc = init_fruit_config(handle); > if (rc != 0) { > return rc; >@@ -2042,6 +2028,28 @@ static int fruit_connect(vfs_handle_struct *handle, > SMB_VFS_HANDLE_GET_DATA(handle, config, > struct fruit_config_data, return -1); > >+ if (config->veto_appledouble) { >+ list = lp_veto_files(talloc_tos(), SNUM(handle->conn)); >+ >+ if (list) { >+ if (strstr(list, "/" ADOUBLE_NAME_PREFIX "*/") == NULL) { >+ newlist = talloc_asprintf( >+ list, >+ "%s/" ADOUBLE_NAME_PREFIX "*/", >+ list); >+ lp_do_parameter(SNUM(handle->conn), >+ "veto files", >+ newlist); >+ } >+ } else { >+ lp_do_parameter(SNUM(handle->conn), >+ "veto files", >+ "/" ADOUBLE_NAME_PREFIX "*/"); >+ } >+ >+ TALLOC_FREE(list); >+ } >+ > if (config->encoding == FRUIT_ENC_NATIVE) { > lp_do_parameter( > SNUM(handle->conn), >-- >2.1.0 >
You cannot view the attachment while viewing its details because your browser does not support IFRAMEs.
View the attachment on a separate page
.
View Attachment As Raw
Actions:
View
Attachments on
bug 11305
:
11117
| 11129 |
11144