diff options
-rw-r--r-- | net/samba35/Makefile | 15 | ||||
-rw-r--r-- | net/samba35/distinfo | 4 | ||||
-rw-r--r-- | net/samba35/files/patch-nsswitch__pam_winbind.c | 2 | ||||
-rw-r--r-- | net/samba35/files/sernet.patch | 702 |
4 files changed, 677 insertions, 46 deletions
diff --git a/net/samba35/Makefile b/net/samba35/Makefile index d7a884176615..9571355bb222 100644 --- a/net/samba35/Makefile +++ b/net/samba35/Makefile @@ -6,8 +6,8 @@ # PORTNAME= ${SAMBA_BASENAME}35 -PORTVERSION= 3.5.6 -PORTREVISION?= 2 +PORTVERSION= 3.5.9 +PORTREVISION?= 0 CATEGORIES?= net MASTER_SITES= ${MASTER_SITE_SAMBA} MASTER_SITE_SUBDIR= . old-versions rc pre @@ -16,7 +16,7 @@ DISTNAME= ${SAMBA_BASENAME}-${PORTVERSION:S|.p|pre|:S|.r|rc|:S|.t|tp|:S|.a|alph MAINTAINER?= timur@FreeBSD.org COMMENT?= A free SMB and CIFS client and server for UNIX -CONFLICTS?= *samba3[0-4]-3.* sharity-light-1.* +CONFLICTS?= *samba3[2-4]-3.* # Additional patches from Sernet.de PATCH_STRIP= -p1 EXTRA_PATCHES= ${PATCHDIR}/sernet.patch @@ -74,7 +74,7 @@ CONFIGURE_ARGS+= --exec-prefix="${PREFIX}" \ CPPFLAGS+= -I${LOCALBASE}/include LDFLAGS+= -L${LOCALBASE}/lib -CONFIGURE_ENV+= CPPFLAGS="${CPPFLAGS}" LDFLAGS="${LDFLAGS}" \ +CONFIGURE_ENV+= LDFLAGS="${LDFLAGS}" \ PTHREAD_CFLAGS="${PTHREAD_CFLAGS}" \ PTHREAD_LDFLAGS="${PTHREAD_LIBS}" # pkg-config is used to find talloc @@ -94,7 +94,7 @@ CONFIGURE_ARGS+= --without-libtdb --enable-external-libtdb BUILD_DEPENDS+= talloc>=2.0.1:${PORTSDIR}/devel/talloc RUN_DEPENDS+= talloc>=2.0.1:${PORTSDIR}/devel/talloc CONFIGURE_ARGS+= --without-libtalloc --enable-external-libtalloc -# These options are common for all (sub)ports --disable-pie --disable-as-needed +# These options are common for all (sub)ports CONFIGURE_ARGS+= --with-libiconv="${LOCALBASE}" .if !defined(SAMBA_SUBPORT) @@ -121,10 +121,15 @@ OPTIONS= LDAP "With LDAP support" on \ .endif .include <bsd.port.options.mk> + # XXX .if ${OSVERSION} >= 701000 && ${OSVERSION} < 702000 IGNORE= databases/tdb crashes on FreeBSD 7.1. Please, consider upgrading to 7.2 or higher .endif +# There are reports that on ARM PIE makes binaries to core dump(#149186) +.if ${ARCH} == "arm" +CONFIGURE_ARGS+= --disable-pie +.endif .if defined(SAMBA_SUBPORT) # Switch off all extra functionality diff --git a/net/samba35/distinfo b/net/samba35/distinfo index aa76747662c1..3d6759795ebd 100644 --- a/net/samba35/distinfo +++ b/net/samba35/distinfo @@ -1,2 +1,2 @@ -SHA256 (samba-3.5.6.tar.gz) = 466410868375d19a286ac3fc5d9f3c267ce359189f8e0d76e72ec10bd54247da -SIZE (samba-3.5.6.tar.gz) = 30803319 +SHA256 (samba-3.5.9.tar.gz) = 8af8dccbb87a70a71f795180d873102b5cccba7012d66f2620cea8b87174380a +SIZE (samba-3.5.9.tar.gz) = 30750297 diff --git a/net/samba35/files/patch-nsswitch__pam_winbind.c b/net/samba35/files/patch-nsswitch__pam_winbind.c index 60f178178f58..b16145b1fd33 100644 --- a/net/samba35/files/patch-nsswitch__pam_winbind.c +++ b/net/samba35/files/patch-nsswitch__pam_winbind.c @@ -83,7 +83,7 @@ case 0: - pam_get_data(pamh, PAM_WINBIND_NEW_AUTHTOK_REQD, - (const void **)&tmp); -+ _pam_get_data(pamh, PAM_WINBIND_NEW_AUTHTOK_REQD, tmp); ++ _pam_get_data(pamh, PAM_WINBIND_NEW_AUTHTOK_REQD, &tmp); if (tmp != NULL) { ret = atoi((const char *)tmp); switch (ret) { diff --git a/net/samba35/files/sernet.patch b/net/samba35/files/sernet.patch index c0a64a71f426..0a61074f9a44 100644 --- a/net/samba35/files/sernet.patch +++ b/net/samba35/files/sernet.patch @@ -1,42 +1,5 @@ -0001-s3-Fix-another-aspect-of-bug-7262.patch samba3-3.4-honor-all-loopback-ips.patch - -From 325f03d3df7afb758b6815d327739fc121dbbe71 Mon Sep 17 00:00:00 2001 -From: Volker Lendecke <vl@samba.org> -Date: Tue, 6 Jul 2010 16:55:14 +0200 -Subject: [PATCH] s3: Fix another aspect of bug 7262 and make paged results work again ---- - source3/passdb/pdb_ldap.c | 8 ++++---- - 1 files changed, 4 insertions(+), 4 deletions(-) - -diff --git a/source3/passdb/pdb_ldap.c b/source3/passdb/pdb_ldap.c -index 6ac8f0d..f4c8dbe 100644 ---- a/source3/passdb/pdb_ldap.c -+++ b/source3/passdb/pdb_ldap.c -@@ -4483,10 +4483,6 @@ static bool ldapsam_search_next_entry(struct pdb_search *search, - bool result; - - retry: -- if (state->current_entry == NULL) { -- return false; -- } -- - if ((state->entries == NULL) && (state->pagedresults_cookie == NULL)) - return False; - -@@ -4494,6 +4490,10 @@ static bool ldapsam_search_next_entry(struct pdb_search *search, - !ldapsam_search_nextpage(search)) - return False; - -+ if (state->current_entry == NULL) { -+ return false; -+ } -+ - result = state->ldap2displayentry(state, search, - state->connection->ldap_struct, - state->current_entry, entry); --- -1.6.0.4 +samba-3.5-crossrename.patch commit b6afe7ef236a454d8a6abf104b8846f817378f73 Author: Björn Jacke <bj@sernet.de> @@ -70,3 +33,666 @@ index 0ce495e..0511a28 100644 } /** +From 433d1b5816a9a2befdf86c806f1ae79f7d35bef4 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Bj=C3=B6rn=20Jacke?= <bj@sernet.de> +Date: Mon, 8 Mar 2010 12:52:13 +0100 +Subject: [PATCH 1/3] s3: remove cross-device rename support from vfs_default + +cross-device rename support has some major limitations: + +- on huge files clients will timeout or hang +- ACLs and EA information is not retained + +Usually a client will have to handle this. A Windows Server with a reparse +point will also just return NT_STATUS_NOT_SAME_DEVICE. We will now by default +do the same. + +I will add a vfs module which will restore the old cross-device renames. +--- + source3/modules/vfs_default.c | 116 ----------------------------------------- + 1 files changed, 0 insertions(+), 116 deletions(-) + +diff --git a/source3/modules/vfs_default.c b/source3/modules/vfs_default.c +index 6e2a571..faca292 100644 +--- a/source3/modules/vfs_default.c ++++ b/source3/modules/vfs_default.c +@@ -475,117 +475,6 @@ static ssize_t vfswrap_recvfile(vfs_handle_struct *handle, + return result; + } + +-/********************************************************* +- For rename across filesystems Patch from Warren Birnbaum +- <warrenb@hpcvscdp.cv.hp.com> +-**********************************************************/ +- +-static int copy_reg(const char *source, const char *dest) +-{ +- SMB_STRUCT_STAT source_stats; +- int saved_errno; +- int ifd = -1; +- int ofd = -1; +- +- if (sys_lstat(source, &source_stats, false) == -1) +- return -1; +- +- if (!S_ISREG (source_stats.st_ex_mode)) +- return -1; +- +- if((ifd = sys_open (source, O_RDONLY, 0)) < 0) +- return -1; +- +- if (unlink (dest) && errno != ENOENT) +- return -1; +- +-#ifdef O_NOFOLLOW +- if((ofd = sys_open (dest, O_WRONLY | O_CREAT | O_TRUNC | O_NOFOLLOW, 0600)) < 0 ) +-#else +- if((ofd = sys_open (dest, O_WRONLY | O_CREAT | O_TRUNC , 0600)) < 0 ) +-#endif +- goto err; +- +- if (transfer_file(ifd, ofd, (size_t)-1) == -1) +- goto err; +- +- /* +- * Try to preserve ownership. For non-root it might fail, but that's ok. +- * But root probably wants to know, e.g. if NFS disallows it. +- */ +- +-#ifdef HAVE_FCHOWN +- if ((fchown(ofd, source_stats.st_ex_uid, source_stats.st_ex_gid) == -1) && (errno != EPERM)) +-#else +- if ((chown(dest, source_stats.st_ex_uid, source_stats.st_ex_gid) == -1) && (errno != EPERM)) +-#endif +- goto err; +- +- /* +- * fchown turns off set[ug]id bits for non-root, +- * so do the chmod last. +- */ +- +-#if defined(HAVE_FCHMOD) +- if (fchmod (ofd, source_stats.st_ex_mode & 07777)) +-#else +- if (chmod (dest, source_stats.st_ex_mode & 07777)) +-#endif +- goto err; +- +- if (close (ifd) == -1) +- goto err; +- +- if (close (ofd) == -1) +- return -1; +- +- /* Try to copy the old file's modtime and access time. */ +-#if defined(HAVE_UTIMENSAT) +- { +- struct timespec ts[2]; +- +- ts[0] = source_stats.st_ex_atime; +- ts[1] = source_stats.st_ex_mtime; +- utimensat(AT_FDCWD, dest, ts, AT_SYMLINK_NOFOLLOW); +- } +-#elif defined(HAVE_UTIMES) +- { +- struct timeval tv[2]; +- +- tv[0] = convert_timespec_to_timeval(source_stats.st_ex_atime); +- tv[1] = convert_timespec_to_timeval(source_stats.st_ex_mtime); +-#ifdef HAVE_LUTIMES +- lutimes(dest, tv); +-#else +- utimes(dest, tv); +-#endif +- } +-#elif defined(HAVE_UTIME) +- { +- struct utimbuf tv; +- +- tv.actime = convert_timespec_to_time_t(source_stats.st_ex_atime); +- tv.modtime = convert_timespec_to_time_t(source_stats.st_ex_mtime); +- utime(dest, &tv); +- } +-#endif +- +- if (unlink (source) == -1) +- return -1; +- +- return 0; +- +- err: +- +- saved_errno = errno; +- if (ifd != -1) +- close(ifd); +- if (ofd != -1) +- close(ofd); +- errno = saved_errno; +- return -1; +-} +- + static int vfswrap_rename(vfs_handle_struct *handle, + const struct smb_filename *smb_fname_src, + const struct smb_filename *smb_fname_dst) +@@ -600,11 +489,6 @@ static int vfswrap_rename(vfs_handle_struct *handle, + } + + result = rename(smb_fname_src->base_name, smb_fname_dst->base_name); +- if ((result == -1) && (errno == EXDEV)) { +- /* Rename across filesystems needed. */ +- result = copy_reg(smb_fname_src->base_name, +- smb_fname_dst->base_name); +- } + + out: + END_PROFILE(syscall_rename); +-- +1.6.6.1 + + +From 6dc931b27daf06aa1f4cdca19dae44ffef0bc3fb Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Bj=C3=B6rn=20Jacke?= <bj@sernet.de> +Date: Mon, 8 Mar 2010 18:18:59 +0100 +Subject: [PATCH 2/3] s3: add vfs_crossrename + +this module adds optional server-side support for limited rename operations +beyond filesystem boundaries, which was the previously the default. +--- + source3/Makefile.in | 5 + + source3/configure.in | 3 +- + source3/modules/vfs_crossrename.c | 200 +++++++++++++++++++++++++++++++++++++ + 3 files changed, 207 insertions(+), 1 deletions(-) + create mode 100644 source3/modules/vfs_crossrename.c + +diff --git a/source3/Makefile.in b/source3/Makefile.in +index f84ed20..2b90958 100644 +--- a/source3/Makefile.in ++++ b/source3/Makefile.in +@@ -741,6 +741,7 @@ PERFCOUNT_ONEFS_OBJ = modules/perfcount_onefs.o + PERFCOUNT_TEST_OBJ = modules/perfcount_test.o + VFS_DIRSORT_OBJ = modules/vfs_dirsort.o + VFS_SCANNEDONLY_OBJ = modules/vfs_scannedonly.o ++VFS_CROSSRENAME_OBJ = modules/vfs_crossrename.o + + PLAINTEXT_AUTH_OBJ = auth/pampass.o auth/pass_check.o + +@@ -2846,6 +2847,10 @@ bin/scannedonly.@SHLIBEXT@: $(BINARY_PREREQS) $(VFS_SCANNEDONLY_OBJ) + @echo "Building plugin $@" + @$(SHLD_MODULE) $(VFS_SCANNEDONLY_OBJ) + ++bin/crossrename.@SHLIBEXT@: $(BINARY_PREREQS) $(VFS_CROSSRENAME_OBJ) ++ @echo "Building plugin $@" ++ @$(SHLD_MODULE) $(VFS_CROSSRENAME_OBJ) ++ + ######################################################### + ## IdMap NSS plugins + +diff --git a/source3/configure.in b/source3/configure.in +index 0529a69..dbbc5be 100644 +--- a/source3/configure.in ++++ b/source3/configure.in +@@ -387,7 +387,7 @@ dnl These have to be built static: + default_static_modules="pdb_smbpasswd pdb_tdbsam pdb_wbc_sam rpc_lsarpc rpc_samr rpc_winreg rpc_initshutdown rpc_dssetup rpc_wkssvc rpc_svcctl rpc_ntsvcs rpc_netlogon rpc_netdfs rpc_srvsvc rpc_spoolss rpc_eventlog auth_sam auth_unix auth_winbind auth_wbc auth_server auth_domain auth_builtin auth_netlogond vfs_default nss_info_template" + + dnl These are preferably build shared, and static if dlopen() is not available +-default_shared_modules="vfs_recycle vfs_audit vfs_extd_audit vfs_full_audit vfs_netatalk vfs_fake_perms vfs_default_quota vfs_readonly vfs_cap vfs_expand_msdfs vfs_shadow_copy vfs_shadow_copy2 charset_CP850 charset_CP437 auth_script vfs_readahead vfs_xattr_tdb vfs_streams_xattr vfs_streams_depot vfs_acl_xattr vfs_acl_tdb vfs_smb_traffic_analyzer vfs_preopen vfs_catia vfs_scannedonly" ++default_shared_modules="vfs_recycle vfs_audit vfs_extd_audit vfs_full_audit vfs_netatalk vfs_fake_perms vfs_default_quota vfs_readonly vfs_cap vfs_expand_msdfs vfs_shadow_copy vfs_shadow_copy2 charset_CP850 charset_CP437 auth_script vfs_readahead vfs_xattr_tdb vfs_streams_xattr vfs_streams_depot vfs_acl_xattr vfs_acl_tdb vfs_smb_traffic_analyzer vfs_preopen vfs_catia vfs_scannedonly vfs_crossrename" + + if test "x$developer" = xyes; then + default_static_modules="$default_static_modules rpc_rpcecho pdb_ads" +@@ -6571,6 +6571,7 @@ SMB_MODULE(vfs_onefs, \$(VFS_ONEFS), "bin/onefs.$SHLIBEXT", VFS) + SMB_MODULE(vfs_onefs_shadow_copy, \$(VFS_ONEFS_SHADOW_COPY), "bin/onefs_shadow_copy.$SHLIBEXT", VFS) + SMB_MODULE(vfs_dirsort, \$(VFS_DIRSORT_OBJ), "bin/dirsort.$SHLIBEXT", VFS) + SMB_MODULE(vfs_scannedonly, \$(VFS_SCANNEDONLY_OBJ), "bin/scannedonly.$SHLIBEXT", VFS) ++SMB_MODULE(vfs_crossrename, \$(VFS_CROSSRENAME_OBJ), "bin/crossrename.$SHLIBEXT", VFS) + + SMB_SUBSYSTEM(VFS,smbd/vfs.o) + +diff --git a/source3/modules/vfs_crossrename.c b/source3/modules/vfs_crossrename.c +new file mode 100644 +index 0000000..323ceb1 +--- /dev/null ++++ b/source3/modules/vfs_crossrename.c +@@ -0,0 +1,200 @@ ++/* ++ * Copyright (c) Björn Jacke 2010 ++ * ++ * This program is free software; you can redistribute it and/or modify ++ * it under the terms of the GNU General Public License as published by ++ * the Free Software Foundation; either version 3 of the License, or ++ * (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, see <http://www.gnu.org/licenses/>. ++ */ ++ ++#include "includes.h" ++ ++ ++#define MODULE "crossrename" ++static SMB_OFF_T module_sizelimit; ++ ++static int crossrename_connect( ++ struct vfs_handle_struct * handle, ++ const char * service, ++ const char * user) ++{ ++ int ret = SMB_VFS_NEXT_CONNECT(handle, service, user); ++ ++ if (ret < 0) { ++ return ret; ++ } ++ ++ module_sizelimit = (SMB_OFF_T) lp_parm_int(SNUM(handle->conn), ++ MODULE, "sizelimit", 20); ++ /* convert from MiB to byte: */ ++ module_sizelimit *= 1048576; ++ ++ return 0; ++} ++ ++/********************************************************* ++ For rename across filesystems initial Patch from Warren Birnbaum ++ <warrenb@hpcvscdp.cv.hp.com> ++**********************************************************/ ++ ++static int copy_reg(const char *source, const char *dest) ++{ ++ SMB_STRUCT_STAT source_stats; ++ int saved_errno; ++ int ifd = -1; ++ int ofd = -1; ++ ++ if (sys_lstat(source, &source_stats, false) == -1) ++ return -1; ++ ++ if (!S_ISREG (source_stats.st_ex_mode)) ++ return -1; ++ ++ if (source_stats.st_ex_size > module_sizelimit) { ++ DEBUG(5, ++ ("%s: size of %s larger than sizelimit (%lld > %lld), rename prohititted\n", ++ MODULE, source, ++ (long long)source_stats.st_ex_size, ++ (long long)module_sizelimit)); ++ return -1; ++ } ++ ++ if((ifd = sys_open (source, O_RDONLY, 0)) < 0) ++ return -1; ++ ++ if (unlink (dest) && errno != ENOENT) ++ return -1; ++ ++#ifdef O_NOFOLLOW ++ if((ofd = sys_open (dest, O_WRONLY | O_CREAT | O_TRUNC | O_NOFOLLOW, 0600)) < 0 ) ++#else ++ if((ofd = sys_open (dest, O_WRONLY | O_CREAT | O_TRUNC , 0600)) < 0 ) ++#endif ++ goto err; ++ ++ if (transfer_file(ifd, ofd, (size_t)-1) == -1) ++ goto err; ++ ++ /* ++ * Try to preserve ownership. For non-root it might fail, but that's ok. ++ * But root probably wants to know, e.g. if NFS disallows it. ++ */ ++ ++#ifdef HAVE_FCHOWN ++ if ((fchown(ofd, source_stats.st_ex_uid, source_stats.st_ex_gid) == -1) && (errno != EPERM)) ++#else ++ if ((chown(dest, source_stats.st_ex_uid, source_stats.st_ex_gid) == -1) && (errno != EPERM)) ++#endif ++ goto err; ++ ++ /* ++ * fchown turns off set[ug]id bits for non-root, ++ * so do the chmod last. ++ */ ++ ++#if defined(HAVE_FCHMOD) ++ if (fchmod (ofd, source_stats.st_ex_mode & 07777)) ++#else ++ if (chmod (dest, source_stats.st_ex_mode & 07777)) ++#endif ++ goto err; ++ ++ if (close (ifd) == -1) ++ goto err; ++ ++ if (close (ofd) == -1) ++ return -1; ++ ++ /* Try to copy the old file's modtime and access time. */ ++#if defined(HAVE_UTIMENSAT) ++ { ++ struct timespec ts[2]; ++ ++ ts[0] = source_stats.st_ex_atime; ++ ts[1] = source_stats.st_ex_mtime; ++ utimensat(AT_FDCWD, dest, ts, AT_SYMLINK_NOFOLLOW); ++ } ++#elif defined(HAVE_UTIMES) ++ { ++ struct timeval tv[2]; ++ ++ tv[0] = convert_timespec_to_timeval(source_stats.st_ex_atime); ++ tv[1] = convert_timespec_to_timeval(source_stats.st_ex_mtime); ++#ifdef HAVE_LUTIMES ++ lutimes(dest, tv); ++#else ++ utimes(dest, tv); ++#endif ++ } ++#elif defined(HAVE_UTIME) ++ { ++ struct utimbuf tv; ++ ++ tv.actime = convert_timespec_to_time_t(source_stats.st_ex_atime); ++ tv.modtime = convert_timespec_to_time_t(source_stats.st_ex_mtime); ++ utime(dest, &tv); ++ } ++#endif ++ ++ if (unlink (source) == -1) ++ return -1; ++ ++ return 0; ++ ++ err: ++ ++ saved_errno = errno; ++ if (ifd != -1) ++ close(ifd); ++ if (ofd != -1) ++ close(ofd); ++ errno = saved_errno; ++ return -1; ++} ++ ++ ++static int crossrename_rename(vfs_handle_struct *handle, ++ const struct smb_filename *smb_fname_src, ++ const struct smb_filename *smb_fname_dst) ++{ ++ int result = -1; ++ ++ START_PROFILE(syscall_rename); ++ ++ if (smb_fname_src->stream_name || smb_fname_dst->stream_name) { ++ errno = ENOENT; ++ goto out; ++ } ++ ++ result = rename(smb_fname_src->base_name, smb_fname_dst->base_name); ++ if ((result == -1) && (errno == EXDEV)) { ++ /* Rename across filesystems needed. */ ++ result = copy_reg(smb_fname_src->base_name, ++ smb_fname_dst->base_name); ++ } ++ ++ out: ++ END_PROFILE(syscall_rename); ++ return result; ++} ++ ++static struct vfs_fn_pointers vfs_crossrename_fns = { ++ .connect_fn = crossrename_connect, ++ .rename = crossrename_rename ++}; ++ ++NTSTATUS vfs_crossrename_init(void); ++NTSTATUS vfs_crossrename_init(void) ++{ ++ return smb_register_vfs(SMB_VFS_INTERFACE_VERSION, MODULE, ++ &vfs_crossrename_fns); ++} ++ +-- +1.6.6.1 + + +From 555acebc72c2827691e91648f697212ffa6725d4 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Bj=C3=B6rn=20Jacke?= <bj@sernet.de> +Date: Mon, 8 Mar 2010 12:38:38 +0100 +Subject: [PATCH 3/3] s3: add man page for vfs_crossrename + +--- + docs-xml/manpages-3/vfs_crossrename.8.xml | 115 +++++++++++++++++++++++++++++ + 1 files changed, 115 insertions(+), 0 deletions(-) + create mode 100644 docs-xml/manpages-3/vfs_crossrename.8.xml + +diff --git a/docs-xml/manpages-3/vfs_crossrename.8.xml b/docs-xml/manpages-3/vfs_crossrename.8.xml +new file mode 100644 +index 0000000..675c92e +--- /dev/null ++++ b/docs-xml/manpages-3/vfs_crossrename.8.xml +@@ -0,0 +1,115 @@ ++<?xml version="1.0" encoding="iso-8859-1"?> ++<!DOCTYPE refentry PUBLIC "-//Samba-Team//DTD DocBook V4.2-Based Variant V1.0//EN" "http://www.samba.org/samba/DTD/samba-doc"> ++<refentry id="vfs_crossrename.8"> ++ ++<refmeta> ++ <refentrytitle>vfs_crossrename</refentrytitle> ++ <manvolnum>8</manvolnum> ++ <refmiscinfo class="source">Samba</refmiscinfo> ++ <refmiscinfo class="manual">System Administration tools</refmiscinfo> ++ <refmiscinfo class="version">3.6</refmiscinfo> ++</refmeta> ++ ++ ++<refnamediv> ++ <refname>vfs_crossrename</refname> ++ <refpurpose>server side rename files across filesystem boundaries</refpurpose> ++</refnamediv> ++ ++<refsynopsisdiv> ++ <cmdsynopsis> ++ <command>vfs objects = crossrename</command> ++ </cmdsynopsis> ++</refsynopsisdiv> ++ ++<refsect1> ++ <title>DESCRIPTION</title> ++ ++ <para>This VFS module is part of the ++ <citerefentry><refentrytitle>samba</refentrytitle> ++ <manvolnum>7</manvolnum></citerefentry> suite.</para> ++ ++ <para>The <command>vfs_crossrename</command> VFS module allows ++ server side rename operations even if source and target are on ++ differen physical devices. A "move" in Explorer is usually a ++ rename operation if it is inside of a single share or device. ++ Usually such a rename operation returns ++ NT_STATUS_NOT_SAME_DEVICE and the client has to move the file by ++ manual copy and delete operations. If the rename by copy is done by the ++ server this can be much more efficient. vfs_crossrename tries to do ++ this server-side cross-device rename operation. There are however ++ limitations that this module currently does not solve: ++ ++ <variablelist> ++ <varlistentry> ++ the ACLs of files are not preserved ++ </varlistentry> ++ <varlistentry> ++ meta data in EAs are not preserved ++ </varlistentry> ++ <varlistentry> ++ renames of whole subdirectories cannot be done recursively, ++ in that case we still return STATUS_NOT_SAME_DEVICE and ++ let the client decide what to do ++ </varlistentry> ++ <varlistentry> ++ rename operations of huge files can cause hangs on the ++ client because clients expect a rename operation to ++ return fast ++ </varlistentry> ++ </variablelist> ++ </para> ++ ++ <para>This module is stackable.</para> ++ ++</refsect1> ++ ++ ++<refsect1> ++ <title>OPTIONS</title> ++ ++ <variablelist> ++ ++ <varlistentry> ++ <term>crossrename:sizelimit = BYTES</term> ++ <listitem> ++ <para>server-side cross-device-renames are only done ++ for files if the filesize is not larger than the defined ++ size in MiB to prevent timeouts. The default sizelimit is ++ 20 (MiB) ++ </para> ++ </varlistentry> ++ </variablelist> ++</refsect1> ++ ++<refsect1> ++ <title>EXAMPLES</title> ++ ++ <para>To add server-side cross-device renames inside of a share ++ for all files sized up to 50MB:</para> ++ ++<programlisting> ++ <smbconfsection name="[testshare]"/> ++ <smbconfoption name="path">/data/mounts</smbconfoption> ++ <smbconfoption name="vfs objects">crossrename</smbconfoption> ++ <smbconfoption name="crossrename:sizelimit">50</smbconfoption> ++</programlisting> ++</refsect1> ++ ++<refsect1> ++ <title>VERSION</title> ++ <para>This man page is correct for version 3.6.0 of the Samba suite. ++ </para> ++</refsect1> ++ ++<refsect1> ++ <title>AUTHOR</title> ++ ++ <para>The original Samba software and related utilities ++ were created by Andrew Tridgell. Samba is now developed ++ by the Samba Team as an Open Source project similar ++ to the way the Linux kernel is developed.</para> ++ ++</refsect1> ++ ++</refentry> +-- +1.6.6.1 + +From 36f4541d92b7ae588743ce206514d27419d478df Mon Sep 17 00:00:00 2001 +From: Torsten Kurbad <samba-technical@tk-webart.de> +Date: Thu, 25 Mar 2010 17:58:27 +0100 +Subject: [PATCH] s3: Fix a missing </listitem> in vfs_crossrename.8.xml + +--- + docs-xml/manpages-3/vfs_crossrename.8.xml | 1 + + 1 files changed, 1 insertions(+), 0 deletions(-) + +diff --git a/docs-xml/manpages-3/vfs_crossrename.8.xml b/docs-xml/manpages-3/vfs_crossrename.8.xml +index 675c92e..f5a4444 100644 +--- a/docs-xml/manpages-3/vfs_crossrename.8.xml ++++ b/docs-xml/manpages-3/vfs_crossrename.8.xml +@@ -78,6 +78,7 @@ + size in MiB to prevent timeouts. The default sizelimit is + 20 (MiB) + </para> ++ </listitem> + </varlistentry> + </variablelist> + </refsect1> +-- +1.7.0.2 + +--- a/source3/configure 2010-04-06 13:05:13.000000000 +0000 ++++ b/source3/configure 2010-04-14 09:28:51.000000000 +0000 +@@ -13401,6 +13401,7 @@ + default_static_modules="pdb_smbpasswd pdb_tdbsam pdb_wbc_sam rpc_lsarpc rpc_samr rpc_winreg rpc_initshutdown rpc_dssetup rpc_wkssvc rpc_svcctl rpc_ntsvcs rpc_netlogon rpc_netdfs rpc_srvsvc rpc_spoolss rpc_eventlog auth_sam auth_unix auth_winbind auth_wbc auth_server auth_domain auth_builtin auth_netlogond vfs_default nss_info_template" + + default_shared_modules="vfs_recycle vfs_audit vfs_extd_audit vfs_full_audit vfs_netatalk vfs_fake_perms vfs_default_quota vfs_readonly vfs_cap vfs_expand_msdfs vfs_shadow_copy vfs_shadow_copy2 charset_CP850 charset_CP437 auth_script vfs_readahead vfs_xattr_tdb vfs_streams_xattr vfs_streams_depot vfs_acl_xattr vfs_acl_tdb vfs_smb_traffic_analyzer vfs_preopen vfs_catia vfs_scannedonly" ++default_shared_modules="$default_shared_modules vfs_crossrename" + + if test "x$developer" = xyes; then + default_static_modules="$default_static_modules rpc_rpcecho pdb_ads" +@@ -87389,6 +87371,43 @@ + { $as_echo "$as_me:$LINENO: result: not" >&5 + $as_echo "not" >&6; } + fi ++ ++ ++ { $as_echo "$as_me:$LINENO: checking how to build vfs_crossrename" >&5 ++$as_echo_n "checking how to build vfs_crossrename... " >&6; } ++ if test "$MODULE_vfs_crossrename"; then ++ DEST=$MODULE_vfs_crossrename ++ elif test "$MODULE_vfs" -a "$MODULE_DEFAULT_vfs_crossrename"; then ++ DEST=$MODULE_vfs ++ else ++ DEST=$MODULE_DEFAULT_vfs_crossrename ++ fi ++ ++ if test x"$DEST" = xSHARED; then ++ ++cat >>confdefs.h <<\_ACEOF ++#define vfs_crossrename_init init_samba_module ++_ACEOF ++ ++ VFS_MODULES="$VFS_MODULES "bin/crossrename.$SHLIBEXT"" ++ { $as_echo "$as_me:$LINENO: result: shared" >&5 ++$as_echo "shared" >&6; } ++ ++ string_shared_modules="$string_shared_modules vfs_crossrename" ++ elif test x"$DEST" = xSTATIC; then ++ init_static_modules_vfs="$init_static_modules_vfs vfs_crossrename_init();" ++ decl_static_modules_vfs="$decl_static_modules_vfs extern NTSTATUS vfs_crossrename_init(void);" ++ string_static_modules="$string_static_modules vfs_crossrename" ++ VFS_STATIC="$VFS_STATIC \$(VFS_CROSSRENAME_OBJ)" ++ ++ ++ { $as_echo "$as_me:$LINENO: result: static" >&5 ++$as_echo "static" >&6; } ++ else ++ string_ignored_modules="$string_ignored_modules vfs_crossrename" ++ { $as_echo "$as_me:$LINENO: result: not" >&5 ++$as_echo "not" >&6; } ++ fi + + + +From 0b0c5596034a007b71785a0f36aaf40cf74b234d Mon Sep 17 00:00:00 2001 +From: Volker Lendecke <vl@samba.org> +Date: Thu, 16 Jun 2011 22:20:49 +0200 +Subject: [PATCH] s3: Fix bug 8238 -- KB2536276 prevents access to shares + +Without this we were not sending the workgroup name in the negprot reply if +plain text passwords are used. +--- + source3/smbd/negprot.c | 1 + + 1 files changed, 1 insertions(+), 0 deletions(-) + +diff --git a/source3/smbd/negprot.c b/source3/smbd/negprot.c +index 81d29d9..51ad80d 100644 +--- a/source3/smbd/negprot.c ++++ b/source3/smbd/negprot.c +@@ -382,6 +382,7 @@ static void reply_nt1(struct smb_request *req, uint16 choice) + reply_nterror(req, NT_STATUS_NO_MEMORY); + return; + } ++ p += ret; + DEBUG(3,("not using SPNEGO\n")); + } else { + DATA_BLOB spnego_blob = negprot_spnego(); +-- +1.5.6.5 + |