Index: head/net/samba48/Makefile =================================================================== --- head/net/samba48/Makefile (revision 492473) +++ head/net/samba48/Makefile (revision 492474) @@ -1,622 +1,623 @@ # Created by: timur@FreeBSD.org # $FreeBSD$ PORTNAME= ${SAMBA4_BASENAME}48 PORTVERSION= ${SAMBA4_VERSION} PORTREVISION= 0 CATEGORIES?= net MASTER_SITES= SAMBA/samba/stable SAMBA/samba/rc DISTNAME= ${SAMBA4_DISTNAME} MAINTAINER= timur@FreeBSD.org COMMENT= Free SMB/CIFS and AD/DC server and client for Unix LICENSE= GPLv3 -BROKEN_powerpc64= fails to compile: auth.idl:107: Unable to determine origin of type struct cli_credentials IGNORE_NONTHREAD_PYTHON= needs port lang/python${PYTHON_SUFFIX} to be build with THREADS support CONFLICTS_INSTALL?= samba4-4.0.* samba4[1-79]-4.* p5-Parse-Pidl-4.* EXTRA_PATCHES+= ${PATCHDIR}/0001-Zfs-provision-1.patch:-p1 EXTRA_PATCHES+= ${PATCHDIR}/0001-Freenas-master-mdns-fixes-22.patch:-p1 EXTRA_PATCHES+= ${PATCHDIR}/0001-audit.patch:-p1 -EXTRA_PATCHES+= ${PATCHDIR}/0001-bug-13175.patch:-p1 EXTRA_PATCHES+= ${PATCHDIR}/0001-bug-228462.patch:-p1 SAMBA4_BASENAME= samba SAMBA4_PORTNAME= ${SAMBA4_BASENAME}4 -SAMBA4_VERSION= 4.8.7 +SAMBA4_VERSION= 4.8.9 SAMBA4_DISTNAME= ${SAMBA4_BASENAME}-${SAMBA4_VERSION:S|.p|pre|:S|.r|rc|:S|.t|tp|:S|.a|alpha|} WRKSRC?= ${WRKDIR}/${DISTNAME} .if !defined(SAMBA4_SUBPORT) CPE_VENDOR= samba CPE_PRODUCT= samba # Directories VARDIR= ${DESTDIR}/var SAMBA4_RUNDIR= ${VARDIR}/run/${SAMBA4_PORTNAME} SAMBA4_LOGDIR= ${VARDIR}/log/${SAMBA4_PORTNAME} SAMBA4_LOCKDIR= ${VARDIR}/db/${SAMBA4_PORTNAME} SAMBA4_BINDDNSDIR= ${SAMBA4_LOCKDIR}/bind-dns SAMBA4_PRIVATEDIR= ${SAMBA4_LOCKDIR}/private SAMBA4_PAMDIR= ${PREFIX}/lib SAMBA4_LIBDIR= ${PREFIX}/lib/${SAMBA4_PORTNAME} SAMBA4_MODULEDIR= ${PREFIX}/lib/shared-modules SAMBA4_INCLUDEDIR= ${PREFIX}/include/${SAMBA4_PORTNAME} SAMBA4_CONFDIR= ${PREFIX}/etc SAMBA4_CONFIG= smb4.conf CONFIGURE_ARGS+= --mandir="${MANPREFIX}/man" \ --sysconfdir="${SAMBA4_CONFDIR}" \ --includedir="${SAMBA4_INCLUDEDIR}" \ --datadir="${DATADIR}" \ --libdir="${SAMBA4_LIBDIR}" \ --with-privatelibdir="${SAMBA4_LIBDIR}/private" \ --with-pammodulesdir="${SAMBA4_PAMDIR}" \ --with-modulesdir="${SAMBA4_MODULEDIR}" \ --with-pkgconfigdir="${PKGCONFIGDIR}" \ --localstatedir="${VARDIR}" \ --with-piddir="${SAMBA4_RUNDIR}" \ --with-sockets-dir="${SAMBA4_RUNDIR}" \ --with-privileged-socket-dir="${SAMBA4_RUNDIR}" \ --with-lockdir="${SAMBA4_LOCKDIR}" \ --with-statedir="${SAMBA4_LOCKDIR}" \ --with-cachedir="${SAMBA4_LOCKDIR}" \ --with-bind-dns-dir=${SAMBA4_BINDDNSDIR} \ --with-privatedir="${SAMBA4_PRIVATEDIR}" \ --with-logfilebase="${SAMBA4_LOGDIR}" # XXX: Flags CONFIGURE_ENV+= PTHREAD_LDFLAGS="-lpthread" -CPPFLAGS+= -I${LOCALBASE}/include -LDFLAGS+= -L${LOCALBASE}/lib -USES= cpe compiler waf pkgconfig perl5 \ - iconv shebangfix +USES= compiler:c++11-lang cpe iconv \ + localbase:ldflags perl5 pkgconfig shebangfix waf USE_PERL5= build USE_LDCONFIG= ${SAMBA4_LIBDIR} WAF_CMD= buildtools/bin/waf CONFIGURE_LOG= bin/config.log PKGCONFIGDIR?= ${PREFIX}/libdata/pkgconfig PKGCONFIGDIR_REL?= ${PKGCONFIGDIR:S,^${PREFIX}/,,} PLIST_SUB+= PKGCONFIGDIR=${PKGCONFIGDIR_REL} SUB_LIST+= PKGCONFIGDIR=${PKGCONFIGDIR_REL} ############################################################################## # Options OPTIONS_SUB= yes OPTIONS_DEFINE= AD_DC ADS DEBUG DOCS FAM LDAP \ QUOTAS SYSLOG UTMP PROFILE # Make those default options OPTIONS_DEFAULT:= ${OPTIONS_DEFINE} GSSAPI_BUILTIN # This shouldn't be default in the release OPTIONS_DEFINE+= DEVELOPER MANDOC OPTIONS_DEFINE_amd64= AESNI OPTIONS_DEFAULT_amd64= AESNI -OPTIONS_DEFINE+= CLUSTER CUPS GPGME NTVFS SPOTLIGHT +OPTIONS_DEFINE+= CLUSTER CUPS GLUSTERFS GPGME NTVFS SPOTLIGHT #OPTIONS_DEFINE+= MEMORY_DEBUG OPTIONS_SINGLE= GSSAPI # GSSAPI_HEIMDAL OPTIONS_SINGLE_GSSAPI= GSSAPI_BUILTIN GSSAPI_MIT OPTIONS_RADIO= DNS ZEROCONF -OPTIONS_RADIO_DNS= NSUPDATE BIND911 +OPTIONS_RADIO_DNS= NSUPDATE BIND911 BIND912 OPTIONS_RADIO_ZEROCONF= MDNSRESPONDER AVAHI ############################################################################## AD_DC_DESC= Active Directory Domain Controller ADS_DESC= Active Directory client(implies LDAP) AESNI_DESC= Accelerated AES crypto functions(amd64 only) CLUSTER_DESC= Clustering DEVELOPER_DESC= With developer framework(implies NTVFS) FAM_DESC= File Alteration Monitor GPGME_DESC= GpgME GLUSTERFS_DESC= GlusterFS LDAP_DESC= LDAP client LIBZFS_DESC= LibZFS SPOTLIGHT_DESC= Spotlight MANDOC_DESC= Build manpages from DOCBOOK templates MEMORY_DEBUG_DESC= Debug memory allocation NTVFS_DESC= Build *DEPRECATED* NTVFS file server PICKY_DEVELOPER_DESC= Treat compiler warnings as errors(implies DEVELOPER) PROFILE_DESC= Profiling data QUOTAS_DESC= Disk quota UTMP_DESC= UTMP accounting GSSAPI_BUILTIN_DESC= GSSAPI support via bundled Heimdal BIND911_DESC= Use Bind 9.11 as AD DC DNS server frontend +BIND912_DESC= Use Bind 9.12 as AD DC DNS server frontend NSUPDATE_DESC= Use samba NSUPDATE utility for AD DC ############################################################################## # XXX: Unconditional dependencies which can't be switched off(if present in # the system) # Readline(sponsored by Python) # XXX: USES=readline pollutes CPPFLAGS, so we explicitly put dependency LIB_DEPENDS+= libreadline.so.7:devel/readline # popt LIB_DEPENDS+= libpopt.so:devel/popt # inotify LIB_DEPENDS+= libinotify.so:devel/libinotify # GNUTLS LIB_DEPENDS+= libgnutls.so:security/gnutls # NFS4 ACL glue LIB_DEPENDS+= libsunacl.so:sysutils/libsunacl # Jansson BUILD_DEPENDS+= jansson>=2.10:devel/jansson RUN_DEPENDS+= jansson>=2.10:devel/jansson # External Samba dependencies # Needed for IDL compiler BUILD_DEPENDS+= p5-Parse-Yapp>=0:devel/p5-Parse-Yapp # Libarchive SAMBA4_BUNDLED_LIBS+= !libarchive BUILD_DEPENDS+= libarchive>=3.1.2:archivers/libarchive RUN_DEPENDS+= libarchive>=3.1.2:archivers/libarchive ### Bundled libraries SAMBA4_BUNDLED_CMOCKA?= no SAMBA4_BUNDLED_TALLOC?= no SAMBA4_BUNDLED_TEVENT?= no SAMBA4_BUNDLED_TDB?= no SAMBA4_BUNDLED_LDB?= yes SAMBA4_LDB= 13 # cmocka .if defined(SAMBA4_BUNDLED_CMOCKA) && ${SAMBA4_BUNDLED_CMOCKA} == yes SAMBA4_BUNDLED_LIBS+= cmocka CONFLICTS+= cmocka-1.* PLIST_SUB+= SAMBA4_BUNDLED_CMOCKA="" SUB_LIST+= SAMBA4_BUNDLED_CMOCKA="" .else SAMBA4_BUNDLED_LIBS+= !cmocka BUILD_DEPENDS+= cmocka>=1.1.1:sysutils/cmocka RUN_DEPENDS+= cmocka>=1.1.1:sysutils/cmocka PLIST_SUB+= SAMBA4_BUNDLED_CMOCKA="@comment " SUB_LIST+= SAMBA4_BUNDLED_CMOCKA="@comment " .endif # talloc .if defined(SAMBA4_BUNDLED_TALLOC) && ${SAMBA4_BUNDLED_TALLOC} == yes SAMBA4_BUNDLED_LIBS+= talloc CONFLICTS+= talloc-2.* PLIST_SUB+= SAMBA4_BUNDLED_TALLOC="" SUB_LIST+= SAMBA4_BUNDLED_TALLOC="" .else SAMBA4_BUNDLED_LIBS+= !talloc BUILD_DEPENDS+= talloc>=2.1.14:devel/talloc RUN_DEPENDS+= talloc>=2.1.14:devel/talloc PLIST_SUB+= SAMBA4_BUNDLED_TALLOC="@comment " SUB_LIST+= SAMBA4_BUNDLED_TALLOC="@comment " .endif # tevent .if defined(SAMBA4_BUNDLED_TEVENT) && ${SAMBA4_BUNDLED_TEVENT} == yes SAMBA4_BUNDLED_LIBS+= tevent CONFLICTS+= tevent-0.* PLIST_SUB+= SAMBA4_BUNDLED_TEVENT="" SUB_LIST+= SAMBA4_BUNDLED_TEVENT="" .else SAMBA4_BUNDLED_LIBS+= !tevent BUILD_DEPENDS+= tevent>=0.9.37:devel/tevent RUN_DEPENDS+= tevent>=0.9.37:devel/tevent PLIST_SUB+= SAMBA4_BUNDLED_TEVENT="@comment " SUB_LIST+= SAMBA4_BUNDLED_TEVENT="@comment " .endif # tdb .if defined(SAMBA4_BUNDLED_TDB) && ${SAMBA4_BUNDLED_TDB} == yes SAMBA4_BUNDLED_LIBS+= tdb CONFLICTS+= tdb-1.* PLIST_SUB+= SAMBA4_BUNDLED_TDB="" SUB_LIST+= SAMBA4_BUNDLED_TDB="" .else SAMBA4_BUNDLED_LIBS+= !tdb BUILD_DEPENDS+= tdb>=1.3.15:databases/tdb RUN_DEPENDS+= tdb>=1.3.15:databases/tdb PLIST_SUB+= SAMBA4_BUNDLED_TDB="@comment " SUB_LIST+= SAMBA4_BUNDLED_TDB="@comment " .endif # ldb .if (defined(SAMBA4_BUNDLED_LDB) && ${SAMBA4_BUNDLED_LDB} == yes) || !defined(SAMBA4_LDB) SAMBA4_BUNDLED_LDB= yes SAMBA4_BUNDLED_LIBS+= ldb CONFLICTS+= ldb-1.* ldb1[23]-1.* PLIST_SUB+= SAMBA4_BUNDLED_LDB="" SUB_LIST+= SAMBA4_BUNDLED_LDB="" .else . if ${SAMBA4_LDB} == 13 BUILD_DEPENDS+= ldb13>=1.3.6:databases/ldb13 RUN_DEPENDS+= ldb13>=1.3.6:databases/ldb13 . elif ${SAMBA4_LDB} == 12 BUILD_DEPENDS+= ldb12>=1.2.3:databases/ldb12 RUN_DEPENDS+= ldb12>=1.2.3:databases/ldb12 . elif ${SAMBA4_LDB} == 11 BUILD_DEPENDS+= ldb>=1.1.29:databases/ldb RUN_DEPENDS+= ldb>=1.1.29:databases/ldb . endif SAMBA4_BUNDLED_LIBS+= !ldb PLIST_SUB+= SAMBA4_BUNDLED_LDB="@comment " SUB_LIST+= SAMBA4_BUNDLED_LDB="@comment " .endif .if (defined(SAMBA4_BUNDLED_TALLOC) && ${SAMBA4_BUNDLED_TEVENT} == yes) \ || (defined(SAMBA4_BUNDLED_TDB) && ${SAMBA4_BUNDLED_TDB} == yes) \ || (defined(SAMBA4_BUNDLED_TEVENT) && ${SAMBA4_BUNDLED_TEVENT} == yes) SAMBA4_BUNDLED_LIBS+= replace .endif # Don't use external libcom_err SAMBA4_BUNDLED_LIBS+= com_err # Set the test environment variables TEST_ENV+= PYTHON="${PYTHON_CMD}" \ SHA1SUM=/sbin/sha1 \ SHA256SUM=/sbin/sha256 \ MD5SUM=/sbin/md5 TEST_DEPENDS+= python:lang/python \ bash:shells/bash \ tshark:net/tshark ############################################################################## CONFIGURE_ARGS+= \ --with-pam \ --with-iconv \ --with-winbind \ --with-regedit \ --disable-rpath \ --without-lttng \ --without-gettext \ --enable-pthreadpool \ --without-fake-kaserver \ --without-systemd \ --enable-gnutls \ --with-libarchive \ --with-acl-support \ --with-sendfile-support \ --disable-ctdb-tests \ ${ICONV_CONFIGURE_BASE} ############################################################################## BIND911_RUN_DEPENDS= bind911>=9.11.0.0:dns/bind911 +BIND912_RUN_DEPENDS= bind911>=9.12.0.0:dns/bind912 NSUPDATE_RUN_DEPENDS= samba-nsupdate:dns/samba-nsupdate AVAHI_CONFIGURE_ENABLE= avahi AVAHI_LIB_DEPENDS= libavahi-client.so:net/avahi-app +AVAHI_VARS= SAMBA4_SERVICES+=avahi_daemon MDNSRESPONDER_CONFIGURE_ENABLE= dnssd MDNSRESPONDER_LIB_DEPENDS= libdns_sd.so:net/mDNSResponder +MDNSRESPONDER_VARS= SAMBA4_SERVICES+=mdnsd ############################################################################## DEBUG_CONFIGURE_ON= --verbose --enable-debug DEBUG_MAKE_ARGS= --verbose DEBUG_FLAGS= -g -ggdb3 -O0 MEMORY_DEBUG_IMPLIES= DEBUG MEMORY_DEBUG_CONFIGURE_ENV= ADDITIONAL_CFLAGS="-DENABLE_JEMALLOC `pkg-config --cflags jemalloc`" ADDITIONAL_LDFLAGS="`pkg-config --libs jemalloc`" MEMORY_DEBUG_LIB_DEPENDS= libjemalloc.so.2:devel/jemalloc # https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=194046 GDB_CMD?= ${LOCALBASE}/bin/gdb # https://bugzilla.samba.org/show_bug.cgi?id=8969 PICKY_DEVELOPER_IMPLIES= DEVELOPER PICKY_DEVELOPER_CONFIGURE_ON= --picky-developer DEVELOPER_IMPLIES= NTVFS DEVELOPER_CONFIGURE_ON= --enable-developer --enable-selftest --abi-check-disable DEVELOPER_BUILD_DEPENDS= ${GDB_CMD}:devel/gdb DEVELOPER_TEST_DEPENDS= ${GDB_CMD}:devel/gdb DEVELOPER_VARS_OFF= GDB_CMD=true # XXX: Mostly used in conjuction with the DEVELOPER option, don't enable it # if you don't know what you are doing NTVFS_CONFIGURE_WITH= ntvfs-fileserver NTVFS_PLIST_FILES= lib/shared-modules/service/smb.so \ lib/samba4/private/libntvfs-samba4.so ############################################################################## CLUSTER_CONFIGURE_WITH= cluster-support CUPS_CONFIGURE_ENABLE= cups iprint CUPS_LIB_DEPENDS= libcups.so:print/cups # https://bugzilla.samba.org/show_bug.cgi?id=9545 FAM_USES= fam FAM_CONFIGURE_WITH= fam GLUSTERFS_CONFIGURE_ENABLE= glusterfs GLUSTERFS_LIB_DEPENDS= libglusterfs.so:net/glusterfs GLUSTERFS_VARS= SAMBA4_MODULES+=vfs_glusterfs GPGME_CONFIGURE_WITH= gpgme GPGME_LIB_DEPENDS= libgpgme.so:security/gpgme PROFILE_CONFIGURE_WITH= profiling-data QUOTAS_CONFIGURE_WITH= quotas SPOTLIGHT_CONFIGURE_ENABLE= spotlight SPOTLIGHT_BUILD_DEPENDS= tracker>=1.4.1:sysutils/tracker SPOTLIGHT_RUN_DEPENDS= tracker>=1.4.1:sysutils/tracker SPOTLIGHT_USES= bison SPOTLIGHT_USE= gnome=glib20 SYSLOG_CONFIGURE_WITH= syslog UTMP_CONFIGURE_WITH= utmp AD_DC_CONFIGURE_OFF= --without-ad-dc ADS_IMPLIES= LDAP ADS_CONFIGURE_WITH= ads dnsupdate LDAP_CONFIGURE_WITH= ldap LDAP_CONFIGURE_ON= --with-openldap=${LOCALBASE} LDAP_USE= OPENLDAP=yes LDAP_VARS= SAMBA4_MODULES+=idmap_ldap GSSAPI_MIT_CONFIGURE_ON= --with-system-mitkrb5 ${GSSAPIBASEDIR} \ --with-system-mitkdc=${GSSAPIBASEDIR}/sbin/krb5kdc \ --with-experimental-mit-ad-dc GSSAPI_MIT_USES= gssapi:mit LIBZFS_CONFIGURE_WITH= libzfs LIBZFS_VARS= SAMBA4_MODULES+=vfs_zfs_space MANDOC_BUILD_DEPENDS= ${LOCALBASE}/share/xsl/docbook/manpages/docbook.xsl:textproc/docbook-xsl \ xsltproc:textproc/libxslt MANDOC_CONFIGURE_ENV_OFF= XSLTPROC="true" # !SAMBA4_SUBPORT .endif ############################################################################## .include ############################################################################## .if !defined(SAMBA4_SUBPORT) .if !defined(WANT_EXP_MODULES) || empty(WANT_EXP_MODULES) WANT_EXP_MODULES= vfs_cacheprime .endif .if ${WANT_EXP_MODULES:Mvfs_snapper} # snapper needs dbus LIB_DEPENDS+= libdbus-1.so:devel/dbus LIB_DEPENDS+= libdbus-glib-1.so:devel/dbus-glib .endif SAMBA4_MODULES+= vfs_freebsd SAMBA4_MODULES+= idmap_nss idmap_autorid idmap_rid idmap_hash idmap_tdb idmap_tdb2 idmap_script nss-info_hash # List of extra modules taken from RHEL build # https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=197320 .if ${PORT_OPTIONS:MADS} SAMBA4_MODULES+= idmap_ad idmap_rfc2307 nss-info_template nss-info_rfc2307 nss-info_sfu nss-info_sfu20 .endif .if ${PORT_OPTIONS:MDEVELOPER} SAMBA4_MODULES+= auth_skel pdb_test gpext_security gpext_registry gpext_scripts perfcount_test \ vfs_fake_dfq vfs_skel_opaque vfs_skel_transparent vfs_shadow_copy_test vfs_fake_acls \ vfs_nfs4acl_xattr vfs_error_inject vfs_delay_inject .endif .if defined(WANT_EXP_MODULES) && !empty(WANT_EXP_MODULES) SAMBA4_MODULES+= ${WANT_EXP_MODULES} .endif .if defined(SAMBA4_BUNDLED_LIBS) && !empty(SAMBA4_BUNDLED_LIBS) CONFIGURE_ARGS+= --bundled-libraries="${SAMBA4_BUNDLED_LIBS:Q:C|(\\\\ )+|,|g:S|\\||g}" .endif .if defined(SAMBA4_MODULES) && !empty(SAMBA4_MODULES) CONFIGURE_ARGS+= --with-shared-modules="${SAMBA4_MODULES:C|-|_|:Q:C|(\\\\ )+|,|g:S|\\||g}" .endif # XXX: Hack for nss-info_* -> nss_info/* modules # Add selected modules to the plist .for module in ${SAMBA4_MODULES} PLIST_FILES+= lib/shared-modules/${module:C|_|/|:C|-|_|}.so .endfor # Python bindings .if defined(NO_PYTHON) USES+= python:2.7,build,test CONFIGURE_ARGS+= --disable-python PLIST_SUB+= SAMBA4_PYTHON2="@comment " SAMBA4_PYTHON3="@comment " SUB_LIST+= SAMBA4_PYTHON2="@comment " SAMBA4_PYTHON3="@comment " .else USES+= python:2.7 PLIST_SUB+= SAMBA4_PYTHON2="" SUB_LIST+= SAMBA4_PYTHON2="" .if !defined(SAMBA4_BUNDLED_TALLOC) SAMBA4_BUNDLED_LIBS+= !pytalloc-util .endif .if !defined(SAMBA4_BUNDLED_TEVENT) SAMBA4_BUNDLED_LIBS+= !pytevent .endif .if !defined(SAMBA4_BUNDLED_TDB) SAMBA4_BUNDLED_LIBS+= !pytdb .endif .if !defined(SAMBA4_BUNDLED_LDB) SAMBA4_BUNDLED_LIBS+= !pyldb,!pyldb-util .endif # External Python modules BUILD_DEPENDS+= ${PYTHON_PKGNAMEPREFIX}dnspython>=1.15.0:dns/py-dnspython@${PY_FLAVOR} RUN_DEPENDS+= ${PYTHON_PKGNAMEPREFIX}dnspython>=1.15.0:dns/py-dnspython@${PY_FLAVOR} BUILD_DEPENDS+= ${PYTHON_PKGNAMEPREFIX}iso8601>=0.1.11:devel/py-iso8601@${PY_FLAVOR} RUN_DEPENDS+= ${PYTHON_PKGNAMEPREFIX}iso8601>=0.1.11:devel/py-iso8601@${PY_FLAVOR} # XXX: This is a gross hack to make port use both Python 2.7+ and 3.3+ # This is not officially supported, use at your own risk .if defined(WITH_SAMBA4_PYTHON3) && ${WITH_SAMBA4_PYTHON3:M3\.[0-9]} SAMBA4_PYTHON3_VERSION= ${WITH_SAMBA4_PYTHON3} SAMBA4_PYTHON3= python${SAMBA4_PYTHON3_VERSION} SAMBA4_PYTHON3_VER= ${SAMBA4_PYTHON3_VERSION:C/\.//} .if !exists(${PORTSDIR}/lang/python${SAMBA4_PYTHON3_VER}) .error unsupported or unknown Python version ${SAMBA4_PYTHON3_VERSION} .endif BUILD_DEPENDS+= ${SAMBA4_PYTHON3}:lang/python${SAMBA4_PYTHON3_VER} RUN_DEPENDS+= ${SAMBA4_PYTHON3}:lang/python${SAMBA4_PYTHON3_VER} # External Python modules BUILD_DEPENDS+= py${SAMBA4_PYTHON3_VER}-dnspython>=1.15.0:dns/py-dnspython@py${SAMBA4_PYTHON3_VER} RUN_DEPENDS+= py${SAMBA4_PYTHON3_VER}-dnspython>=1.15.0:dns/py-dnspython@py${SAMBA4_PYTHON3_VER} BUILD_DEPENDS+= py${SAMBA4_PYTHON3_VER}-iso8601>=0.1.11:devel/py-iso8601@py${SAMBA4_PYTHON3_VER} RUN_DEPENDS+= py${SAMBA4_PYTHON3_VER}-iso8601>=0.1.11:devel/py-iso8601@py${SAMBA4_PYTHON3_VER} # cpython-36m SAMBA4_PYTHON3_SO_ABI!= [ ! -f "${LOCALBASE}/bin/${SAMBA4_PYTHON3}" ] || ${LOCALBASE}/bin/${SAMBA4_PYTHON3} -c 'import sysconfig; print(sysconfig.get_config_var("SOABI") or "")' 2>/dev/null SAMBA4_PYTHON3_SITELIBDIR= lib/python${SAMBA4_PYTHON3_VERSION}/site-packages CONFIGURE_ENV+= PYTHON3_SO_ABI_FLAG=.${SAMBA4_PYTHON3_SO_ABI} CONFIGURE_ARGS+= --extra-python=${LOCALBASE}/bin/${SAMBA4_PYTHON3} PLIST_SUB+= SAMBA4_PYTHON3="" SAMBA4_PYTHON3_SITELIBDIR="${SAMBA4_PYTHON3_SITELIBDIR}" SUB_LIST+= SAMBA4_PYTHON3="" SAMBA4_PYTHON3_SITELIBDIR="${SAMBA4_PYTHON3_SITELIBDIR}" .else PLIST_SUB+= SAMBA4_PYTHON3="@comment " SUB_LIST+= SAMBA4_PYTHON3="@comment " .endif .endif # !SAMBA4_SUBPORT .endif ############################################################################## .include ############################################################################## .if !defined(SAMBA4_SUBPORT) # Require llvm 4.0 and AMD64 .if ${PORT_OPTIONS:MAESNI} && ${ARCH} == "amd64" CONFIGURE_ARGS+= --accel-aes=intelaesni PLIST_FILES+= lib/samba4/private/libaesni-intel-samba4.so .else CONFIGURE_ARGS+= --accel-aes=none .endif .if ${PORT_OPTIONS:MGSSAPI_MIT} PLIST_FILES+= lib/shared-modules/krb5/winbind_krb5_localauth.so \ man/man8/winbind_krb5_localauth.8.gz . if ${PORT_OPTIONS:MAD_DC} PLIST_FILES+= lib/samba4/krb5/plugins/kdb/samba.so . endif .endif # for libexecinfo: (so that __builtin_frame_address() finds the top of the stack) CFLAGS_amd64+= -fno-omit-frame-pointer # No fancy color error messages CONFIGURE_ENV+= NOCOLOR=yes WAF_LOG_FORMAT='%(c1)s%(zone)s%(c2)s %(message)s' MAKE_ENV+= NOCOLOR=yes WAF_LOG_FORMAT='%(c1)s%(zone)s%(c2)s %(message)s' .if ${CHOSEN_COMPILER_TYPE} == clang CFLAGS+= -fno-color-diagnostics .endif #.if ${readline_ARGS} == port #CFLAGS+= -D_FUNCTION_DEF #.endif # Make sure that the right version of Python is used by the tools # https://bugzilla.samba.org/show_bug.cgi?id=7305 SHEBANG_FILES= ${PATCH_WRKSRC}/source4/scripting/bin/* ${PATCH_WRKSRC}/selftest/* SAMBA4_SUB= SAMBA4_LOGDIR="${SAMBA4_LOGDIR}" \ SAMBA4_RUNDIR="${SAMBA4_RUNDIR}" \ SAMBA4_LOCKDIR="${SAMBA4_LOCKDIR}" \ SAMBA4_MODULEDIR="${SAMBA4_MODULEDIR}" \ SAMBA4_BINDDNSDIR="${SAMBA4_BINDDNSDIR}" \ SAMBA4_PRIVATEDIR="${SAMBA4_PRIVATEDIR}" \ SAMBA4_CONFDIR="${SAMBA4_CONFDIR}" \ - SAMBA4_CONFIG="${SAMBA4_CONFIG}" + SAMBA4_CONFIG="${SAMBA4_CONFIG}" \ + SAMBA4_SERVICES="${SAMBA4_SERVICES}" PLIST_SUB+= ${SAMBA4_SUB} SUB_LIST+= ${SAMBA4_SUB} USE_RC_SUBR= samba_server SUB_FILES= pkg-message README.FreeBSD PORTDOCS= README.FreeBSD post-extract: @${RM} -r ${WRKSRC}/pidl/lib/Parse/Yapp post-patch: @${REINPLACE_CMD} -e 's|$${PKGCONFIGDIR}|${PKGCONFIGDIR}|g' \ ${PATCH_WRKSRC}/buildtools/wafsamba/pkgconfig.py @${REINPLACE_CMD} -e 's|%%LOCALBASE%%|${LOCALBASE}|g' \ ${PATCH_WRKSRC}/buildtools/wafsamba/wafsamba.py @${REINPLACE_CMD} -e 's|%%GDB_CMD%%|${GDB_CMD}|g' \ ${PATCH_WRKSRC}/buildtools/scripts/abi_gen.sh @${REINPLACE_CMD} -e 's|%%SAMBA4_CONFIG%%|${SAMBA4_CONFIG}|g' \ ${PATCH_WRKSRC}/dynconfig/wscript @${REINPLACE_CMD} -e '1s|/bin/bash|/bin/sh|' \ ${PATCH_WRKSRC}/ctdb/tools/onnode # Use threading (or multiprocessing) but not thread (renamed in python 3+). pre-configure: .if ! ${PORT_OPTIONS:MAD_DC} && ${PORT_OPTIONS:MNTVFS} @${ECHO_CMD}; \ ${ECHO_MSG} "===> NTVFS option requires AD_DC to be set"; \ ${ECHO_CMD}; \ ${FALSE} .endif @if ! ${PYTHON_CMD} -c "import multiprocessing;" 2>/dev/null; then \ ${ECHO_CMD}; \ ${ECHO_MSG} "===> ${PKGNAME} "${IGNORE_NONTHREAD_PYTHON:Q}.; \ ${ECHO_CMD}; \ ${FALSE}; \ fi pre-build-MANDOC-off: ${MKDIR} ${BUILD_WRKSRC}/bin/default/docs-xml/ ${CP} -rp ${BUILD_WRKSRC}/docs/manpages ${BUILD_WRKSRC}/bin/default/docs-xml/ .for man in libcli/nbt/man/nmblookup4.1 \ librpc/tools/ndrdump.1 \ source4/lib/registry/man/regdiff.1 \ source4/lib/registry/man/regpatch.1 \ source4/lib/registry/man/regshell.1 \ source4/lib/registry/man/regtree.1 \ source4/scripting/man/samba_gpoupdate.8 \ source4/torture/man/gentest.1 \ source4/torture/man/locktest.1 \ source4/torture/man/masktest.1 \ source4/torture/man/smbtorture.1 \ source4/utils/man/ntlm_auth4.1 \ source4/utils/man/oLschema2ldif.1 \ lib/tdb/man/tdbdump.8 \ lib/tdb/man/tdbbackup.8 \ lib/tdb/man/tdbtool.8 \ lib/talloc/man/talloc.3 \ lib/tdb/man/tdbrestore.8 \ lib/ldb/man/ldb.3 \ lib/ldb/man/ldbadd.1 \ lib/ldb/man/ldbsearch.1 \ lib/ldb/man/ldbmodify.1 \ lib/ldb/man/ldbrename.1 \ lib/ldb/man/ldbdel.1 \ lib/ldb/man/ldbedit.1 ${MKDIR} `dirname ${BUILD_WRKSRC}/bin/default/${man}` ${INSTALL_MAN} ${FILESDIR}/man/`basename ${man}` ${BUILD_WRKSRC}/bin/default/${man} .endfor .if ${PORT_OPTIONS:MCLUSTER} ${MKDIR} ${BUILD_WRKSRC}/bin/default/ctdb/ . for man in ctdb_diagnostics.1 ctdb.1 ctdbd_wrapper.1 ctdbd.1 \ ltdbtool.1 onnode.1 ping_pong.1 ctdbd.conf.5 \ ctdb.7 ctdb-statistics.7 ctdb-tunables.7 ${INSTALL_MAN} ${FILESDIR}/man/${man} ${BUILD_WRKSRC}/bin/default/ctdb/ . endfor .endif post-install-rm-junk: .for f in vfs_aio_linux.8 vfs_btrfs.8 vfs_ceph.8 vfs_gpfs.8 ${RM} ${STAGEDIR}${PREFIX}/man/man8/${f} .endfor .if defined(NO_PYTHON) ${RM} -r ${STAGEDIR}${PYTHON_SITELIBDIR}/samba/third_party/dns \ ${STAGEDIR}${PYTHON_SITELIBDIR}/samba/third_party/iso8601 .endif post-install: post-install-rm-junk ${LN} -sf smb.conf.5.gz ${STAGEDIR}${PREFIX}/man/man5/smb4.conf.5.gz # Run post-install script .for dir in ${SAMBA4_LOGDIR} ${SAMBA4_RUNDIR} ${SAMBA4_LOCKDIR} ${SAMBA4_MODULEDIR} ${INSTALL} -d -m 0755 "${STAGEDIR}${dir}" .endfor ${INSTALL} -d -m 0750 "${STAGEDIR}${SAMBA4_BINDDNSDIR}" ${INSTALL} -d -m 0750 "${STAGEDIR}${SAMBA4_PRIVATEDIR}" .for dir in auth bind9 gensec gpext idmap ldb nss_info pdb perfcount process_model service vfs ${INSTALL} -d -m 0755 "${STAGEDIR}${SAMBA4_MODULEDIR}/${dir}" .endfor post-install-DOCS-on: ${MKDIR} ${STAGEDIR}${DOCSDIR} .for doc in ${PORTDOCS} ${INSTALL_DATA} ${WRKDIR}/${doc} ${STAGEDIR}${DOCSDIR} .endfor # !SAMBA4_SUBPORT .endif .include Index: head/net/samba48/distinfo =================================================================== --- head/net/samba48/distinfo (revision 492473) +++ head/net/samba48/distinfo (revision 492474) @@ -1,3 +1,3 @@ -TIMESTAMP = 1543311377 -SHA256 (samba-4.8.7.tar.gz) = 0f6f67932e8bb23ab83b43070037ac452f9fc5f20763857d2b67e209ee7cd362 -SIZE (samba-4.8.7.tar.gz) = 17724232 +TIMESTAMP = 1549652430 +SHA256 (samba-4.8.9.tar.gz) = ad2acf6bed436c125314a054f0589308eb664ac3d96cfb02d05e654a44e09c80 +SIZE (samba-4.8.9.tar.gz) = 17750151 Index: head/net/samba48/files/0001-bug-13175.patch =================================================================== --- head/net/samba48/files/0001-bug-13175.patch (revision 492473) +++ head/net/samba48/files/0001-bug-13175.patch (nonexistent) @@ -1,143 +0,0 @@ -From 60bdced298831b2750ce785e01891e4aeb79f0dc Mon Sep 17 00:00:00 2001 -From: Ralph Boehme -Date: Fri, 18 May 2018 13:14:57 +0200 -Subject: [PATCH 1/2] s3:smbd: make psbuf arg to make_default_acl_posix() const - -Bug: https://bugzilla.samba.org/show_bug.cgi?id=13175 - -Signed-off-by: Ralph Boehme ---- - source3/smbd/posix_acls.c | 8 ++++---- - source3/smbd/proto.h | 2 +- - 2 files changed, 5 insertions(+), 5 deletions(-) - -diff --git a/source3/smbd/posix_acls.c b/source3/smbd/posix_acls.c -index 8d42535d877..6396f818176 100644 ---- a/source3/smbd/posix_acls.c -+++ b/source3/smbd/posix_acls.c -@@ -4779,7 +4779,7 @@ int posix_sys_acl_blob_get_fd(vfs_handle_struct *handle, - - static NTSTATUS make_default_acl_posix(TALLOC_CTX *ctx, - const char *name, -- SMB_STRUCT_STAT *psbuf, -+ const SMB_STRUCT_STAT *psbuf, - struct security_descriptor **ppdesc) - { - struct dom_sid owner_sid, group_sid; -@@ -4886,7 +4886,7 @@ static NTSTATUS make_default_acl_posix(TALLOC_CTX *ctx, - - static NTSTATUS make_default_acl_windows(TALLOC_CTX *ctx, - const char *name, -- SMB_STRUCT_STAT *psbuf, -+ const SMB_STRUCT_STAT *psbuf, - struct security_descriptor **ppdesc) - { - struct dom_sid owner_sid, group_sid; -@@ -4958,7 +4958,7 @@ static NTSTATUS make_default_acl_windows(TALLOC_CTX *ctx, - - static NTSTATUS make_default_acl_everyone(TALLOC_CTX *ctx, - const char *name, -- SMB_STRUCT_STAT *psbuf, -+ const SMB_STRUCT_STAT *psbuf, - struct security_descriptor **ppdesc) - { - struct dom_sid owner_sid, group_sid; -@@ -5022,7 +5022,7 @@ NTSTATUS make_default_filesystem_acl( - TALLOC_CTX *ctx, - enum default_acl_style acl_style, - const char *name, -- SMB_STRUCT_STAT *psbuf, -+ const SMB_STRUCT_STAT *psbuf, - struct security_descriptor **ppdesc) - { - NTSTATUS status; -diff --git a/source3/smbd/proto.h b/source3/smbd/proto.h -index bee7acadeea..262338d81e4 100644 ---- a/source3/smbd/proto.h -+++ b/source3/smbd/proto.h -@@ -819,7 +819,7 @@ NTSTATUS make_default_filesystem_acl( - TALLOC_CTX *ctx, - enum default_acl_style acl_style, - const char *name, -- SMB_STRUCT_STAT *psbuf, -+ const SMB_STRUCT_STAT *psbuf, - struct security_descriptor **ppdesc); - - /* The following definitions come from smbd/process.c */ --- -2.13.6 - - -From 0918370e20156e4a21a0c244b963b672ed6b46b1 Mon Sep 17 00:00:00 2001 -From: Ralph Boehme -Date: Tue, 5 Dec 2017 08:28:28 +0100 -Subject: [PATCH 2/2] vfs_zfsacl: return synthesized ACL when ZFS return - ENOTSUP - -This allows accessing the ZFS .snapshots directory where ZFS returns -ENOTSUP when calling acl(".snapshots"). - -Bug: https://bugzilla.samba.org/show_bug.cgi?id=13175 - -Signed-off-by: Ralph Boehme ---- - source3/modules/vfs_zfsacl.c | 36 ++++++++++++++++++++++++++++++++++-- - 1 file changed, 34 insertions(+), 2 deletions(-) - -diff --git a/source3/modules/vfs_zfsacl.c b/source3/modules/vfs_zfsacl.c -index 0bc4ba6604f..43e41f95c1a 100644 ---- a/source3/modules/vfs_zfsacl.c -+++ b/source3/modules/vfs_zfsacl.c -@@ -238,7 +238,20 @@ static NTSTATUS zfsacl_fget_nt_acl(struct vfs_handle_struct *handle, - fsp->fsp_name, &pacl); - if (!NT_STATUS_IS_OK(status)) { - TALLOC_FREE(frame); -- return status; -+ if (!NT_STATUS_EQUAL(status, NT_STATUS_NOT_SUPPORTED)) { -+ return status; -+ } -+ -+ status = make_default_filesystem_acl(mem_ctx, -+ DEFAULT_ACL_POSIX, -+ fsp->fsp_name->base_name, -+ &fsp->fsp_name->st, -+ ppdesc); -+ if (!NT_STATUS_IS_OK(status)) { -+ return status; -+ } -+ (*ppdesc)->type |= SEC_DESC_DACL_PROTECTED; -+ return NT_STATUS_OK; - } - - status = smb_fget_nt_acl_nfs4(fsp, NULL, security_info, mem_ctx, -@@ -260,7 +273,26 @@ static NTSTATUS zfsacl_get_nt_acl(struct vfs_handle_struct *handle, - status = zfs_get_nt_acl_common(handle->conn, frame, smb_fname, &pacl); - if (!NT_STATUS_IS_OK(status)) { - TALLOC_FREE(frame); -- return status; -+ if (!NT_STATUS_EQUAL(status, NT_STATUS_NOT_SUPPORTED)) { -+ return status; -+ } -+ -+ if (!VALID_STAT(smb_fname->st)) { -+ DBG_ERR("No stat info for [%s]\n", -+ smb_fname_str_dbg(smb_fname)); -+ return NT_STATUS_INTERNAL_ERROR; -+ } -+ -+ status = make_default_filesystem_acl(mem_ctx, -+ DEFAULT_ACL_POSIX, -+ smb_fname->base_name, -+ &smb_fname->st, -+ ppdesc); -+ if (!NT_STATUS_IS_OK(status)) { -+ return status; -+ } -+ (*ppdesc)->type |= SEC_DESC_DACL_PROTECTED; -+ return NT_STATUS_OK; - } - - status = smb_get_nt_acl_nfs4(handle->conn, --- -2.13.6 - Property changes on: head/net/samba48/files/0001-bug-13175.patch ___________________________________________________________________ Deleted: fbsd:nokeywords ## -1 +0,0 ## -yes \ No newline at end of property Deleted: svn:eol-style ## -1 +0,0 ## -native \ No newline at end of property Deleted: svn:mime-type ## -1 +0,0 ## -text/plain \ No newline at end of property Index: head/net/samba48/files/patch-source3__modules__vfs_streams_xattr.c =================================================================== --- head/net/samba48/files/patch-source3__modules__vfs_streams_xattr.c (revision 492473) +++ head/net/samba48/files/patch-source3__modules__vfs_streams_xattr.c (nonexistent) @@ -1,505 +0,0 @@ ---- source3/modules/vfs_streams_xattr.c.orig 2018-08-11 23:00:01 UTC -+++ source3/modules/vfs_streams_xattr.c -@@ -1,10 +1,10 @@ - /* - * Store streams in xattrs - * -- * Copyright (C) Volker Lendecke, 2008 -+ * Copyright (C) Volker Lendecke, 2008 -+ * Copyright (C) Timur I. Bakeyev, 2017 - * - * Partly based on James Peach's Darwin module, which is -- * - * Copyright (C) James Peach 2006-2007 - * - * This program is free software; you can redistribute it and/or modify -@@ -79,25 +79,79 @@ static SMB_INO_T stream_inode(const SMB_ - } - - static ssize_t get_xattr_size(connection_struct *conn, -- const struct smb_filename *smb_fname, -- const char *xattr_name) -+ const struct smb_filename *smb_fname, -+ const char *xattr_name) - { -- NTSTATUS status; -- struct ea_struct ea; - ssize_t result; - -- status = get_ea_value(talloc_tos(), conn, NULL, smb_fname, -- xattr_name, &ea); -+ result = SMB_VFS_GETXATTR(conn, smb_fname, xattr_name, NULL, 0); -+ // ? -1 -+ return result; -+} - -- if (!NT_STATUS_IS_OK(status)) { -- return -1; -+static NTSTATUS get_xattr_value(TALLOC_CTX *mem_ctx, -+ connection_struct *conn, -+ const struct smb_filename *smb_fname, -+ const char *ea_name, -+ struct ea_struct *pea) -+{ -+ ssize_t attr_size; -+ -+ attr_size = get_xattr_size(conn, smb_fname, ea_name); -+ -+ if (attr_size == -1) { -+ return map_nt_error_from_unix(errno); - } - -- result = ea.value.length-1; -- TALLOC_FREE(ea.value.data); -- return result; -+ pea->value = data_blob_talloc(mem_ctx, NULL, attr_size); -+ /* We may have xattr of a 0 size */ -+ if(pea->value.data == NULL && attr_size) { -+ DEBUG(5, -+ ("get_xattr_value: for EA '%s' failed to allocate %lu bytes\n", -+ ea_name, (unsigned long)attr_size) -+ ); -+ return NT_STATUS_NO_MEMORY; -+ } -+ -+ attr_size = SMB_VFS_GETXATTR(conn, smb_fname, ea_name, pea->value.data, pea->value.length); -+ -+ if (attr_size == -1) { -+ return map_nt_error_from_unix(errno); -+ } -+ -+ if(pea->value.length != attr_size) { -+ DEBUG(5, -+ ("get_xattr_value: for EA '%s' requested %lu, read %lu bytes\n", -+ ea_name, (unsigned long)pea->value.length, (unsigned long)attr_size) -+ ); -+ return NT_STATUS_UNSUCCESSFUL; -+ } -+ -+ DEBUG(10,("get_xattr_value: EA '%s' is of length %lu\n", ea_name, (unsigned long)attr_size)); -+ /* -+ * This can dump huge amount of data multiple times. For example -+ * for 1Mb ADS and chunk size 64Kb the same 1Mb dump will be -+ * logged 16 times! -+ */ -+ dump_data(50, (uint8_t *)pea->value.data, pea->value.length); -+ -+ pea->flags = 0; -+ // ? user. -+ if (strnequal(ea_name, "user.", 5)) { -+ pea->name = talloc_strdup(mem_ctx, &ea_name[5]); -+ } else { -+ pea->name = talloc_strdup(mem_ctx, ea_name); -+ } -+ -+ if (pea->name == NULL) { -+ data_blob_free(&pea->value); -+ return NT_STATUS_NO_MEMORY; -+ } -+ -+ return NT_STATUS_OK; - } - -+ - /** - * Given a stream name, populate xattr_name with the xattr name to use for - * accessing the stream. -@@ -114,6 +168,7 @@ static NTSTATUS streams_xattr_get_name(v - SMB_VFS_HANDLE_GET_DATA(handle, config, struct streams_xattr_config, - return NT_STATUS_UNSUCCESSFUL); - -+ // stream_name is passed as ':stream', so skip leading ':' - sname = talloc_strdup(ctx, stream_name + 1); - if (sname == NULL) { - return NT_STATUS_NO_MEMORY; -@@ -125,7 +180,7 @@ static NTSTATUS streams_xattr_get_name(v - * characters from their on-the-wire Unicode Private Range - * encoding to their native ASCII representation. - * -- * As as result the name of xattrs storing the streams (via -+ * As a result the name of xattrs storing the streams (via - * vfs_streams_xattr) may contain a colon, so we have to use - * strrchr_m() instead of strchr_m() for matching the stream - * type suffix. -@@ -157,7 +212,7 @@ static NTSTATUS streams_xattr_get_name(v - return NT_STATUS_NO_MEMORY; - } - -- DEBUG(10, ("xattr_name: %s, stream_name: %s\n", *xattr_name, -+ DEBUG(10, ("xattr_name: '%s', stream_name: '%s'\n", *xattr_name, - stream_name)); - - talloc_free(sname); -@@ -265,8 +320,8 @@ static int streams_xattr_fstat(vfs_handl - return -1; - } - -- sbuf->st_ex_size = get_xattr_size(handle->conn, -- smb_fname_base, io->xattr_name); -+ sbuf->st_ex_size = get_xattr_size(handle->conn, smb_fname_base, -+ io->xattr_name); - if (sbuf->st_ex_size == -1) { - TALLOC_FREE(smb_fname_base); - SET_STAT_INVALID(*sbuf); -@@ -453,10 +508,10 @@ static int streams_xattr_open(vfs_handle - pipe_fds[1] = -1; - fakefd = pipe_fds[0]; - -- status = get_ea_value(talloc_tos(), handle->conn, NULL, -- smb_fname, xattr_name, &ea); -+ status = get_xattr_value(talloc_tos(), handle->conn, -+ smb_fname, xattr_name, &ea); - -- DEBUG(10, ("get_ea_value returned %s\n", nt_errstr(status))); -+ DEBUG(10, ("get_xattr_value returned %s\n", nt_errstr(status))); - - if (!NT_STATUS_IS_OK(status) - && !NT_STATUS_EQUAL(status, NT_STATUS_NOT_FOUND)) { -@@ -625,8 +680,8 @@ static int streams_xattr_rename(vfs_hand - } - - /* read the old stream */ -- status = get_ea_value(talloc_tos(), handle->conn, NULL, -- smb_fname_src, src_xattr_name, &ea); -+ status = get_xattr_value(talloc_tos(), handle->conn, -+ smb_fname_src, src_xattr_name, &ea); - if (!NT_STATUS_IS_OK(status)) { - errno = ENOENT; - goto fail; -@@ -713,14 +768,13 @@ static NTSTATUS walk_xattr_streams(vfs_h - continue; - } - -- status = get_ea_value(names, -+ status = get_xattr_value(names, - handle->conn, -- NULL, - smb_fname, - names[i], - &ea); - if (!NT_STATUS_IS_OK(status)) { -- DEBUG(10, ("Could not get ea %s for file %s: %s\n", -+ DEBUG(10, ("Could not get EA %s for file %s: %s\n", - names[i], - smb_fname->base_name, - nt_errstr(status))); -@@ -782,16 +836,17 @@ struct streaminfo_state { - NTSTATUS status; - }; - --static bool collect_one_stream(struct ea_struct *ea, void *private_data) -+static bool collect_one_stream(struct ea_struct *pea, void *private_data) - { - struct streaminfo_state *state = - (struct streaminfo_state *)private_data; - -+ // ? -1 - if (!add_one_stream(state->mem_ctx, - &state->num_streams, &state->streams, -- ea->name, ea->value.length-1, -+ pea->name, pea->value.length, - smb_roundup(state->handle->conn, -- ea->value.length-1))) { -+ pea->value.length))) { - state->status = NT_STATUS_NO_MEMORY; - return false; - } -@@ -911,14 +966,17 @@ static ssize_t streams_xattr_pwrite(vfs_ - files_struct *fsp, const void *data, - size_t n, off_t offset) - { -- struct stream_io *sio = -+ struct stream_io *sio = - (struct stream_io *)VFS_FETCH_FSP_EXTENSION(handle, fsp); -+ struct smb_filename *smb_fname_base = NULL; -+ TALLOC_CTX *frame = NULL; -+ - struct ea_struct ea; - NTSTATUS status; -- struct smb_filename *smb_fname_base = NULL; - int ret; - -- DEBUG(10, ("streams_xattr_pwrite called for %d bytes\n", (int)n)); -+ DEBUG(10, ("streams_xattr_pwrite: offset=%lu, size=%lu\n", -+ (unsigned long)offset, (unsigned long)n)); - - if (sio == NULL) { - return SMB_VFS_NEXT_PWRITE(handle, fsp, data, n, offset); -@@ -928,6 +986,8 @@ static ssize_t streams_xattr_pwrite(vfs_ - return -1; - } - -+ frame = talloc_stackframe(); -+ - /* Create an smb_filename with stream_name == NULL. */ - smb_fname_base = synthetic_smb_fname(talloc_tos(), - sio->base, -@@ -935,39 +995,55 @@ static ssize_t streams_xattr_pwrite(vfs_ - NULL, - fsp->fsp_name->flags); - if (smb_fname_base == NULL) { -+ TALLOC_FREE(frame); - errno = ENOMEM; - return -1; - } - -- status = get_ea_value(talloc_tos(), handle->conn, NULL, -- smb_fname_base, sio->xattr_name, &ea); -- if (!NT_STATUS_IS_OK(status)) { -- return -1; -- } -- -- if ((offset + n) > ea.value.length-1) { -- uint8_t *tmp; -+ status = get_xattr_value(talloc_tos(), handle->conn, -+ smb_fname_base, sio->xattr_name, &ea); - -- tmp = talloc_realloc(talloc_tos(), ea.value.data, uint8_t, -- offset + n + 1); -+ if (NT_STATUS_EQUAL(status, NT_STATUS_NOT_FOUND)) { -+ /* -+ * This can happen if we sit behind vfs_fruit: -+ * fruit_ftruncate calls UNLINK on an attribute -+ * truncating the "file" to zero length. A later -+ * pwrite faces a non-existing attribute, we need to -+ * cope with that here. -+ * -+ * This might be not the last word on this. -+ */ - -- if (tmp == NULL) { -- TALLOC_FREE(ea.value.data); -- errno = ENOMEM; -- return -1; -- } -- ea.value.data = tmp; -- ea.value.length = offset + n + 1; -- ea.value.data[offset+n] = 0; -- } -+ ea = (struct ea_struct) {0}; -+ ea.name = talloc_strdup(talloc_tos(), sio->xattr_name); -+ if (ea.name == NULL) { -+ TALLOC_FREE(frame); -+ errno = ENOMEM; -+ return -1; -+ } -+ status = NT_STATUS_OK; -+ } - -- memcpy(ea.value.data + offset, data, n); -+ if (!NT_STATUS_IS_OK(status)) { -+ TALLOC_FREE(frame); -+ return -1; -+ } -+ // ? -1 -+ if ((offset + n) > ea.value.length) { -+ if(!data_blob_realloc(talloc_tos(), &ea.value, offset + n)) { -+ TALLOC_FREE(frame); -+ errno = ENOMEM; -+ return -1; -+ } -+ } -+ memcpy(ea.value.data + offset, data, n); - - ret = SMB_VFS_SETXATTR(fsp->conn, - fsp->fsp_name, - sio->xattr_name, - ea.value.data, ea.value.length, 0); -- TALLOC_FREE(ea.value.data); -+ -+ TALLOC_FREE(frame); - - if (ret == -1) { - return -1; -@@ -980,15 +1056,17 @@ static ssize_t streams_xattr_pread(vfs_h - files_struct *fsp, void *data, - size_t n, off_t offset) - { -- struct stream_io *sio = -+ struct stream_io *sio = - (struct stream_io *)VFS_FETCH_FSP_EXTENSION(handle, fsp); -+ struct smb_filename *smb_fname_base = NULL; -+ TALLOC_CTX *frame = NULL; -+ - struct ea_struct ea; - NTSTATUS status; -- size_t length, overlap; -- struct smb_filename *smb_fname_base = NULL; -+ size_t overlap; - -- DEBUG(10, ("streams_xattr_pread: offset=%d, size=%d\n", -- (int)offset, (int)n)); -+ DEBUG(10, ("streams_xattr_pread: offset=%lu, size=%lu\n", -+ (unsigned long)offset, (unsigned long)n)); - - if (sio == NULL) { - return SMB_VFS_NEXT_PREAD(handle, fsp, data, n, offset); -@@ -998,6 +1076,8 @@ static ssize_t streams_xattr_pread(vfs_h - return -1; - } - -+ frame = talloc_stackframe(); -+ - /* Create an smb_filename with stream_name == NULL. */ - smb_fname_base = synthetic_smb_fname(talloc_tos(), - sio->base, -@@ -1005,31 +1085,35 @@ static ssize_t streams_xattr_pread(vfs_h - NULL, - fsp->fsp_name->flags); - if (smb_fname_base == NULL) { -+ TALLOC_FREE(frame); - errno = ENOMEM; - return -1; - } - -- status = get_ea_value(talloc_tos(), handle->conn, NULL, -- smb_fname_base, sio->xattr_name, &ea); -+ status = get_xattr_value(talloc_tos(), handle->conn, -+ smb_fname_base, sio->xattr_name, &ea); - if (!NT_STATUS_IS_OK(status)) { -+ TALLOC_FREE(frame); - return -1; - } -+ // ? -1 -+ //length = ea.value.length-1; - -- length = ea.value.length-1; -+ DEBUG(10, ("streams_xattr_pread: get_xattr_value() returned %lu bytes\n", -+ (unsigned long)ea.value.length)); - -- DEBUG(10, ("streams_xattr_pread: get_ea_value returned %d bytes\n", -- (int)length)); -+ /* Attempt to read past EOF. */ -+ if (ea.value.length <= offset) { -+ TALLOC_FREE(frame); -+ return 0; -+ } - -- /* Attempt to read past EOF. */ -- if (length <= offset) { -- return 0; -- } -+ overlap = (offset + n) > ea.value.length ? (ea.value.length - offset) : n; -+ memcpy(data, ea.value.data + offset, overlap); - -- overlap = (offset + n) > length ? (length - offset) : n; -- memcpy(data, ea.value.data + offset, overlap); -+ TALLOC_FREE(frame); - -- TALLOC_FREE(ea.value.data); -- return overlap; -+ return overlap; - } - - struct streams_xattr_pread_state { -@@ -1196,16 +1280,18 @@ static int streams_xattr_ftruncate(struc - struct files_struct *fsp, - off_t offset) - { -- int ret; -- uint8_t *tmp; -- struct ea_struct ea; -- NTSTATUS status; -- struct stream_io *sio = -+ struct stream_io *sio = - (struct stream_io *)VFS_FETCH_FSP_EXTENSION(handle, fsp); - struct smb_filename *smb_fname_base = NULL; -+ TALLOC_CTX *frame = NULL; - -- DEBUG(10, ("streams_xattr_ftruncate called for file %s offset %.0f\n", -- fsp_str_dbg(fsp), (double)offset)); -+ struct ea_struct ea; -+ NTSTATUS status; -+ size_t orig_length; -+ int ret; -+ -+ DEBUG(10, ("streams_xattr_ftruncate: called for file '%s' with offset %lu\n", -+ fsp_str_dbg(fsp), (unsigned long)offset)); - - if (sio == NULL) { - return SMB_VFS_NEXT_FTRUNCATE(handle, fsp, offset); -@@ -1215,6 +1301,8 @@ static int streams_xattr_ftruncate(struc - return -1; - } - -+ frame = talloc_stackframe(); -+ - /* Create an smb_filename with stream_name == NULL. */ - smb_fname_base = synthetic_smb_fname(talloc_tos(), - sio->base, -@@ -1222,40 +1310,46 @@ static int streams_xattr_ftruncate(struc - NULL, - fsp->fsp_name->flags); - if (smb_fname_base == NULL) { -+ TALLOC_FREE(frame); - errno = ENOMEM; - return -1; - } - -- status = get_ea_value(talloc_tos(), handle->conn, NULL, -- smb_fname_base, sio->xattr_name, &ea); -+ status = get_xattr_value(talloc_tos(), handle->conn, -+ smb_fname_base, sio->xattr_name, &ea); - if (!NT_STATUS_IS_OK(status)) { -+ TALLOC_FREE(frame); - return -1; - } -+ orig_length = ea.value.length; - -- tmp = talloc_realloc(talloc_tos(), ea.value.data, uint8_t, -- offset + 1); -+ /* Requested size matches the original size */ -+ if(orig_length == offset) { -+ TALLOC_FREE(frame); -+ return 0; -+ } - -- if (tmp == NULL) { -- TALLOC_FREE(ea.value.data); -+ /* That can both shrink and expand */ -+ /* XXX: If offset == 0 the result of talloc_realloc is NULL, but still valid */ -+ if(offset && !data_blob_realloc(talloc_tos(), &ea.value, offset)) { -+ TALLOC_FREE(frame); - errno = ENOMEM; - return -1; - } - -- /* Did we expand ? */ -- if (ea.value.length < offset + 1) { -- memset(&tmp[ea.value.length], '\0', -- offset + 1 - ea.value.length); -+ /* If we expanded, fill up extra space with zeros */ -+ if (orig_length < offset) { -+ memset(ea.value.data + orig_length, 0, -+ offset - orig_length); - } - -- ea.value.data = tmp; -- ea.value.length = offset + 1; -- ea.value.data[offset] = 0; -- -+ /* XXX: We should use ea.value.length here, but when offset == 0 -+ it's not reset to 0 in data_blob_realloc() */ - ret = SMB_VFS_SETXATTR(fsp->conn, - fsp->fsp_name, - sio->xattr_name, -- ea.value.data, ea.value.length, 0); -- TALLOC_FREE(ea.value.data); -+ ea.value.data, offset, 0); -+ TALLOC_FREE(frame); - - if (ret == -1) { - return -1; -@@ -1273,9 +1367,9 @@ static int streams_xattr_fallocate(struc - struct stream_io *sio = - (struct stream_io *)VFS_FETCH_FSP_EXTENSION(handle, fsp); - -- DEBUG(10, ("streams_xattr_fallocate called for file %s offset %.0f" -- "len = %.0f\n", -- fsp_str_dbg(fsp), (double)offset, (double)len)); -+ DEBUG(10, ("streams_xattr_fallocate: called for file '%s' with offset %lu" -+ "len = %lu\n", -+ fsp_str_dbg(fsp), (unsigned long)offset, (unsigned long)len)); - - if (sio == NULL) { - return SMB_VFS_NEXT_FALLOCATE(handle, fsp, mode, offset, len); Property changes on: head/net/samba48/files/patch-source3__modules__vfs_streams_xattr.c ___________________________________________________________________ Deleted: fbsd:nokeywords ## -1 +0,0 ## -yes \ No newline at end of property Deleted: svn:eol-style ## -1 +0,0 ## -native \ No newline at end of property Deleted: svn:mime-type ## -1 +0,0 ## -text/plain \ No newline at end of property Index: head/net/samba48/files/patch-vfs_freebsd.c =================================================================== --- head/net/samba48/files/patch-vfs_freebsd.c (revision 492473) +++ head/net/samba48/files/patch-vfs_freebsd.c (nonexistent) @@ -1,1785 +0,0 @@ ---- /dev/null 2018-03-05 02:00:00 UTC -+++ source3/modules/vfs_freebsd.c 2018-03-05 02:04:19.982828000 +0100 -@@ -0,0 +1,1782 @@ -+/* -+ * This module implements VFS calls specific to FreeBSD -+ * -+ * Copyright (C) Timur I. Bakeyev, 2018 -+ * -+ * 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 . -+ */ -+ -+#include "includes.h" -+ -+//#include "../source3/include/includes.h" -+#include "lib/util/tevent_unix.h" -+#include "lib/util/tevent_ntstatus.h" -+#include "system/filesys.h" -+ -+#include -+ -+ -+#ifndef EXTATTR_MAXNAMELEN -+#define EXTATTR_MAXNAMELEN UINT8_MAX -+#endif -+ -+#define EXTATTR_NAMESPACE(NS) EXTATTR_NAMESPACE_ ## NS, \ -+ EXTATTR_NAMESPACE_ ## NS ## _STRING ".", \ -+ .data.len = (sizeof(EXTATTR_NAMESPACE_ ## NS ## _STRING ".") - 1) -+ -+#define EXTATTR_EMPTY 0x00 -+#define EXTATTR_USER 0x01 -+#define EXTATTR_SYSTEM 0x02 -+#define EXTATTR_SECURITY 0x03 -+#define EXTATTR_TRUSTED 0x04 -+ -+ -+static bool is_secure = true; -+static bool is_legacy = false; -+ -+typedef struct { -+ int namespace; -+ char name[EXTATTR_MAXNAMELEN+1]; -+ union { -+ uint16_t len; -+ uint16_t flags; -+ } data; -+} extattr_attr; -+ -+ -+/* XXX: This order doesn't match namespace ids order! */ -+static extattr_attr extattr[] = { -+ { EXTATTR_NAMESPACE(EMPTY) }, -+ { EXTATTR_NAMESPACE(SYSTEM) }, -+ { EXTATTR_NAMESPACE(USER) }, -+}; -+ -+typedef struct { -+ enum { -+ EXTATTR_FILE, EXTATTR_LINK, EXTATTR_FDES -+ } method; -+ union { -+ const char *path; -+ int filedes; -+ } param; -+} extattr_arg; -+ -+ -+ -+static bool freebsd_in_jail(void) { -+ int val = 0; -+ size_t val_len = sizeof(val); -+ -+ if((sysctlbyname("security.jail.jailed", &val, &val_len, NULL, 0) != -1) && val == 1) { -+ return true; -+ } -+ return false; -+} -+ -+static uint16_t freebsd_map_attrname(const char *name) -+{ -+ if(name == NULL || name[0] == '\0') { -+ return EXTATTR_EMPTY; -+ } -+ -+ switch(name[0]) { -+ case 'u': -+ if(strncmp(name, "user.", 5) == 0) -+ return EXTATTR_USER; -+ break; -+ case 't': -+ if(strncmp(name, "trusted.", 8) == 0) -+ return EXTATTR_TRUSTED; -+ break; -+ case 's': -+ /* name[1] could be any character, including '\0' */ -+ switch(name[1]) { -+ case 'e': -+ if(strncmp(name, "security.", 9) == 0) -+ return EXTATTR_SECURITY; -+ break; -+ case 'y': -+ if(strncmp(name, "system.", 7) == 0) -+ return EXTATTR_SYSTEM; -+ break; -+ } -+ break; -+ } -+ return EXTATTR_USER; -+} -+ -+/* security, system, trusted or user */ -+static extattr_attr* freebsd_map_xattr(const char *name, extattr_attr *attr) -+{ -+ int attrnamespace = EXTATTR_NAMESPACE_EMPTY; -+ const char *attrname = name; -+ -+ if(name == NULL || name[0] == '\0') { -+ return NULL; -+ } -+ -+ if(attr == NULL) { -+ return NULL; -+ } -+ -+ uint16_t flags = freebsd_map_attrname(name); -+ -+ switch(flags) { -+ case EXTATTR_USER: -+ attrnamespace = EXTATTR_NAMESPACE_USER; -+ if(is_legacy) -+ attrname = name + 5; -+ break; -+ case EXTATTR_SECURITY: -+ case EXTATTR_TRUSTED: -+ attrnamespace = (is_secure) ? -+ EXTATTR_NAMESPACE_SYSTEM : -+ EXTATTR_NAMESPACE_USER; -+ break; -+ case EXTATTR_SYSTEM: -+ attrnamespace = (is_secure) ? -+ EXTATTR_NAMESPACE_SYSTEM : -+ EXTATTR_NAMESPACE_USER; -+ if (is_legacy) -+ attrname = name + 7; -+ break; -+ default: -+ /* Default to "user" namespace if nothing else was specified */ -+ attrnamespace = EXTATTR_NAMESPACE_USER; -+ flags = EXTATTR_USER; -+ } -+ -+ attr->namespace = attrnamespace; -+ attr->data.flags = flags; -+ strlcpy(attr->name, attrname, EXTATTR_MAXNAMELEN+1); -+ -+ return attr; -+} -+ -+static ssize_t extattr_size(extattr_arg arg, extattr_attr *attr) -+{ -+ ssize_t result; -+ -+ switch(arg.method) { -+#if defined(HAVE_EXTATTR_GET_FILE) -+ case EXTATTR_FILE: -+ result = extattr_get_file(arg.param.path, attr->namespace, attr->name, NULL, 0); -+ break; -+#endif -+#if defined(HAVE_EXTATTR_GET_LINK) -+ case EXTATTR_LINK: -+ result = extattr_get_link(arg.param.path, attr->namespace, attr->name, NULL, 0); -+ break; -+#endif -+#if defined(HAVE_EXTATTR_GET_FD) -+ case EXTATTR_FDES: -+ result = extattr_get_fd(arg.param.filedes, attr->namespace, attr->name, NULL, 0); -+ break; -+#endif -+ default: -+ errno = ENOSYS; -+ return -1; -+ } -+ -+ if(result < 0) { -+ errno = EINVAL; -+ return -1; -+ } -+ -+ return result; -+} -+ -+ -+/* -+ * The list of names is returned as an unordered array of NULL-terminated -+ * character strings (attribute names are separated by NULL characters), -+ * like this: -+ * user.name1\0system.name1\0user.name2\0 -+ * -+ * Filesystems like ext2, ext3 and XFS which implement POSIX ACLs using -+ * extended attributes, might return a list like this: -+ * system.posix_acl_access\0system.posix_acl_default\0 -+ */ -+/* -+ * The extattr_list_file() returns a list of attributes present in the -+ * requested namespace. Each list entry consists of a single byte containing -+ * the length of the attribute name, followed by the attribute name. The -+ * attribute name is not terminated by ASCII 0 (nul). -+*/ -+ -+static ssize_t freebsd_extattr_list(extattr_arg arg, char *list, size_t size) -+{ -+ ssize_t list_size, total_size = 0; -+ char *p, *q, *list_end; -+ int len; -+ /* -+ Ignore all but user namespace when we are not root or in jail -+ See: https://bugzilla.samba.org/show_bug.cgi?id=10247 -+ */ -+ bool as_root = (geteuid() == 0); -+ -+ int ns = (is_secure && as_root) ? 1 : 2; -+ -+ /* Iterate through extattr(2) namespaces */ -+ for(; ns < ARRAY_SIZE(extattr); ns++) { -+ switch(arg.method) { -+#if defined(HAVE_EXTATTR_LIST_FILE) -+ case EXTATTR_FILE: -+ list_size = extattr_list_file(arg.param.path, extattr[ns].namespace, list, size); -+ break; -+#endif -+#if defined(HAVE_EXTATTR_LIST_LINK) -+ case EXTATTR_LINK: -+ list_size = extattr_list_link(arg.param.path, extattr[ns].namespace, list, size); -+ break; -+#endif -+#if defined(HAVE_EXTATTR_LIST_FD) -+ case EXTATTR_FDES: -+ list_size = extattr_list_fd(arg.param.filedes, extattr[ns].namespace, list, size); -+ break; -+#endif -+ default: -+ errno = ENOSYS; -+ return -1; -+ } -+ /* Some error happend. Errno should be set by the previous call */ -+ if(list_size < 0) -+ return -1; -+ /* No attributes in this namespace */ -+ if(list_size == 0) -+ continue; -+ /* -+ Call with an empty buffer may be used to calculate -+ necessary buffer size. -+ */ -+ if(list == NULL) { -+ /* -+ XXX: Unfortunately, we can't say, how many attributes were -+ returned, so here is the potential problem with the emulation. -+ */ -+ if(is_legacy) { -+ /* -+ Take the worse case of one char attribute names - -+ two bytes per name plus one more for sanity. -+ */ -+ total_size += list_size + (list_size/2 + 1)*extattr[ns].data.len; -+ } -+ else { -+ total_size += list_size; -+ } -+ continue; -+ } -+ -+ if(is_legacy) { -+ /* Count necessary offset to fit namespace prefixes */ -+ int extra_len = 0; -+ uint16_t flags; -+ list_end = list + list_size; -+ for(list_size = 0, p = q = list; p < list_end; p += len) { -+ len = p[0] + 1; -+ (void)strlcpy(q, p + 1, len); -+ flags = freebsd_map_attrname(q); -+ /* Skip secure attributes for non-root user */ -+ if(!is_secure && !as_root && flags > EXTATTR_USER) { -+ continue; -+ } -+ if(flags <= EXTATTR_USER) { -+ /* Don't count trailing '\0' */ -+ extra_len += extattr[ns].data.len; -+ } -+ list_size += len; -+ q += len; -+ } -+ total_size += list_size + extra_len; -+ /* Buffer is too small to fit the results */ -+ if(total_size > size) { -+ errno = ERANGE; -+ return -1; -+ } -+ /* Shift results backwards, so we can prepend prefixes */ -+ list_end = list + extra_len; -+ p = (char*)memmove(list_end, list, list_size); -+ /* -+ We enter the loop with `p` pointing to the shifted list and -+ `extra_len` having the total margin between `list` and `p` -+ */ -+ for(list_end += list_size; p < list_end; p += len) { -+ len = strlen(p) + 1; -+ flags = freebsd_map_attrname(p); -+ if(flags <= EXTATTR_USER) { -+ /* Add namespace prefix */ -+ (void)strncpy(list, extattr[ns].name, extattr[ns].data.len); -+ list += extattr[ns].data.len; -+ } -+ /* Append attribute name */ -+ (void)strlcpy(list, p, len); -+ list += len; -+ } -+ } -+ else { -+ /* Convert UCSD strings into nul-terminated strings */ -+ for(list_end = list + list_size; list < list_end; list += len) { -+ len = list[0] + 1; -+ (void)strlcpy(list, list + 1, len); -+ } -+ total_size += list_size; -+ } -+ } -+ return total_size; -+} -+ -+/* -+static ssize_t freebsd_getxattr_size(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ const char *name) -+{ -+ extattr_arg arg = { EXTATTR_FILE, smb_fname->base_name }; -+ extattr_attr attr; -+ -+ if(!freebsd_map_xattr(name, &attr)) { -+ errno = EINVAL; -+ return -1; -+ } -+ -+ if(!is_secure && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { -+ errno = ENOATTR; -+ return -1; -+ } -+ -+ return extattr_size(arg, &attr); -+} -+*/ -+ -+/* VFS entries */ -+static ssize_t freebsd_getxattr(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ const char *name, -+ void *value, -+ size_t size) -+{ -+#if defined(HAVE_EXTATTR_GET_FILE) -+ extattr_arg arg = { EXTATTR_FILE, .param.path = smb_fname->base_name }; -+ extattr_attr attr; -+ ssize_t res; -+ -+ if(!freebsd_map_xattr(name, &attr)) { -+ errno = EINVAL; -+ return -1; -+ } -+ -+ /* Filter out 'secure' entries */ -+ if(!is_secure && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { -+ errno = ENOATTR; -+ return -1; -+ } -+ -+ /* -+ * The BSD implementation has a nasty habit of silently truncating -+ * the returned value to the size of the buffer, so we have to check -+ * that the buffer is large enough to fit the returned value. -+ */ -+ if((res=extattr_size(arg, &attr)) < 0) { -+ return -1; -+ } -+ -+ if (size == 0) { -+ return res; -+ } -+ else if (res > size) { -+ errno = ERANGE; -+ return -1; -+ } -+ -+ if((res=extattr_get_file(smb_fname->base_name, attr.namespace, attr.name, value, size)) >= 0) { -+ return res; -+ } -+ return -1; -+#else -+ errno = ENOSYS; -+ return -1; -+#endif -+} -+ -+ -+static ssize_t freebsd_fgetxattr(vfs_handle_struct *handle, -+ struct files_struct *fsp, const char *name, -+ void *value, size_t size) -+{ -+#if defined(HAVE_EXTATTR_GET_FD) -+ extattr_arg arg = { EXTATTR_FDES, .param.filedes = fsp->fh->fd }; -+ extattr_attr attr; -+ ssize_t res; -+ -+ if(!freebsd_map_xattr(name, &attr)) { -+ errno = EINVAL; -+ return -1; -+ } -+ -+ /* Filter out 'secure' entries */ -+ if(!is_secure && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { -+ errno = ENOATTR; -+ return -1; -+ } -+ -+ /* -+ * The BSD implementation has a nasty habit of silently truncating -+ * the returned value to the size of the buffer, so we have to check -+ * that the buffer is large enough to fit the returned value. -+ */ -+ if((res=extattr_size(arg, &attr)) < 0) { -+ return -1; -+ } -+ -+ if (size == 0) { -+ return res; -+ } -+ else if (res > size) { -+ errno = ERANGE; -+ return -1; -+ } -+ -+ if((res=extattr_get_fd(fsp->fh->fd, attr.namespace, attr.name, value, size)) >= 0) { -+ return res; -+ } -+ return -1; -+#else -+ errno = ENOSYS; -+ return -1; -+#endif -+} -+ -+ -+static ssize_t freebsd_listxattr(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ char *list, -+ size_t size) -+{ -+#if defined(HAVE_EXTATTR_LIST_FILE) -+ extattr_arg arg = { EXTATTR_FILE, .param.path = smb_fname->base_name }; -+ -+ return freebsd_extattr_list(arg, list, size); -+#else -+ errno = ENOSYS; -+ return -1; -+#endif -+} -+ -+ -+static ssize_t freebsd_flistxattr(vfs_handle_struct *handle, -+ struct files_struct *fsp, char *list, -+ size_t size) -+{ -+#if defined(HAVE_EXTATTR_LIST_FD) -+ extattr_arg arg = { EXTATTR_FDES, .param.filedes = fsp->fh->fd }; -+ -+ return freebsd_extattr_list(arg, list, size); -+#else -+ errno = ENOSYS; -+ return -1; -+#endif -+} -+ -+static int freebsd_removexattr(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ const char *name) -+{ -+#if defined(HAVE_EXTATTR_DELETE_FILE) -+ extattr_attr attr; -+ -+ if(!freebsd_map_xattr(name, &attr)) { -+ errno = EINVAL; -+ return -1; -+ } -+ -+ /* Filter out 'secure' entries */ -+ if(!is_secure && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { -+ errno = ENOATTR; -+ return -1; -+ } -+ -+ return extattr_delete_file(smb_fname->base_name, attr.namespace, attr.name); -+#else -+ errno = ENOSYS; -+ return -1; -+#endif -+} -+ -+ -+static int freebsd_fremovexattr(vfs_handle_struct *handle, -+ struct files_struct *fsp, const char *name) -+{ -+#if defined(HAVE_EXTATTR_DELETE_FD) -+ extattr_attr attr; -+ -+ if(!freebsd_map_xattr(name, &attr)) { -+ errno = EINVAL; -+ return -1; -+ } -+ -+ /* Filter out 'secure' entries */ -+ if(!is_secure && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { -+ errno = ENOATTR; -+ return -1; -+ } -+ -+ return extattr_delete_fd(fsp->fh->fd, attr.namespace, attr.name); -+#else -+ errno = ENOSYS; -+ return -1; -+#endif -+} -+ -+ -+static int freebsd_setxattr(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ const char *name, -+ const void *value, -+ size_t size, -+ int flags) -+{ -+#if defined(HAVE_EXTATTR_SET_FILE) -+ extattr_attr attr; -+ ssize_t res; -+ -+ if(!freebsd_map_xattr(name, &attr)) { -+ errno = EINVAL; -+ return -1; -+ } -+ -+ /* Filter out 'secure' entries */ -+ if(!is_secure && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { -+ errno = ENOATTR; -+ return -1; -+ } -+ -+ if (flags) { -+ extattr_arg arg = { EXTATTR_FILE, .param.path = smb_fname->base_name }; -+ /* Check attribute existence */ -+ res = extattr_size(arg, &attr); -+ if (res < 0) { -+ /* REPLACE attribute, that doesn't exist */ -+ if ((flags & XATTR_REPLACE) && errno == ENOATTR) { -+ errno = ENOATTR; -+ return -1; -+ } -+ /* Ignore other errors */ -+ } -+ else { -+ /* CREATE attribute, that already exists */ -+ if (flags & XATTR_CREATE) { -+ errno = EEXIST; -+ return -1; -+ } -+ } -+ } -+ res = extattr_set_file(smb_fname->base_name, attr.namespace, attr.name, value, size); -+ -+ return (res >= 0) ? 0 : -1; -+#else -+ errno = ENOSYS; -+ return -1; -+#endif -+} -+ -+ -+static int freebsd_fsetxattr(vfs_handle_struct *handle, struct files_struct *fsp, -+ const char *name, const void *value, size_t size, -+ int flags) -+{ -+#if defined(HAVE_EXTATTR_SET_FD) -+ extattr_attr attr; -+ ssize_t res; -+ -+ if(!freebsd_map_xattr(name, &attr)) { -+ errno = EINVAL; -+ return -1; -+ } -+ -+ /* Filter out 'secure' entries */ -+ if(!is_secure && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { -+ errno = ENOATTR; -+ return -1; -+ } -+ -+ if (flags) { -+ extattr_arg arg = { EXTATTR_FDES, .param.filedes = fsp->fh->fd }; -+ /* Check attribute existence */ -+ res = extattr_size(arg, &attr); -+ if (res < 0) { -+ /* REPLACE attribute, that doesn't exist */ -+ if ((flags & XATTR_REPLACE) && errno == ENOATTR) { -+ errno = ENOATTR; -+ return -1; -+ } -+ /* Ignore other errors */ -+ } -+ else { -+ /* CREATE attribute, that already exists */ -+ if (flags & XATTR_CREATE) { -+ errno = EEXIST; -+ return -1; -+ } -+ } -+ } -+ -+ res = extattr_set_fd(fsp->fh->fd, attr.namespace, attr.name, value, size); -+ -+ return (res >= 0) ? 0 : -1; -+#else -+ errno = ENOSYS; -+ return -1; -+#endif -+} -+ -+ -+ -+ -+static int freebsd_connect(vfs_handle_struct *handle, const char *service, -+ const char *user) -+{ -+ return SMB_VFS_NEXT_CONNECT(handle, service, user); -+} -+ -+static void freebsd_disconnect(vfs_handle_struct *handle) -+{ -+ SMB_VFS_NEXT_DISCONNECT(handle); -+} -+ -+static uint64_t freebsd_disk_free(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ uint64_t *bsize, -+ uint64_t *dfree, -+ uint64_t *dsize) -+{ -+ return SMB_VFS_NEXT_DISK_FREE(handle, smb_fname, bsize, dfree, dsize); -+} -+ -+static int freebsd_get_quota(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ enum SMB_QUOTA_TYPE qtype, -+ unid_t id, -+ SMB_DISK_QUOTA *dq) -+{ -+ return SMB_VFS_NEXT_GET_QUOTA(handle, smb_fname, qtype, id, dq); -+} -+ -+static int freebsd_set_quota(vfs_handle_struct *handle, enum SMB_QUOTA_TYPE qtype, -+ unid_t id, SMB_DISK_QUOTA *dq) -+{ -+ return SMB_VFS_NEXT_SET_QUOTA(handle, qtype, id, dq); -+} -+ -+static int freebsd_get_shadow_copy_data(vfs_handle_struct *handle, -+ files_struct *fsp, -+ struct shadow_copy_data *shadow_copy_data, -+ bool labels) -+{ -+ return SMB_VFS_NEXT_GET_SHADOW_COPY_DATA(handle, fsp, shadow_copy_data, -+ labels); -+} -+ -+static int freebsd_statvfs(struct vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ struct vfs_statvfs_struct *statbuf) -+{ -+ return SMB_VFS_NEXT_STATVFS(handle, smb_fname, statbuf); -+} -+ -+static uint32_t freebsd_fs_capabilities(struct vfs_handle_struct *handle, -+ enum timestamp_set_resolution *p_ts_res) -+{ -+ return SMB_VFS_NEXT_FS_CAPABILITIES(handle, p_ts_res); -+} -+ -+static NTSTATUS freebsd_get_dfs_referrals(struct vfs_handle_struct *handle, -+ struct dfs_GetDFSReferral *r) -+{ -+ return SMB_VFS_NEXT_GET_DFS_REFERRALS(handle, r); -+} -+ -+static DIR *freebsd_opendir(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ const char *mask, -+ uint32_t attr) -+{ -+ return SMB_VFS_NEXT_OPENDIR(handle, smb_fname, mask, attr); -+} -+ -+static NTSTATUS freebsd_snap_check_path(struct vfs_handle_struct *handle, -+ TALLOC_CTX *mem_ctx, -+ const char *service_path, -+ char **base_volume) -+{ -+ return SMB_VFS_NEXT_SNAP_CHECK_PATH(handle, mem_ctx, service_path, -+ base_volume); -+} -+ -+static NTSTATUS freebsd_snap_create(struct vfs_handle_struct *handle, -+ TALLOC_CTX *mem_ctx, -+ const char *base_volume, -+ time_t *tstamp, -+ bool rw, -+ char **base_path, -+ char **snap_path) -+{ -+ return SMB_VFS_NEXT_SNAP_CREATE(handle, mem_ctx, base_volume, tstamp, -+ rw, base_path, snap_path); -+} -+ -+static NTSTATUS freebsd_snap_delete(struct vfs_handle_struct *handle, -+ TALLOC_CTX *mem_ctx, -+ char *base_path, -+ char *snap_path) -+{ -+ return SMB_VFS_NEXT_SNAP_DELETE(handle, mem_ctx, base_path, snap_path); -+} -+ -+static DIR *freebsd_fdopendir(vfs_handle_struct *handle, files_struct *fsp, -+ const char *mask, uint32_t attr) -+{ -+ return SMB_VFS_NEXT_FDOPENDIR(handle, fsp, mask, attr); -+} -+ -+static struct dirent *freebsd_readdir(vfs_handle_struct *handle, -+ DIR *dirp, SMB_STRUCT_STAT *sbuf) -+{ -+ return SMB_VFS_NEXT_READDIR(handle, dirp, sbuf); -+} -+ -+static void freebsd_seekdir(vfs_handle_struct *handle, DIR *dirp, long offset) -+{ -+ SMB_VFS_NEXT_SEEKDIR(handle, dirp, offset); -+} -+ -+static long freebsd_telldir(vfs_handle_struct *handle, DIR *dirp) -+{ -+ return SMB_VFS_NEXT_TELLDIR(handle, dirp); -+} -+ -+static void freebsd_rewind_dir(vfs_handle_struct *handle, DIR *dirp) -+{ -+ SMB_VFS_NEXT_REWINDDIR(handle, dirp); -+} -+ -+static int freebsd_mkdir(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ mode_t mode) -+{ -+ return SMB_VFS_NEXT_MKDIR(handle, smb_fname, mode); -+} -+ -+static int freebsd_rmdir(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname) -+{ -+ return SMB_VFS_NEXT_RMDIR(handle, smb_fname); -+} -+ -+static int freebsd_closedir(vfs_handle_struct *handle, DIR *dir) -+{ -+ return SMB_VFS_NEXT_CLOSEDIR(handle, dir); -+} -+ -+static int freebsd_open(vfs_handle_struct *handle, struct smb_filename *smb_fname, -+ files_struct *fsp, int flags, mode_t mode) -+{ -+ return SMB_VFS_NEXT_OPEN(handle, smb_fname, fsp, flags, mode); -+} -+ -+static NTSTATUS freebsd_create_file(struct vfs_handle_struct *handle, -+ struct smb_request *req, -+ uint16_t root_dir_fid, -+ struct smb_filename *smb_fname, -+ uint32_t access_mask, -+ uint32_t share_access, -+ uint32_t create_disposition, -+ uint32_t create_options, -+ uint32_t file_attributes, -+ uint32_t oplock_request, -+ struct smb2_lease *lease, -+ uint64_t allocation_size, -+ uint32_t private_flags, -+ struct security_descriptor *sd, -+ struct ea_list *ea_list, -+ files_struct ** result, int *pinfo, -+ const struct smb2_create_blobs *in_context_blobs, -+ struct smb2_create_blobs *out_context_blobs) -+{ -+ return SMB_VFS_NEXT_CREATE_FILE(handle, -+ req, -+ root_dir_fid, -+ smb_fname, -+ access_mask, -+ share_access, -+ create_disposition, -+ create_options, -+ file_attributes, -+ oplock_request, -+ lease, -+ allocation_size, -+ private_flags, -+ sd, ea_list, result, pinfo, -+ in_context_blobs, out_context_blobs); -+} -+ -+static int freebsd_close_fn(vfs_handle_struct *handle, files_struct *fsp) -+{ -+ return SMB_VFS_NEXT_CLOSE(handle, fsp); -+} -+ -+static ssize_t freebsd_vfs_read(vfs_handle_struct *handle, files_struct *fsp, -+ void *data, size_t n) -+{ -+ return SMB_VFS_NEXT_READ(handle, fsp, data, n); -+} -+ -+static ssize_t freebsd_pread(vfs_handle_struct *handle, files_struct *fsp, -+ void *data, size_t n, off_t offset) -+{ -+ return SMB_VFS_NEXT_PREAD(handle, fsp, data, n, offset); -+} -+ -+struct freebsd_pread_state { -+ ssize_t ret; -+ struct vfs_aio_state vfs_aio_state; -+}; -+ -+static void freebsd_pread_done(struct tevent_req *subreq); -+ -+static struct tevent_req *freebsd_pread_send(struct vfs_handle_struct *handle, -+ TALLOC_CTX *mem_ctx, -+ struct tevent_context *ev, -+ struct files_struct *fsp, -+ void *data, size_t n, off_t offset) -+{ -+ struct tevent_req *req, *subreq; -+ struct freebsd_pread_state *state; -+ -+ req = tevent_req_create(mem_ctx, &state, struct freebsd_pread_state); -+ if (req == NULL) { -+ return NULL; -+ } -+ subreq = SMB_VFS_NEXT_PREAD_SEND(state, ev, handle, fsp, data, -+ n, offset); -+ if (tevent_req_nomem(subreq, req)) { -+ return tevent_req_post(req, ev); -+ } -+ tevent_req_set_callback(subreq, freebsd_pread_done, req); -+ return req; -+} -+ -+static void freebsd_pread_done(struct tevent_req *subreq) -+{ -+ struct tevent_req *req = -+ tevent_req_callback_data(subreq, struct tevent_req); -+ struct freebsd_pread_state *state = -+ tevent_req_data(req, struct freebsd_pread_state); -+ -+ state->ret = SMB_VFS_PREAD_RECV(subreq, &state->vfs_aio_state); -+ TALLOC_FREE(subreq); -+ tevent_req_done(req); -+} -+ -+static ssize_t freebsd_pread_recv(struct tevent_req *req, -+ struct vfs_aio_state *vfs_aio_state) -+{ -+ struct freebsd_pread_state *state = -+ tevent_req_data(req, struct freebsd_pread_state); -+ -+ if (tevent_req_is_unix_error(req, &vfs_aio_state->error)) { -+ return -1; -+ } -+ *vfs_aio_state = state->vfs_aio_state; -+ return state->ret; -+} -+ -+static ssize_t freebsd_write(vfs_handle_struct *handle, files_struct *fsp, -+ const void *data, size_t n) -+{ -+ return SMB_VFS_NEXT_WRITE(handle, fsp, data, n); -+} -+ -+static ssize_t freebsd_pwrite(vfs_handle_struct *handle, files_struct *fsp, -+ const void *data, size_t n, off_t offset) -+{ -+ return SMB_VFS_NEXT_PWRITE(handle, fsp, data, n, offset); -+} -+ -+struct freebsd_pwrite_state { -+ ssize_t ret; -+ struct vfs_aio_state vfs_aio_state; -+}; -+ -+static void freebsd_pwrite_done(struct tevent_req *subreq); -+ -+static struct tevent_req *freebsd_pwrite_send(struct vfs_handle_struct *handle, -+ TALLOC_CTX *mem_ctx, -+ struct tevent_context *ev, -+ struct files_struct *fsp, -+ const void *data, -+ size_t n, off_t offset) -+{ -+ struct tevent_req *req, *subreq; -+ struct freebsd_pwrite_state *state; -+ -+ req = tevent_req_create(mem_ctx, &state, struct freebsd_pwrite_state); -+ if (req == NULL) { -+ return NULL; -+ } -+ subreq = SMB_VFS_NEXT_PWRITE_SEND(state, ev, handle, fsp, data, -+ n, offset); -+ if (tevent_req_nomem(subreq, req)) { -+ return tevent_req_post(req, ev); -+ } -+ tevent_req_set_callback(subreq, freebsd_pwrite_done, req); -+ return req; -+} -+ -+static void freebsd_pwrite_done(struct tevent_req *subreq) -+{ -+ struct tevent_req *req = -+ tevent_req_callback_data(subreq, struct tevent_req); -+ struct freebsd_pwrite_state *state = -+ tevent_req_data(req, struct freebsd_pwrite_state); -+ -+ state->ret = SMB_VFS_PWRITE_RECV(subreq, &state->vfs_aio_state); -+ TALLOC_FREE(subreq); -+ tevent_req_done(req); -+} -+ -+static ssize_t freebsd_pwrite_recv(struct tevent_req *req, -+ struct vfs_aio_state *vfs_aio_state) -+{ -+ struct freebsd_pwrite_state *state = -+ tevent_req_data(req, struct freebsd_pwrite_state); -+ -+ if (tevent_req_is_unix_error(req, &vfs_aio_state->error)) { -+ return -1; -+ } -+ *vfs_aio_state = state->vfs_aio_state; -+ return state->ret; -+} -+ -+static off_t freebsd_lseek(vfs_handle_struct *handle, files_struct *fsp, -+ off_t offset, int whence) -+{ -+ return SMB_VFS_NEXT_LSEEK(handle, fsp, offset, whence); -+} -+ -+static ssize_t freebsd_sendfile(vfs_handle_struct *handle, int tofd, -+ files_struct *fromfsp, const DATA_BLOB *hdr, -+ off_t offset, size_t n) -+{ -+ return SMB_VFS_NEXT_SENDFILE(handle, tofd, fromfsp, hdr, offset, n); -+} -+ -+static ssize_t freebsd_recvfile(vfs_handle_struct *handle, int fromfd, -+ files_struct *tofsp, off_t offset, size_t n) -+{ -+ return SMB_VFS_NEXT_RECVFILE(handle, fromfd, tofsp, offset, n); -+} -+ -+static int freebsd_rename(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname_src, -+ const struct smb_filename *smb_fname_dst) -+{ -+ return SMB_VFS_NEXT_RENAME(handle, smb_fname_src, smb_fname_dst); -+} -+ -+static int freebsd_fsync(vfs_handle_struct *handle, files_struct *fsp) -+{ -+ return SMB_VFS_NEXT_FSYNC(handle, fsp); -+} -+ -+struct freebsd_fsync_state { -+ int ret; -+ struct vfs_aio_state vfs_aio_state; -+}; -+ -+static void freebsd_fsync_done(struct tevent_req *subreq); -+ -+static struct tevent_req *freebsd_fsync_send(struct vfs_handle_struct *handle, -+ TALLOC_CTX *mem_ctx, -+ struct tevent_context *ev, -+ struct files_struct *fsp) -+{ -+ struct tevent_req *req, *subreq; -+ struct freebsd_fsync_state *state; -+ -+ req = tevent_req_create(mem_ctx, &state, struct freebsd_fsync_state); -+ if (req == NULL) { -+ return NULL; -+ } -+ subreq = SMB_VFS_NEXT_FSYNC_SEND(state, ev, handle, fsp); -+ if (tevent_req_nomem(subreq, req)) { -+ return tevent_req_post(req, ev); -+ } -+ tevent_req_set_callback(subreq, freebsd_fsync_done, req); -+ return req; -+} -+ -+static void freebsd_fsync_done(struct tevent_req *subreq) -+{ -+ struct tevent_req *req = -+ tevent_req_callback_data(subreq, struct tevent_req); -+ struct freebsd_fsync_state *state = -+ tevent_req_data(req, struct freebsd_fsync_state); -+ -+ state->ret = SMB_VFS_FSYNC_RECV(subreq, &state->vfs_aio_state); -+ TALLOC_FREE(subreq); -+ tevent_req_done(req); -+} -+ -+static int freebsd_fsync_recv(struct tevent_req *req, -+ struct vfs_aio_state *vfs_aio_state) -+{ -+ struct freebsd_fsync_state *state = -+ tevent_req_data(req, struct freebsd_fsync_state); -+ -+ if (tevent_req_is_unix_error(req, &vfs_aio_state->error)) { -+ return -1; -+ } -+ *vfs_aio_state = state->vfs_aio_state; -+ return state->ret; -+} -+ -+static int freebsd_stat(vfs_handle_struct *handle, struct smb_filename *smb_fname) -+{ -+ return SMB_VFS_NEXT_STAT(handle, smb_fname); -+} -+ -+static int freebsd_fstat(vfs_handle_struct *handle, files_struct *fsp, -+ SMB_STRUCT_STAT *sbuf) -+{ -+ return SMB_VFS_NEXT_FSTAT(handle, fsp, sbuf); -+} -+ -+static int freebsd_lstat(vfs_handle_struct *handle, -+ struct smb_filename *smb_fname) -+{ -+ return SMB_VFS_NEXT_LSTAT(handle, smb_fname); -+} -+ -+static uint64_t freebsd_get_alloc_size(struct vfs_handle_struct *handle, -+ struct files_struct *fsp, -+ const SMB_STRUCT_STAT *sbuf) -+{ -+ return SMB_VFS_NEXT_GET_ALLOC_SIZE(handle, fsp, sbuf); -+} -+ -+static int freebsd_unlink(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname) -+{ -+ return SMB_VFS_NEXT_UNLINK(handle, smb_fname); -+} -+ -+static int freebsd_chmod(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ mode_t mode) -+{ -+ return SMB_VFS_NEXT_CHMOD(handle, smb_fname, mode); -+} -+ -+static int freebsd_fchmod(vfs_handle_struct *handle, files_struct *fsp, -+ mode_t mode) -+{ -+ return SMB_VFS_NEXT_FCHMOD(handle, fsp, mode); -+} -+ -+static int freebsd_chown(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ uid_t uid, -+ gid_t gid) -+{ -+ return SMB_VFS_NEXT_CHOWN(handle, smb_fname, uid, gid); -+} -+ -+static int freebsd_fchown(vfs_handle_struct *handle, files_struct *fsp, -+ uid_t uid, gid_t gid) -+{ -+ return SMB_VFS_NEXT_FCHOWN(handle, fsp, uid, gid); -+} -+ -+static int freebsd_lchown(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ uid_t uid, -+ gid_t gid) -+{ -+ return SMB_VFS_NEXT_LCHOWN(handle, smb_fname, uid, gid); -+} -+ -+static int freebsd_chdir(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname) -+{ -+ return SMB_VFS_NEXT_CHDIR(handle, smb_fname); -+} -+ -+static struct smb_filename *freebsd_getwd(vfs_handle_struct *handle, -+ TALLOC_CTX *ctx) -+{ -+ return SMB_VFS_NEXT_GETWD(handle, ctx); -+} -+ -+static int freebsd_ntimes(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ struct smb_file_time *ft) -+{ -+ return SMB_VFS_NEXT_NTIMES(handle, smb_fname, ft); -+} -+ -+static int freebsd_ftruncate(vfs_handle_struct *handle, files_struct *fsp, -+ off_t offset) -+{ -+ return SMB_VFS_NEXT_FTRUNCATE(handle, fsp, offset); -+} -+ -+static int freebsd_fallocate(vfs_handle_struct *handle, files_struct *fsp, -+ uint32_t mode, off_t offset, off_t len) -+{ -+ return SMB_VFS_NEXT_FALLOCATE(handle, fsp, mode, offset, len); -+} -+ -+static bool freebsd_lock(vfs_handle_struct *handle, files_struct *fsp, int op, -+ off_t offset, off_t count, int type) -+{ -+ return SMB_VFS_NEXT_LOCK(handle, fsp, op, offset, count, type); -+} -+ -+static int freebsd_kernel_flock(struct vfs_handle_struct *handle, -+ struct files_struct *fsp, uint32_t share_mode, -+ uint32_t access_mask) -+{ -+ return SMB_VFS_NEXT_KERNEL_FLOCK(handle, fsp, share_mode, access_mask); -+} -+ -+static int freebsd_linux_setlease(struct vfs_handle_struct *handle, -+ struct files_struct *fsp, int leasetype) -+{ -+ return SMB_VFS_NEXT_LINUX_SETLEASE(handle, fsp, leasetype); -+} -+ -+static bool freebsd_getlock(vfs_handle_struct *handle, files_struct *fsp, -+ off_t *poffset, off_t *pcount, int *ptype, -+ pid_t *ppid) -+{ -+ return SMB_VFS_NEXT_GETLOCK(handle, fsp, poffset, pcount, ptype, ppid); -+} -+ -+static int freebsd_symlink(vfs_handle_struct *handle, -+ const char *link_contents, -+ const struct smb_filename *new_smb_fname) -+{ -+ return SMB_VFS_NEXT_SYMLINK(handle, link_contents, new_smb_fname); -+} -+ -+static int freebsd_vfs_readlink(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ char *buf, -+ size_t bufsiz) -+{ -+ return SMB_VFS_NEXT_READLINK(handle, smb_fname, buf, bufsiz); -+} -+ -+static int freebsd_link(vfs_handle_struct *handle, -+ const struct smb_filename *old_smb_fname, -+ const struct smb_filename *new_smb_fname) -+{ -+ return SMB_VFS_NEXT_LINK(handle, old_smb_fname, new_smb_fname); -+} -+ -+static int freebsd_mknod(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ mode_t mode, -+ SMB_DEV_T dev) -+{ -+ return SMB_VFS_NEXT_MKNOD(handle, smb_fname, mode, dev); -+} -+ -+static struct smb_filename *freebsd_realpath(vfs_handle_struct *handle, -+ TALLOC_CTX *ctx, -+ const struct smb_filename *smb_fname) -+{ -+ return SMB_VFS_NEXT_REALPATH(handle, ctx, smb_fname); -+} -+ -+static int freebsd_chflags(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ uint flags) -+{ -+ return SMB_VFS_NEXT_CHFLAGS(handle, smb_fname, flags); -+} -+ -+static struct file_id freebsd_file_id_create(vfs_handle_struct *handle, -+ const SMB_STRUCT_STAT *sbuf) -+{ -+ return SMB_VFS_NEXT_FILE_ID_CREATE(handle, sbuf); -+} -+ -+struct freebsd_offload_read_state { -+ struct vfs_handle_struct *handle; -+ DATA_BLOB token; -+}; -+ -+static void freebsd_offload_read_done(struct tevent_req *subreq); -+ -+static struct tevent_req *freebsd_offload_read_send( -+ TALLOC_CTX *mem_ctx, -+ struct tevent_context *ev, -+ struct vfs_handle_struct *handle, -+ struct files_struct *fsp, -+ uint32_t fsctl, -+ uint32_t ttl, -+ off_t offset, -+ size_t to_copy) -+{ -+ struct tevent_req *req = NULL; -+ struct freebsd_offload_read_state *state = NULL; -+ struct tevent_req *subreq = NULL; -+ -+ req = tevent_req_create(mem_ctx, &state, struct freebsd_offload_read_state); -+ if (req == NULL) { -+ return NULL; -+ } -+ *state = (struct freebsd_offload_read_state) { -+ .handle = handle, -+ }; -+ -+ subreq = SMB_VFS_NEXT_OFFLOAD_READ_SEND(mem_ctx, ev, handle, fsp, -+ fsctl, ttl, offset, to_copy); -+ if (tevent_req_nomem(subreq, req)) { -+ return tevent_req_post(req, ev); -+ } -+ tevent_req_set_callback(subreq, freebsd_offload_read_done, req); -+ return req; -+} -+ -+static void freebsd_offload_read_done(struct tevent_req *subreq) -+{ -+ struct tevent_req *req = tevent_req_callback_data( -+ subreq, struct tevent_req); -+ struct freebsd_offload_read_state *state = tevent_req_data( -+ req, struct freebsd_offload_read_state); -+ NTSTATUS status; -+ -+ status = SMB_VFS_NEXT_OFFLOAD_READ_RECV(subreq, -+ state->handle, -+ state, -+ &state->token); -+ TALLOC_FREE(subreq); -+ if (tevent_req_nterror(req, status)) { -+ return; -+ } -+ -+ tevent_req_done(req); -+ return; -+} -+ -+static NTSTATUS freebsd_offload_read_recv(struct tevent_req *req, -+ struct vfs_handle_struct *handle, -+ TALLOC_CTX *mem_ctx, -+ DATA_BLOB *_token) -+{ -+ struct freebsd_offload_read_state *state = tevent_req_data( -+ req, struct freebsd_offload_read_state); -+ DATA_BLOB token; -+ NTSTATUS status; -+ -+ if (tevent_req_is_nterror(req, &status)) { -+ tevent_req_received(req); -+ return status; -+ } -+ -+ token = data_blob_talloc(mem_ctx, -+ state->token.data, -+ state->token.length); -+ -+ tevent_req_received(req); -+ -+ if (token.data == NULL) { -+ return NT_STATUS_NO_MEMORY; -+ } -+ -+ *_token = token; -+ return NT_STATUS_OK; -+} -+ -+struct freebsd_offload_write_state { -+ struct vfs_handle_struct *handle; -+ off_t copied; -+}; -+static void freebsd_offload_write_done(struct tevent_req *subreq); -+ -+static struct tevent_req *freebsd_offload_write_send(struct vfs_handle_struct *handle, -+ TALLOC_CTX *mem_ctx, -+ struct tevent_context *ev, -+ uint32_t fsctl, -+ DATA_BLOB *token, -+ off_t transfer_offset, -+ struct files_struct *dest_fsp, -+ off_t dest_off, -+ off_t num) -+{ -+ struct tevent_req *req; -+ struct tevent_req *subreq; -+ struct freebsd_offload_write_state *state; -+ -+ req = tevent_req_create(mem_ctx, &state, struct freebsd_offload_write_state); -+ if (req == NULL) { -+ return NULL; -+ } -+ -+ state->handle = handle; -+ subreq = SMB_VFS_NEXT_OFFLOAD_WRITE_SEND(handle, state, ev, -+ fsctl, token, transfer_offset, -+ dest_fsp, dest_off, num); -+ if (tevent_req_nomem(subreq, req)) { -+ return tevent_req_post(req, ev); -+ } -+ -+ tevent_req_set_callback(subreq, freebsd_offload_write_done, req); -+ return req; -+} -+ -+static void freebsd_offload_write_done(struct tevent_req *subreq) -+{ -+ struct tevent_req *req = tevent_req_callback_data( -+ subreq, struct tevent_req); -+ struct freebsd_offload_write_state *state -+ = tevent_req_data(req, struct freebsd_offload_write_state); -+ NTSTATUS status; -+ -+ status = SMB_VFS_NEXT_OFFLOAD_WRITE_RECV(state->handle, -+ subreq, -+ &state->copied); -+ TALLOC_FREE(subreq); -+ if (tevent_req_nterror(req, status)) { -+ return; -+ } -+ tevent_req_done(req); -+} -+ -+static NTSTATUS freebsd_offload_write_recv(struct vfs_handle_struct *handle, -+ struct tevent_req *req, -+ off_t *copied) -+{ -+ struct freebsd_offload_write_state *state -+ = tevent_req_data(req, struct freebsd_offload_write_state); -+ NTSTATUS status; -+ -+ *copied = state->copied; -+ if (tevent_req_is_nterror(req, &status)) { -+ tevent_req_received(req); -+ return status; -+ } -+ -+ tevent_req_received(req); -+ return NT_STATUS_OK; -+} -+ -+static NTSTATUS freebsd_get_compression(struct vfs_handle_struct *handle, -+ TALLOC_CTX *mem_ctx, -+ struct files_struct *fsp, -+ struct smb_filename *smb_fname, -+ uint16_t *_compression_fmt) -+{ -+ return SMB_VFS_NEXT_GET_COMPRESSION(handle, mem_ctx, fsp, smb_fname, -+ _compression_fmt); -+} -+ -+static NTSTATUS freebsd_set_compression(struct vfs_handle_struct *handle, -+ TALLOC_CTX *mem_ctx, -+ struct files_struct *fsp, -+ uint16_t compression_fmt) -+{ -+ return SMB_VFS_NEXT_SET_COMPRESSION(handle, mem_ctx, fsp, -+ compression_fmt); -+} -+ -+static NTSTATUS freebsd_streaminfo(struct vfs_handle_struct *handle, -+ struct files_struct *fsp, -+ const struct smb_filename *smb_fname, -+ TALLOC_CTX *mem_ctx, -+ unsigned int *num_streams, -+ struct stream_struct **streams) -+{ -+ return SMB_VFS_NEXT_STREAMINFO(handle, -+ fsp, -+ smb_fname, -+ mem_ctx, -+ num_streams, -+ streams); -+} -+ -+static int freebsd_get_real_filename(struct vfs_handle_struct *handle, -+ const char *path, -+ const char *name, -+ TALLOC_CTX *mem_ctx, char **found_name) -+{ -+ return SMB_VFS_NEXT_GET_REAL_FILENAME(handle, -+ path, name, mem_ctx, found_name); -+} -+ -+static const char *freebsd_connectpath(struct vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname) -+{ -+ return SMB_VFS_NEXT_CONNECTPATH(handle, smb_fname); -+} -+ -+static NTSTATUS freebsd_brl_lock_windows(struct vfs_handle_struct *handle, -+ struct byte_range_lock *br_lck, -+ struct lock_struct *plock, -+ bool blocking_lock) -+{ -+ return SMB_VFS_NEXT_BRL_LOCK_WINDOWS(handle, -+ br_lck, plock, blocking_lock); -+} -+ -+static bool freebsd_brl_unlock_windows(struct vfs_handle_struct *handle, -+ struct messaging_context *msg_ctx, -+ struct byte_range_lock *br_lck, -+ const struct lock_struct *plock) -+{ -+ return SMB_VFS_NEXT_BRL_UNLOCK_WINDOWS(handle, msg_ctx, br_lck, plock); -+} -+ -+static bool freebsd_brl_cancel_windows(struct vfs_handle_struct *handle, -+ struct byte_range_lock *br_lck, -+ struct lock_struct *plock) -+{ -+ return SMB_VFS_NEXT_BRL_CANCEL_WINDOWS(handle, br_lck, plock); -+} -+ -+static bool freebsd_strict_lock_check(struct vfs_handle_struct *handle, -+ struct files_struct *fsp, -+ struct lock_struct *plock) -+{ -+ return SMB_VFS_NEXT_STRICT_LOCK_CHECK(handle, fsp, plock); -+} -+ -+static NTSTATUS freebsd_translate_name(struct vfs_handle_struct *handle, -+ const char *mapped_name, -+ enum vfs_translate_direction direction, -+ TALLOC_CTX *mem_ctx, char **pmapped_name) -+{ -+ return SMB_VFS_NEXT_TRANSLATE_NAME(handle, mapped_name, direction, -+ mem_ctx, pmapped_name); -+} -+ -+static NTSTATUS freebsd_fsctl(struct vfs_handle_struct *handle, -+ struct files_struct *fsp, -+ TALLOC_CTX *ctx, -+ uint32_t function, -+ uint16_t req_flags, /* Needed for UNICODE ... */ -+ const uint8_t *_in_data, -+ uint32_t in_len, -+ uint8_t ** _out_data, -+ uint32_t max_out_len, uint32_t *out_len) -+{ -+ return SMB_VFS_NEXT_FSCTL(handle, -+ fsp, -+ ctx, -+ function, -+ req_flags, -+ _in_data, -+ in_len, _out_data, max_out_len, out_len); -+} -+ -+static NTSTATUS freebsd_readdir_attr(struct vfs_handle_struct *handle, -+ const struct smb_filename *fname, -+ TALLOC_CTX *mem_ctx, -+ struct readdir_attr_data **pattr_data) -+{ -+ return SMB_VFS_NEXT_READDIR_ATTR(handle, fname, mem_ctx, pattr_data); -+} -+ -+static NTSTATUS freebsd_get_dos_attributes(struct vfs_handle_struct *handle, -+ struct smb_filename *smb_fname, -+ uint32_t *dosmode) -+{ -+ return SMB_VFS_NEXT_GET_DOS_ATTRIBUTES(handle, -+ smb_fname, -+ dosmode); -+} -+ -+static NTSTATUS freebsd_fget_dos_attributes(struct vfs_handle_struct *handle, -+ struct files_struct *fsp, -+ uint32_t *dosmode) -+{ -+ return SMB_VFS_NEXT_FGET_DOS_ATTRIBUTES(handle, -+ fsp, -+ dosmode); -+} -+ -+static NTSTATUS freebsd_set_dos_attributes(struct vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ uint32_t dosmode) -+{ -+ return SMB_VFS_NEXT_SET_DOS_ATTRIBUTES(handle, -+ smb_fname, -+ dosmode); -+} -+ -+static NTSTATUS freebsd_fset_dos_attributes(struct vfs_handle_struct *handle, -+ struct files_struct *fsp, -+ uint32_t dosmode) -+{ -+ return SMB_VFS_NEXT_FSET_DOS_ATTRIBUTES(handle, -+ fsp, -+ dosmode); -+} -+ -+static NTSTATUS freebsd_fget_nt_acl(vfs_handle_struct *handle, files_struct *fsp, -+ uint32_t security_info, -+ TALLOC_CTX *mem_ctx, -+ struct security_descriptor **ppdesc) -+{ -+ return SMB_VFS_NEXT_FGET_NT_ACL(handle, fsp, security_info, mem_ctx, -+ ppdesc); -+} -+ -+static NTSTATUS freebsd_get_nt_acl(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ uint32_t security_info, -+ TALLOC_CTX *mem_ctx, -+ struct security_descriptor **ppdesc) -+{ -+ return SMB_VFS_NEXT_GET_NT_ACL(handle, -+ smb_fname, -+ security_info, -+ mem_ctx, -+ ppdesc); -+} -+ -+static NTSTATUS freebsd_fset_nt_acl(vfs_handle_struct *handle, files_struct *fsp, -+ uint32_t security_info_sent, -+ const struct security_descriptor *psd) -+{ -+ return SMB_VFS_NEXT_FSET_NT_ACL(handle, fsp, security_info_sent, psd); -+} -+ -+static int freebsd_chmod_acl(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ mode_t mode) -+{ -+ return SMB_VFS_NEXT_CHMOD_ACL(handle, smb_fname, mode); -+} -+ -+static int freebsd_fchmod_acl(vfs_handle_struct *handle, files_struct *fsp, -+ mode_t mode) -+{ -+ return SMB_VFS_NEXT_FCHMOD_ACL(handle, fsp, mode); -+} -+ -+static SMB_ACL_T freebsd_sys_acl_get_file(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ SMB_ACL_TYPE_T type, -+ TALLOC_CTX *mem_ctx) -+{ -+ return SMB_VFS_NEXT_SYS_ACL_GET_FILE(handle, smb_fname, type, mem_ctx); -+} -+ -+static SMB_ACL_T freebsd_sys_acl_get_fd(vfs_handle_struct *handle, -+ files_struct *fsp, TALLOC_CTX *mem_ctx) -+{ -+ return SMB_VFS_NEXT_SYS_ACL_GET_FD(handle, fsp, mem_ctx); -+} -+ -+static int freebsd_sys_acl_blob_get_file(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ TALLOC_CTX *mem_ctx, -+ char **blob_description, -+ DATA_BLOB *blob) -+{ -+ return SMB_VFS_NEXT_SYS_ACL_BLOB_GET_FILE(handle, smb_fname, mem_ctx, -+ blob_description, blob); -+} -+ -+static int freebsd_sys_acl_blob_get_fd(vfs_handle_struct *handle, -+ files_struct *fsp, TALLOC_CTX *mem_ctx, -+ char **blob_description, DATA_BLOB *blob) -+{ -+ return SMB_VFS_NEXT_SYS_ACL_BLOB_GET_FD(handle, fsp, mem_ctx, -+ blob_description, blob); -+} -+ -+static int freebsd_sys_acl_set_file(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname, -+ SMB_ACL_TYPE_T acltype, -+ SMB_ACL_T theacl) -+{ -+ return SMB_VFS_NEXT_SYS_ACL_SET_FILE(handle, smb_fname, -+ acltype, theacl); -+} -+ -+static int freebsd_sys_acl_set_fd(vfs_handle_struct *handle, files_struct *fsp, -+ SMB_ACL_T theacl) -+{ -+ return SMB_VFS_NEXT_SYS_ACL_SET_FD(handle, fsp, theacl); -+} -+ -+static int freebsd_sys_acl_delete_def_file(vfs_handle_struct *handle, -+ const struct smb_filename *smb_fname) -+{ -+ return SMB_VFS_NEXT_SYS_ACL_DELETE_DEF_FILE(handle, smb_fname); -+} -+ -+ -+static bool freebsd_aio_force(struct vfs_handle_struct *handle, -+ struct files_struct *fsp) -+{ -+ return SMB_VFS_NEXT_AIO_FORCE(handle, fsp); -+} -+ -+/* VFS operations structure */ -+ -+struct vfs_fn_pointers freebsd_fns = { -+ /* Disk operations */ -+ -+ .connect_fn = freebsd_connect, -+ .disconnect_fn = freebsd_disconnect, -+ .disk_free_fn = freebsd_disk_free, -+ .get_quota_fn = freebsd_get_quota, -+ .set_quota_fn = freebsd_set_quota, -+ .get_shadow_copy_data_fn = freebsd_get_shadow_copy_data, -+ .statvfs_fn = freebsd_statvfs, -+ .fs_capabilities_fn = freebsd_fs_capabilities, -+ .get_dfs_referrals_fn = freebsd_get_dfs_referrals, -+ .snap_check_path_fn = freebsd_snap_check_path, -+ .snap_create_fn = freebsd_snap_create, -+ .snap_delete_fn = freebsd_snap_delete, -+ -+ /* Directory operations */ -+ -+ .opendir_fn = freebsd_opendir, -+ .fdopendir_fn = freebsd_fdopendir, -+ .readdir_fn = freebsd_readdir, -+ .seekdir_fn = freebsd_seekdir, -+ .telldir_fn = freebsd_telldir, -+ .rewind_dir_fn = freebsd_rewind_dir, -+ .mkdir_fn = freebsd_mkdir, -+ .rmdir_fn = freebsd_rmdir, -+ .closedir_fn = freebsd_closedir, -+ -+ /* File operations */ -+ -+ .open_fn = freebsd_open, -+ .create_file_fn = freebsd_create_file, -+ .close_fn = freebsd_close_fn, -+ .read_fn = freebsd_vfs_read, -+ .pread_fn = freebsd_pread, -+ .pread_send_fn = freebsd_pread_send, -+ .pread_recv_fn = freebsd_pread_recv, -+ .write_fn = freebsd_write, -+ .pwrite_fn = freebsd_pwrite, -+ .pwrite_send_fn = freebsd_pwrite_send, -+ .pwrite_recv_fn = freebsd_pwrite_recv, -+ .lseek_fn = freebsd_lseek, -+ .sendfile_fn = freebsd_sendfile, -+ .recvfile_fn = freebsd_recvfile, -+ .rename_fn = freebsd_rename, -+ .fsync_fn = freebsd_fsync, -+ .fsync_send_fn = freebsd_fsync_send, -+ .fsync_recv_fn = freebsd_fsync_recv, -+ .stat_fn = freebsd_stat, -+ .fstat_fn = freebsd_fstat, -+ .lstat_fn = freebsd_lstat, -+ .get_alloc_size_fn = freebsd_get_alloc_size, -+ .unlink_fn = freebsd_unlink, -+ .chmod_fn = freebsd_chmod, -+ .fchmod_fn = freebsd_fchmod, -+ .chown_fn = freebsd_chown, -+ .fchown_fn = freebsd_fchown, -+ .lchown_fn = freebsd_lchown, -+ .chdir_fn = freebsd_chdir, -+ .getwd_fn = freebsd_getwd, -+ .ntimes_fn = freebsd_ntimes, -+ .ftruncate_fn = freebsd_ftruncate, -+ .fallocate_fn = freebsd_fallocate, -+ .lock_fn = freebsd_lock, -+ .kernel_flock_fn = freebsd_kernel_flock, -+ .linux_setlease_fn = freebsd_linux_setlease, -+ .getlock_fn = freebsd_getlock, -+ .symlink_fn = freebsd_symlink, -+ .readlink_fn = freebsd_vfs_readlink, -+ .link_fn = freebsd_link, -+ .mknod_fn = freebsd_mknod, -+ .realpath_fn = freebsd_realpath, -+ .chflags_fn = freebsd_chflags, -+ .file_id_create_fn = freebsd_file_id_create, -+ .offload_read_send_fn = freebsd_offload_read_send, -+ .offload_read_recv_fn = freebsd_offload_read_recv, -+ .offload_write_send_fn = freebsd_offload_write_send, -+ .offload_write_recv_fn = freebsd_offload_write_recv, -+ .get_compression_fn = freebsd_get_compression, -+ .set_compression_fn = freebsd_set_compression, -+ -+ .streaminfo_fn = freebsd_streaminfo, -+ .get_real_filename_fn = freebsd_get_real_filename, -+ .connectpath_fn = freebsd_connectpath, -+ .brl_lock_windows_fn = freebsd_brl_lock_windows, -+ .brl_unlock_windows_fn = freebsd_brl_unlock_windows, -+ .brl_cancel_windows_fn = freebsd_brl_cancel_windows, -+ .strict_lock_check_fn = freebsd_strict_lock_check, -+ .translate_name_fn = freebsd_translate_name, -+ .fsctl_fn = freebsd_fsctl, -+ .readdir_attr_fn = freebsd_readdir_attr, -+ -+ /* DOS attributes. */ -+ .get_dos_attributes_fn = freebsd_get_dos_attributes, -+ .fget_dos_attributes_fn = freebsd_fget_dos_attributes, -+ .set_dos_attributes_fn = freebsd_set_dos_attributes, -+ .fset_dos_attributes_fn = freebsd_fset_dos_attributes, -+ -+ /* NT ACL operations. */ -+ -+ .fget_nt_acl_fn = freebsd_fget_nt_acl, -+ .get_nt_acl_fn = freebsd_get_nt_acl, -+ .fset_nt_acl_fn = freebsd_fset_nt_acl, -+ -+ /* POSIX ACL operations. */ -+ -+ .chmod_acl_fn = freebsd_chmod_acl, -+ .fchmod_acl_fn = freebsd_fchmod_acl, -+ -+ .sys_acl_get_file_fn = freebsd_sys_acl_get_file, -+ .sys_acl_get_fd_fn = freebsd_sys_acl_get_fd, -+ .sys_acl_blob_get_file_fn = freebsd_sys_acl_blob_get_file, -+ .sys_acl_blob_get_fd_fn = freebsd_sys_acl_blob_get_fd, -+ .sys_acl_set_file_fn = freebsd_sys_acl_set_file, -+ .sys_acl_set_fd_fn = freebsd_sys_acl_set_fd, -+ .sys_acl_delete_def_file_fn = freebsd_sys_acl_delete_def_file, -+ -+ /* EA operations. */ -+ .getxattr_fn = freebsd_getxattr, -+ .fgetxattr_fn = freebsd_fgetxattr, -+ .listxattr_fn = freebsd_listxattr, -+ .flistxattr_fn = freebsd_flistxattr, -+ .removexattr_fn = freebsd_removexattr, -+ .fremovexattr_fn = freebsd_fremovexattr, -+ .setxattr_fn = freebsd_setxattr, -+ .fsetxattr_fn = freebsd_fsetxattr, -+ -+ /* aio operations */ -+ .aio_force_fn = freebsd_aio_force, -+}; -+ -+static_decl_vfs; -+NTSTATUS vfs_freebsd_init(TALLOC_CTX *ctx) -+{ -+ -+ if(freebsd_in_jail()) -+ is_secure = false; -+ -+ return smb_register_vfs(SMB_VFS_INTERFACE_VERSION, "freebsd", -+ &freebsd_fns); -+} Property changes on: head/net/samba48/files/patch-vfs_freebsd.c ___________________________________________________________________ Deleted: fbsd:nokeywords ## -1 +0,0 ## -yes \ No newline at end of property Deleted: svn:eol-style ## -1 +0,0 ## -native \ No newline at end of property Deleted: svn:mime-type ## -1 +0,0 ## -text/plain \ No newline at end of property Index: head/net/samba48/files/0001-bug-228462.patch =================================================================== --- head/net/samba48/files/0001-bug-228462.patch (revision 492473) +++ head/net/samba48/files/0001-bug-228462.patch (revision 492474) @@ -1,182 +1,76 @@ From d9b748869a8f4018ebee302aae8246bf29f60309 Mon Sep 17 00:00:00 2001 From: "Timur I. Bakeyev" Date: Fri, 1 Jun 2018 01:35:08 +0800 Subject: [PATCH 1/2] vfs_fruit: allow broken AFP_Signature where the first byte is 0 FreeBSD bug ... caused the first byte of the AFP_AfpInfo xattr to be 0 instead of 'A'. This hack allows such broken AFP_AfpInfo blobs to be parsed by afpinfo_unpack(). FreeBSD Bug: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=228462 Signed-off-by: Ralph Boehme --- source3/modules/vfs_fruit.c | 32 ++++++++++++++++++++++++-------- - 1 file changed, 24 insertions(+), 8 deletions(-) + 1 file changed, 27 insertions(+), 4 deletions(-) diff --git a/source3/modules/vfs_fruit.c b/source3/modules/vfs_fruit.c index df3cd0c899e..d84e6991036 100644 --- a/source3/modules/vfs_fruit.c +++ b/source3/modules/vfs_fruit.c -@@ -485,8 +485,9 @@ static int adouble_path(TALLOC_CTX *ctx, - struct smb_filename **ppsmb_fname_out); - static AfpInfo *afpinfo_new(TALLOC_CTX *ctx); - static ssize_t afpinfo_pack(const AfpInfo *ai, char *buf); --static AfpInfo *afpinfo_unpack(TALLOC_CTX *ctx, const void *data); -- -+static AfpInfo *afpinfo_unpack(TALLOC_CTX *ctx, -+ const void *data, -+ const struct smb_filename *smb_fname); - - /** - * Return a pointer to an AppleDouble entry -@@ -2073,13 +2074,17 @@ static ssize_t afpinfo_pack(const AfpInfo *ai, char *buf) +@@ -2350,6 +2350,8 @@ static ssize_t afpinfo_pack(const AfpInf return AFP_INFO_SIZE; } +#define BROKEN_FREEBSD_AFP_Signature 0x00465000 + /** * Unpack a buffer into a AfpInfo structure * - * Buffer size must be at least AFP_INFO_SIZE - * Returns allocated AfpInfo struct - **/ --static AfpInfo *afpinfo_unpack(TALLOC_CTX *ctx, const void *data) -+static AfpInfo *afpinfo_unpack(TALLOC_CTX *ctx, -+ const void *data, -+ const struct smb_filename *smb_fname) - { - AfpInfo *ai = talloc_zero(ctx, AfpInfo); - if (ai == NULL) { -@@ -2092,10 +2097,21 @@ static AfpInfo *afpinfo_unpack(TALLOC_CTX *ctx, const void *data) +@@ -2369,10 +2371,20 @@ static AfpInfo *afpinfo_unpack(TALLOC_CT memcpy(ai->afpi_FinderInfo, (const char *)data + 16, sizeof(ai->afpi_FinderInfo)); - if (ai->afpi_Signature != AFP_Signature - || ai->afpi_Version != AFP_Version) { - DEBUG(1, ("Bad AfpInfo signature or version\n")); + if (ai->afpi_Signature != AFP_Signature) { -+ DBG_WARNING("Bad signature [%x] on [%s]\n", -+ ai->afpi_Signature, smb_fname_str_dbg(smb_fname)); ++ DBG_WARNING("Bad AFP signature [%x]\n", ai->afpi_Signature); + + if (ai->afpi_Signature != BROKEN_FREEBSD_AFP_Signature) { + DBG_ERR("Bad AfpInfo signature\n"); + TALLOC_FREE(ai); + return NULL; + } + } + + if (ai->afpi_Version != AFP_Version) { + DBG_ERR("Bad AfpInfo version\n"); TALLOC_FREE(ai); + return NULL; } return ai; -@@ -4222,7 +4238,7 @@ static ssize_t fruit_pwrite_meta_stream(vfs_handle_struct *handle, - size_t nwritten; - bool ok; - -- ai = afpinfo_unpack(talloc_tos(), data); -+ ai = afpinfo_unpack(talloc_tos(), data, fsp->fsp_name); - if (ai == NULL) { - return -1; - } -@@ -4260,7 +4276,7 @@ static ssize_t fruit_pwrite_meta_netatalk(vfs_handle_struct *handle, - int ret; - bool ok; - -- ai = afpinfo_unpack(talloc_tos(), data); -+ ai = afpinfo_unpack(talloc_tos(), data, fsp->fsp_name); - if (ai == NULL) { - return -1; - } --- -2.16.3 - - -From 83ce03a278ec9d15b595f4daf8da1641d27ebdd6 Mon Sep 17 00:00:00 2001 -From: "Timur I. Bakeyev" -Date: Fri, 1 Jun 2018 01:35:58 +0800 -Subject: [PATCH 2/2] vfs_streams_xattr: don't append 0 byte when creating - xattr - -Upstream Samba always appends an internal 0-byte to xattrs to cope -with filesytems or systems that don't support 0-byte sized xattrs. - -An older patch already remove this behaviour from the read and write -code paths, but didn't remove it from the create codepath. - -FreeBSD Bug: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=228462 - -Signed-off-by: Ralph Boehme ---- - source3/modules/vfs_streams_xattr.c | 8 +------- - 1 file changed, 1 insertion(+), 7 deletions(-) - -diff --git a/source3/modules/vfs_streams_xattr.c b/source3/modules/vfs_streams_xattr.c -index 8714007cb8d..5f3dfb30beb 100644 ---- a/source3/modules/vfs_streams_xattr.c -+++ b/source3/modules/vfs_streams_xattr.c -@@ -476,19 +476,13 @@ static int streams_xattr_open(vfs_handle_struct *handle, - /* - * The attribute does not exist or needs to be truncated - */ -- -- /* -- * Darn, xattrs need at least 1 byte -- */ -- char null = '\0'; -- - DEBUG(10, ("creating or truncating attribute %s on file %s\n", - xattr_name, smb_fname->base_name)); - - ret = SMB_VFS_SETXATTR(fsp->conn, - smb_fname, - xattr_name, -- &null, sizeof(null), -+ NULL, 0, - flags & O_EXCL ? XATTR_CREATE : 0); - if (ret != 0) { - goto fail; --- -2.16.3 - -From daa9930fc10459f0567931622e2ffbb636e365f0 Mon Sep 17 00:00:00 2001 -From: Ralph Boehme -Date: Sat, 19 May 2018 01:35:45 +0200 -Subject: [PATCH] vfs_fruit: fixup broken AFP_Signatures - -FreeBSD Bug: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=228462 - -Signed-off-by: Ralph Boehme ---- - source3/modules/vfs_fruit.c | 6 ++++++ - 1 file changed, 6 insertions(+) - -diff --git a/source3/modules/vfs_fruit.c b/source3/modules/vfs_fruit.c -index d92049cc899..0594fd7a538 100644 ---- a/source3/modules/vfs_fruit.c -+++ b/source3/modules/vfs_fruit.c -@@ -3935,10 +3935,16 @@ static ssize_t fruit_pread_meta_stream(vfs_handle_struct *handle, +@@ -4171,9 +4183,20 @@ static ssize_t fruit_pread_meta_stream(v { ssize_t nread; int ret; + char *p = (char *)data; nread = SMB_VFS_NEXT_PREAD(handle, fsp, data, n, offset); - - if (nread == n) { +- if (nread == -1 || nread == n) { ++ ++ if (nread == -1) { ++ return -1; ++ } ++ ++ if (nread == n) { + if (offset == 0 && nread > 3 && p[0] == 0 && p[1] == 'F' && p[2] == 'P') { + DBG_NOTICE("Fixing AFP_Info of [%s]\n", + fsp_str_dbg(fsp)); + p[0] = 'A'; + } return nread; } --- -2.17.0 - Index: head/net/samba48/files/patch-python_samba_provision_sambadns.py =================================================================== --- head/net/samba48/files/patch-python_samba_provision_sambadns.py (nonexistent) +++ head/net/samba48/files/patch-python_samba_provision_sambadns.py (revision 492474) @@ -0,0 +1,29 @@ +--- python/samba/provision/sambadns.py.orig 2018-01-17 09:08:39 UTC ++++ python/samba/provision/sambadns.py +@@ -937,6 +937,7 @@ def create_named_conf(paths, realm, dnsd + bind9_9 = '#' + bind9_10 = '#' + bind9_11 = '#' ++ bind9_12 = '#' + if bind_info.upper().find('BIND 9.8') != -1: + bind9_8 = '' + elif bind_info.upper().find('BIND 9.9') != -1: +@@ -945,6 +946,8 @@ def create_named_conf(paths, realm, dnsd + bind9_10 = '' + elif bind_info.upper().find('BIND 9.11') != -1: + bind9_11 = '' ++ elif bind_info.upper().find('BIND 9.12') != -1: ++ bind9_12 = '' + elif bind_info.upper().find('BIND 9.7') != -1: + raise ProvisioningError("DLZ option incompatible with BIND 9.7.") + else: +@@ -955,7 +958,8 @@ def create_named_conf(paths, realm, dnsd + "BIND9_8" : bind9_8, + "BIND9_9" : bind9_9, + "BIND9_10" : bind9_10, +- "BIND9_11" : bind9_11 ++ "BIND9_11" : bind9_11, ++ "BIND9_12" : bind9_12 + }) + + Property changes on: head/net/samba48/files/patch-python_samba_provision_sambadns.py ___________________________________________________________________ Added: fbsd:nokeywords ## -0,0 +1 ## +yes \ No newline at end of property Added: svn:eol-style ## -0,0 +1 ## +native \ No newline at end of property Added: svn:mime-type ## -0,0 +1 ## +text/plain \ No newline at end of property Index: head/net/samba48/files/patch-source3__lib__sysquotas_4B.c =================================================================== --- head/net/samba48/files/patch-source3__lib__sysquotas_4B.c (nonexistent) +++ head/net/samba48/files/patch-source3__lib__sysquotas_4B.c (revision 492474) @@ -0,0 +1,18 @@ +--- source3/lib/sysquotas_4B.c.orig 2019-01-28 03:56:23 UTC ++++ source3/lib/sysquotas_4B.c +@@ -141,7 +141,14 @@ static int sys_quotactl_4B(const char * + /* ENOTSUP means quota support is not compiled in. EINVAL + * means that quotas are not configured (commonly). + */ +- if (errno != ENOTSUP && errno != EINVAL) { ++ if (errno != ENOTSUP && errno != EINVAL ++/* ++ * FreeBSD 12 between r336017 and r342928 wrongfuly return ENOENT for the not enabled qoutas on ZFS. ++ */ ++#if defined(__FreeBSD__) && ((__FreeBSD_version >= 1102503 && __FreeBSD_version <= 1102506) || (__FreeBSD_version >= 1200072 && __FreeBSD_version <= 1200503) || (__FreeBSD_version >= 1300000 && __FreeBSD_version <= 1300009)) ++ && errno != ENOENT ++#endif ++ ) { + DEBUG(0, ("failed to %s quota for %s ID %u on %s: %s\n", + (cmd & QCMD(Q_GETQUOTA, 0)) ? "get" : "set", + (cmd & QCMD(0, GRPQUOTA)) ? "group" : "user", Property changes on: head/net/samba48/files/patch-source3__lib__sysquotas_4B.c ___________________________________________________________________ Added: fbsd:nokeywords ## -0,0 +1 ## +yes \ No newline at end of property Added: svn:eol-style ## -0,0 +1 ## +native \ No newline at end of property Added: svn:mime-type ## -0,0 +1 ## +text/plain \ No newline at end of property Index: head/net/samba48/files/patch-source3_modules_vfs__freebsd.c =================================================================== --- head/net/samba48/files/patch-source3_modules_vfs__freebsd.c (nonexistent) +++ head/net/samba48/files/patch-source3_modules_vfs__freebsd.c (revision 492474) @@ -0,0 +1,798 @@ +--- /dev/null 2018-11-29 02:13:13 UTC ++++ source3/modules/vfs_freebsd.c +@@ -0,0 +1,795 @@ ++/* ++ * This module implements VFS calls specific to FreeBSD ++ * ++ * Copyright (C) Timur I. Bakeyev, 2018 ++ * ++ * 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 . ++ */ ++ ++#include "includes.h" ++ ++#include "lib/util/tevent_unix.h" ++#include "lib/util/tevent_ntstatus.h" ++#include "system/filesys.h" ++ ++#include ++ ++static int vfs_freebsd_debug_level = DBGC_VFS; ++ ++#undef DBGC_CLASS ++#define DBGC_CLASS vfs_freebsd_debug_level ++ ++#ifndef EXTATTR_MAXNAMELEN ++#define EXTATTR_MAXNAMELEN UINT8_MAX ++#endif ++ ++#define EXTATTR_NAMESPACE(NS) EXTATTR_NAMESPACE_ ## NS, \ ++ EXTATTR_NAMESPACE_ ## NS ## _STRING ".", \ ++ .data.len = (sizeof(EXTATTR_NAMESPACE_ ## NS ## _STRING ".") - 1) ++ ++#define EXTATTR_EMPTY 0x00 ++#define EXTATTR_USER 0x01 ++#define EXTATTR_SYSTEM 0x02 ++#define EXTATTR_SECURITY 0x03 ++#define EXTATTR_TRUSTED 0x04 ++ ++enum extattr_mode { ++ FREEBSD_EXTATTR_SECURE, ++ FREEBSD_EXTATTR_COMPAT, ++ FREEBSD_EXTATTR_LEGACY ++}; ++ ++typedef struct { ++ int namespace; ++ char name[EXTATTR_MAXNAMELEN+1]; ++ union { ++ uint16_t len; ++ uint16_t flags; ++ } data; ++} extattr_attr; ++ ++typedef struct { ++ enum { ++ EXTATTR_FILE, EXTATTR_LINK, EXTATTR_FDES ++ } method; ++ union { ++ const char *path; ++ int filedes; ++ } param; ++} extattr_arg; ++ ++static const struct enum_list extattr_mode_param[] = { ++ { FREEBSD_EXTATTR_SECURE, "secure" }, /* */ ++ { FREEBSD_EXTATTR_COMPAT, "compat" }, /* */ ++ { FREEBSD_EXTATTR_LEGACY, "legacy" }, /* */ ++ { -1, NULL } ++}; ++ ++ ++/* */ ++struct freebsd_handle_data { ++ enum extattr_mode extattr_mode; ++}; ++ ++ ++/* XXX: This order doesn't match namespace ids order! */ ++static extattr_attr extattr[] = { ++ { EXTATTR_NAMESPACE(EMPTY) }, ++ { EXTATTR_NAMESPACE(SYSTEM) }, ++ { EXTATTR_NAMESPACE(USER) }, ++}; ++ ++ ++static bool freebsd_in_jail(void) { ++ int val = 0; ++ size_t val_len = sizeof(val); ++ ++ if((sysctlbyname("security.jail.jailed", &val, &val_len, NULL, 0) != -1) && val == 1) { ++ return true; ++ } ++ return false; ++} ++ ++static uint16_t freebsd_map_attrname(const char *name) ++{ ++ if(name == NULL || name[0] == '\0') { ++ return EXTATTR_EMPTY; ++ } ++ ++ switch(name[0]) { ++ case 'u': ++ if(strncmp(name, "user.", 5) == 0) ++ return EXTATTR_USER; ++ break; ++ case 't': ++ if(strncmp(name, "trusted.", 8) == 0) ++ return EXTATTR_TRUSTED; ++ break; ++ case 's': ++ /* name[1] could be any character, including '\0' */ ++ switch(name[1]) { ++ case 'e': ++ if(strncmp(name, "security.", 9) == 0) ++ return EXTATTR_SECURITY; ++ break; ++ case 'y': ++ if(strncmp(name, "system.", 7) == 0) ++ return EXTATTR_SYSTEM; ++ break; ++ } ++ break; ++ } ++ return EXTATTR_USER; ++} ++ ++/* security, system, trusted or user */ ++static extattr_attr* freebsd_map_xattr(enum extattr_mode extattr_mode, const char *name, extattr_attr *attr) ++{ ++ int attrnamespace = EXTATTR_NAMESPACE_EMPTY; ++ const char *attrname = name; ++ ++ if(name == NULL || name[0] == '\0') { ++ return NULL; ++ } ++ ++ if(attr == NULL) { ++ return NULL; ++ } ++ ++ uint16_t flags = freebsd_map_attrname(name); ++ ++ switch(flags) { ++ case EXTATTR_USER: ++ attrnamespace = EXTATTR_NAMESPACE_USER; ++ if(extattr_mode == FREEBSD_EXTATTR_LEGACY) ++ attrname = name + 5; ++ break; ++ case EXTATTR_SECURITY: ++ case EXTATTR_TRUSTED: ++ attrnamespace = (extattr_mode == FREEBSD_EXTATTR_SECURE) ? ++ EXTATTR_NAMESPACE_SYSTEM : ++ EXTATTR_NAMESPACE_USER; ++ break; ++ case EXTATTR_SYSTEM: ++ attrnamespace = (extattr_mode == FREEBSD_EXTATTR_SECURE) ? ++ EXTATTR_NAMESPACE_SYSTEM : ++ EXTATTR_NAMESPACE_USER; ++ if (extattr_mode == FREEBSD_EXTATTR_LEGACY) ++ attrname = name + 7; ++ break; ++ default: ++ /* Default to "user" namespace if nothing else was specified */ ++ attrnamespace = EXTATTR_NAMESPACE_USER; ++ flags = EXTATTR_USER; ++ } ++ ++ attr->namespace = attrnamespace; ++ attr->data.flags = flags; ++ strlcpy(attr->name, attrname, EXTATTR_MAXNAMELEN+1); ++ ++ return attr; ++} ++ ++static ssize_t extattr_size(extattr_arg arg, extattr_attr *attr) ++{ ++ ssize_t result; ++ ++ switch(arg.method) { ++#if defined(HAVE_EXTATTR_GET_FILE) ++ case EXTATTR_FILE: ++ result = extattr_get_file(arg.param.path, attr->namespace, attr->name, NULL, 0); ++ break; ++#endif ++#if defined(HAVE_EXTATTR_GET_LINK) ++ case EXTATTR_LINK: ++ result = extattr_get_link(arg.param.path, attr->namespace, attr->name, NULL, 0); ++ break; ++#endif ++#if defined(HAVE_EXTATTR_GET_FD) ++ case EXTATTR_FDES: ++ result = extattr_get_fd(arg.param.filedes, attr->namespace, attr->name, NULL, 0); ++ break; ++#endif ++ default: ++ errno = ENOSYS; ++ return -1; ++ } ++ ++ if(result < 0) { ++ errno = EINVAL; ++ return -1; ++ } ++ ++ return result; ++} ++ ++ ++/* ++ * The list of names is returned as an unordered array of NULL-terminated ++ * character strings (attribute names are separated by NULL characters), ++ * like this: ++ * user.name1\0system.name1\0user.name2\0 ++ * ++ * Filesystems like ext2, ext3 and XFS which implement POSIX ACLs using ++ * extended attributes, might return a list like this: ++ * system.posix_acl_access\0system.posix_acl_default\0 ++ */ ++/* ++ * The extattr_list_file() returns a list of attributes present in the ++ * requested namespace. Each list entry consists of a single byte containing ++ * the length of the attribute name, followed by the attribute name. The ++ * attribute name is not terminated by ASCII 0 (nul). ++*/ ++ ++static ssize_t freebsd_extattr_list(extattr_arg arg, enum extattr_mode extattr_mode, char *list, size_t size) ++{ ++ ssize_t list_size, total_size = 0; ++ char *p, *q, *list_end; ++ int len; ++ /* ++ Ignore all but user namespace when we are not root or in jail ++ See: https://bugzilla.samba.org/show_bug.cgi?id=10247 ++ */ ++ bool as_root = (geteuid() == 0); ++ ++ int ns = (extattr_mode == FREEBSD_EXTATTR_SECURE && as_root) ? 1 : 2; ++ ++ /* Iterate through extattr(2) namespaces */ ++ for(; ns < ARRAY_SIZE(extattr); ns++) { ++ switch(arg.method) { ++#if defined(HAVE_EXTATTR_LIST_FILE) ++ case EXTATTR_FILE: ++ list_size = extattr_list_file(arg.param.path, extattr[ns].namespace, list, size); ++ break; ++#endif ++#if defined(HAVE_EXTATTR_LIST_LINK) ++ case EXTATTR_LINK: ++ list_size = extattr_list_link(arg.param.path, extattr[ns].namespace, list, size); ++ break; ++#endif ++#if defined(HAVE_EXTATTR_LIST_FD) ++ case EXTATTR_FDES: ++ list_size = extattr_list_fd(arg.param.filedes, extattr[ns].namespace, list, size); ++ break; ++#endif ++ default: ++ errno = ENOSYS; ++ return -1; ++ } ++ /* Some error happend. Errno should be set by the previous call */ ++ if(list_size < 0) ++ return -1; ++ /* No attributes in this namespace */ ++ if(list_size == 0) ++ continue; ++ /* ++ Call with an empty buffer may be used to calculate ++ necessary buffer size. ++ */ ++ if(list == NULL) { ++ /* ++ XXX: Unfortunately, we can't say, how many attributes were ++ returned, so here is the potential problem with the emulation. ++ */ ++ if(extattr_mode == FREEBSD_EXTATTR_LEGACY) { ++ /* ++ Take the worse case of one char attribute names - ++ two bytes per name plus one more for sanity. ++ */ ++ total_size += list_size + (list_size/2 + 1)*extattr[ns].data.len; ++ } ++ else { ++ total_size += list_size; ++ } ++ continue; ++ } ++ ++ if(extattr_mode == FREEBSD_EXTATTR_LEGACY) { ++ /* Count necessary offset to fit namespace prefixes */ ++ int extra_len = 0; ++ uint16_t flags; ++ list_end = list + list_size; ++ for(list_size = 0, p = q = list; p < list_end; p += len) { ++ len = p[0] + 1; ++ (void)strlcpy(q, p + 1, len); ++ flags = freebsd_map_attrname(q); ++ /* Skip secure attributes for non-root user */ ++ if(extattr_mode != FREEBSD_EXTATTR_SECURE && !as_root && flags > EXTATTR_USER) { ++ continue; ++ } ++ if(flags <= EXTATTR_USER) { ++ /* Don't count trailing '\0' */ ++ extra_len += extattr[ns].data.len; ++ } ++ list_size += len; ++ q += len; ++ } ++ total_size += list_size + extra_len; ++ /* Buffer is too small to fit the results */ ++ if(total_size > size) { ++ errno = ERANGE; ++ return -1; ++ } ++ /* Shift results backwards, so we can prepend prefixes */ ++ list_end = list + extra_len; ++ p = (char*)memmove(list_end, list, list_size); ++ /* ++ We enter the loop with `p` pointing to the shifted list and ++ `extra_len` having the total margin between `list` and `p` ++ */ ++ for(list_end += list_size; p < list_end; p += len) { ++ len = strlen(p) + 1; ++ flags = freebsd_map_attrname(p); ++ if(flags <= EXTATTR_USER) { ++ /* Add namespace prefix */ ++ (void)strncpy(list, extattr[ns].name, extattr[ns].data.len); ++ list += extattr[ns].data.len; ++ } ++ /* Append attribute name */ ++ (void)strlcpy(list, p, len); ++ list += len; ++ } ++ } ++ else { ++ /* Convert UCSD strings into nul-terminated strings */ ++ for(list_end = list + list_size; list < list_end; list += len) { ++ len = list[0] + 1; ++ (void)strlcpy(list, list + 1, len); ++ } ++ total_size += list_size; ++ } ++ } ++ return total_size; ++} ++ ++/* ++static ssize_t freebsd_getxattr_size(vfs_handle_struct *handle, ++ const struct smb_filename *smb_fname, ++ const char *name) ++{ ++ struct freebsd_handle_data *data; ++ extattr_arg arg = { EXTATTR_FILE, smb_fname->base_name }; ++ extattr_attr attr; ++ ++ ++ SMB_VFS_HANDLE_GET_DATA(handle, data, ++ struct freebsd_handle_data, ++ return -1); ++ ++ if(!freebsd_map_xattr(data->extattr_mode, name, &attr)) { ++ errno = EINVAL; ++ return -1; ++ } ++ ++ if(data->extattr_mode != FREEBSD_EXTATTR_SECURE && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { ++ errno = ENOATTR; ++ return -1; ++ } ++ ++ return extattr_size(arg, &attr); ++} ++*/ ++ ++/* VFS entries */ ++static ssize_t freebsd_getxattr(vfs_handle_struct *handle, ++ const struct smb_filename *smb_fname, ++ const char *name, ++ void *value, ++ size_t size) ++{ ++#if defined(HAVE_EXTATTR_GET_FILE) ++ struct freebsd_handle_data *data; ++ extattr_arg arg = { EXTATTR_FILE, .param.path = smb_fname->base_name }; ++ extattr_attr attr; ++ ssize_t res; ++ ++ SMB_VFS_HANDLE_GET_DATA(handle, data, ++ struct freebsd_handle_data, ++ return -1); ++ ++ if(!freebsd_map_xattr(data->extattr_mode, name, &attr)) { ++ errno = EINVAL; ++ return -1; ++ } ++ ++ /* Filter out 'secure' entries */ ++ if(data->extattr_mode != FREEBSD_EXTATTR_SECURE && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { ++ errno = ENOATTR; ++ return -1; ++ } ++ ++ /* ++ * The BSD implementation has a nasty habit of silently truncating ++ * the returned value to the size of the buffer, so we have to check ++ * that the buffer is large enough to fit the returned value. ++ */ ++ if((res=extattr_size(arg, &attr)) < 0) { ++ return -1; ++ } ++ ++ if (size == 0) { ++ return res; ++ } ++ else if (res > size) { ++ errno = ERANGE; ++ return -1; ++ } ++ ++ if((res=extattr_get_file(smb_fname->base_name, attr.namespace, attr.name, value, size)) >= 0) { ++ return res; ++ } ++ return -1; ++#else ++ errno = ENOSYS; ++ return -1; ++#endif ++} ++ ++ ++static ssize_t freebsd_fgetxattr(vfs_handle_struct *handle, ++ struct files_struct *fsp, const char *name, ++ void *value, size_t size) ++{ ++#if defined(HAVE_EXTATTR_GET_FD) ++ struct freebsd_handle_data *data; ++ extattr_arg arg = { EXTATTR_FDES, .param.filedes = fsp->fh->fd }; ++ extattr_attr attr; ++ ssize_t res; ++ ++ SMB_VFS_HANDLE_GET_DATA(handle, data, ++ struct freebsd_handle_data, ++ return -1); ++ ++ if(!freebsd_map_xattr(data->extattr_mode, name, &attr)) { ++ errno = EINVAL; ++ return -1; ++ } ++ ++ /* Filter out 'secure' entries */ ++ if(data->extattr_mode != FREEBSD_EXTATTR_SECURE && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { ++ errno = ENOATTR; ++ return -1; ++ } ++ ++ /* ++ * The BSD implementation has a nasty habit of silently truncating ++ * the returned value to the size of the buffer, so we have to check ++ * that the buffer is large enough to fit the returned value. ++ */ ++ if((res=extattr_size(arg, &attr)) < 0) { ++ return -1; ++ } ++ ++ if (size == 0) { ++ return res; ++ } ++ else if (res > size) { ++ errno = ERANGE; ++ return -1; ++ } ++ ++ if((res=extattr_get_fd(fsp->fh->fd, attr.namespace, attr.name, value, size)) >= 0) { ++ return res; ++ } ++ return -1; ++#else ++ errno = ENOSYS; ++ return -1; ++#endif ++} ++ ++ ++static ssize_t freebsd_listxattr(vfs_handle_struct *handle, ++ const struct smb_filename *smb_fname, ++ char *list, ++ size_t size) ++{ ++#if defined(HAVE_EXTATTR_LIST_FILE) ++ struct freebsd_handle_data *data; ++ ++ SMB_VFS_HANDLE_GET_DATA(handle, data, ++ struct freebsd_handle_data, ++ return -1); ++ ++ extattr_arg arg = { EXTATTR_FILE, .param.path = smb_fname->base_name }; ++ ++ return freebsd_extattr_list(arg, data->extattr_mode, list, size); ++#else ++ errno = ENOSYS; ++ return -1; ++#endif ++} ++ ++ ++static ssize_t freebsd_flistxattr(vfs_handle_struct *handle, ++ struct files_struct *fsp, char *list, ++ size_t size) ++{ ++#if defined(HAVE_EXTATTR_LIST_FD) ++ struct freebsd_handle_data *data; ++ extattr_arg arg = { EXTATTR_FDES, .param.filedes = fsp->fh->fd }; ++ ++ SMB_VFS_HANDLE_GET_DATA(handle, data, ++ struct freebsd_handle_data, ++ return -1); ++ ++ return freebsd_extattr_list(arg, data->extattr_mode, list, size); ++#else ++ errno = ENOSYS; ++ return -1; ++#endif ++} ++ ++static int freebsd_removexattr(vfs_handle_struct *handle, ++ const struct smb_filename *smb_fname, ++ const char *name) ++{ ++#if defined(HAVE_EXTATTR_DELETE_FILE) ++ struct freebsd_handle_data *data; ++ extattr_attr attr; ++ ++ SMB_VFS_HANDLE_GET_DATA(handle, data, ++ struct freebsd_handle_data, ++ return -1); ++ ++ ++ /* Filter out 'secure' entries */ ++ if(data->extattr_mode != FREEBSD_EXTATTR_SECURE && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { ++ errno = ENOATTR; ++ return -1; ++ } ++ ++ return extattr_delete_file(smb_fname->base_name, attr.namespace, attr.name); ++#else ++ errno = ENOSYS; ++ return -1; ++#endif ++} ++ ++ ++static int freebsd_fremovexattr(vfs_handle_struct *handle, ++ struct files_struct *fsp, const char *name) ++{ ++#if defined(HAVE_EXTATTR_DELETE_FD) ++ struct freebsd_handle_data *data; ++ extattr_attr attr; ++ ++ SMB_VFS_HANDLE_GET_DATA(handle, data, ++ struct freebsd_handle_data, ++ return -1); ++ ++ if(!freebsd_map_xattr(data->extattr_mode, name, &attr)) { ++ errno = EINVAL; ++ return -1; ++ } ++ ++ /* Filter out 'secure' entries */ ++ if(data->extattr_mode != FREEBSD_EXTATTR_SECURE && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { ++ errno = ENOATTR; ++ return -1; ++ } ++ ++ return extattr_delete_fd(fsp->fh->fd, attr.namespace, attr.name); ++#else ++ errno = ENOSYS; ++ return -1; ++#endif ++} ++ ++ ++static int freebsd_setxattr(vfs_handle_struct *handle, ++ const struct smb_filename *smb_fname, ++ const char *name, ++ const void *value, ++ size_t size, ++ int flags) ++{ ++#if defined(HAVE_EXTATTR_SET_FILE) ++ struct freebsd_handle_data *data; ++ extattr_attr attr; ++ ssize_t res; ++ ++ SMB_VFS_HANDLE_GET_DATA(handle, data, ++ struct freebsd_handle_data, ++ return -1); ++ ++ if(!freebsd_map_xattr(data->extattr_mode, name, &attr)) { ++ errno = EINVAL; ++ return -1; ++ } ++ ++ /* Filter out 'secure' entries */ ++ if(data->extattr_mode != FREEBSD_EXTATTR_SECURE && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { ++ errno = ENOATTR; ++ return -1; ++ } ++ ++ if (flags) { ++ extattr_arg arg = { EXTATTR_FILE, .param.path = smb_fname->base_name }; ++ /* Check attribute existence */ ++ res = extattr_size(arg, &attr); ++ if (res < 0) { ++ /* REPLACE attribute, that doesn't exist */ ++ if ((flags & XATTR_REPLACE) && errno == ENOATTR) { ++ errno = ENOATTR; ++ return -1; ++ } ++ /* Ignore other errors */ ++ } ++ else { ++ /* CREATE attribute, that already exists */ ++ if (flags & XATTR_CREATE) { ++ errno = EEXIST; ++ return -1; ++ } ++ } ++ } ++ res = extattr_set_file(smb_fname->base_name, attr.namespace, attr.name, value, size); ++ ++ return (res >= 0) ? 0 : -1; ++#else ++ errno = ENOSYS; ++ return -1; ++#endif ++} ++ ++ ++static int freebsd_fsetxattr(vfs_handle_struct *handle, struct files_struct *fsp, ++ const char *name, const void *value, size_t size, ++ int flags) ++{ ++#if defined(HAVE_EXTATTR_SET_FD) ++ struct freebsd_handle_data *data; ++ extattr_attr attr; ++ ssize_t res; ++ ++ SMB_VFS_HANDLE_GET_DATA(handle, data, ++ struct freebsd_handle_data, ++ return -1); ++ ++ if(!freebsd_map_xattr(data->extattr_mode, name, &attr)) { ++ errno = EINVAL; ++ return -1; ++ } ++ ++ /* Filter out 'secure' entries */ ++ if(data->extattr_mode != FREEBSD_EXTATTR_SECURE && geteuid() != 0 && attr.data.flags > EXTATTR_USER) { ++ errno = ENOATTR; ++ return -1; ++ } ++ ++ if (flags) { ++ extattr_arg arg = { EXTATTR_FDES, .param.filedes = fsp->fh->fd }; ++ /* Check attribute existence */ ++ res = extattr_size(arg, &attr); ++ if (res < 0) { ++ /* REPLACE attribute, that doesn't exist */ ++ if ((flags & XATTR_REPLACE) && errno == ENOATTR) { ++ errno = ENOATTR; ++ return -1; ++ } ++ /* Ignore other errors */ ++ } ++ else { ++ /* CREATE attribute, that already exists */ ++ if (flags & XATTR_CREATE) { ++ errno = EEXIST; ++ return -1; ++ } ++ } ++ } ++ ++ res = extattr_set_fd(fsp->fh->fd, attr.namespace, attr.name, value, size); ++ ++ return (res >= 0) ? 0 : -1; ++#else ++ errno = ENOSYS; ++ return -1; ++#endif ++} ++ ++static int freebsd_connect(vfs_handle_struct *handle, const char *service, ++ const char *user) ++{ ++ struct freebsd_handle_data *data; ++ int enumval, saved_errno; ++ ++ int ret = SMB_VFS_NEXT_CONNECT(handle, service, user); ++ ++ if (ret < 0) { ++ return ret; ++ } ++ ++ data = talloc_zero(handle->conn, struct freebsd_handle_data); ++ if (!data) { ++ saved_errno = errno; ++ SMB_VFS_NEXT_DISCONNECT(handle); ++ DEBUG(0, ("talloc_zero() failed\n")); ++ errno = saved_errno; ++ return -1; ++ } ++ ++ enumval = lp_parm_enum(SNUM(handle->conn), "freebsd", ++ "extattr mode", extattr_mode_param, FREEBSD_EXTATTR_LEGACY); ++ if (enumval == -1) { ++ saved_errno = errno; ++ SMB_VFS_NEXT_DISCONNECT(handle); ++ DBG_DEBUG("value for freebsd: 'extattr mode' is unknown\n"); ++ errno = saved_errno; ++ return -1; ++ } ++ ++ if(freebsd_in_jail()) { ++ enumval = FREEBSD_EXTATTR_COMPAT; ++ DBG_WARNING("running in jail, enforcing 'compat' mode\n"); ++ } ++ ++ data->extattr_mode = (enum extattr_mode)enumval; ++ ++ SMB_VFS_HANDLE_SET_DATA(handle, data, NULL, ++ struct freebsd_handle_data, ++ return -1); ++ ++ DBG_DEBUG("connect to service[%s] with '%s' extattr mode\n", ++ service, extattr_mode_param[data->extattr_mode].name); ++ ++ return 0; ++} ++ ++static void freebsd_disconnect(vfs_handle_struct *handle) ++{ ++ SMB_VFS_NEXT_DISCONNECT(handle); ++} ++ ++/* VFS operations structure */ ++ ++struct vfs_fn_pointers freebsd_fns = { ++ /* Disk operations */ ++ ++ .connect_fn = freebsd_connect, ++ .disconnect_fn = freebsd_disconnect, ++ ++ /* EA operations. */ ++ .getxattr_fn = freebsd_getxattr, ++ .fgetxattr_fn = freebsd_fgetxattr, ++ .listxattr_fn = freebsd_listxattr, ++ .flistxattr_fn = freebsd_flistxattr, ++ .removexattr_fn = freebsd_removexattr, ++ .fremovexattr_fn = freebsd_fremovexattr, ++ .setxattr_fn = freebsd_setxattr, ++ .fsetxattr_fn = freebsd_fsetxattr, ++}; ++ ++static_decl_vfs; ++NTSTATUS vfs_freebsd_init(TALLOC_CTX *ctx) ++{ ++ NTSTATUS ret; ++ ++ ret = smb_register_vfs(SMB_VFS_INTERFACE_VERSION, "freebsd", ++ &freebsd_fns); ++ ++ if (!NT_STATUS_IS_OK(ret)) { ++ return ret; ++ } ++ ++ vfs_freebsd_debug_level = debug_add_class("freebsd"); ++ if (vfs_freebsd_debug_level == -1) { ++ vfs_freebsd_debug_level = DBGC_VFS; ++ DEBUG(0, ("vfs_freebsd: Couldn't register custom debugging class!\n")); ++ } else { ++ DEBUG(10, ("vfs_freebsd: Debug class number of 'fileid': %d\n", vfs_freebsd_debug_level)); ++ } ++ ++ return ret; ++} Property changes on: head/net/samba48/files/patch-source3_modules_vfs__freebsd.c ___________________________________________________________________ Added: fbsd:nokeywords ## -0,0 +1 ## +yes \ No newline at end of property Added: svn:eol-style ## -0,0 +1 ## +native \ No newline at end of property Added: svn:mime-type ## -0,0 +1 ## +text/plain \ No newline at end of property Index: head/net/samba48/files/patch-source3_modules_vfs__streams__xattr.c =================================================================== --- head/net/samba48/files/patch-source3_modules_vfs__streams__xattr.c (nonexistent) +++ head/net/samba48/files/patch-source3_modules_vfs__streams__xattr.c (revision 492474) @@ -0,0 +1,526 @@ +--- source3/modules/vfs_streams_xattr.c.orig 2018-11-08 07:58:08 UTC ++++ source3/modules/vfs_streams_xattr.c +@@ -1,10 +1,10 @@ + /* + * Store streams in xattrs + * +- * Copyright (C) Volker Lendecke, 2008 ++ * Copyright (C) Volker Lendecke, 2008 ++ * Copyright (C) Timur I. Bakeyev, 2017 + * + * Partly based on James Peach's Darwin module, which is +- * + * Copyright (C) James Peach 2006-2007 + * + * This program is free software; you can redistribute it and/or modify +@@ -79,25 +79,79 @@ static SMB_INO_T stream_inode(const SMB_ + } + + static ssize_t get_xattr_size(connection_struct *conn, +- const struct smb_filename *smb_fname, +- const char *xattr_name) ++ const struct smb_filename *smb_fname, ++ const char *xattr_name) + { +- NTSTATUS status; +- struct ea_struct ea; + ssize_t result; + +- status = get_ea_value(talloc_tos(), conn, NULL, smb_fname, +- xattr_name, &ea); ++ result = SMB_VFS_GETXATTR(conn, smb_fname, xattr_name, NULL, 0); ++ // ? -1 ++ return result; ++} + +- if (!NT_STATUS_IS_OK(status)) { +- return -1; ++static NTSTATUS get_xattr_value(TALLOC_CTX *mem_ctx, ++ connection_struct *conn, ++ const struct smb_filename *smb_fname, ++ const char *ea_name, ++ struct ea_struct *pea) ++{ ++ ssize_t attr_size; ++ ++ attr_size = get_xattr_size(conn, smb_fname, ea_name); ++ ++ if (attr_size == -1) { ++ return map_nt_error_from_unix(errno); + } + +- result = ea.value.length-1; +- TALLOC_FREE(ea.value.data); +- return result; ++ pea->value = data_blob_talloc(mem_ctx, NULL, attr_size); ++ /* We may have xattr of a 0 size */ ++ if(pea->value.data == NULL && attr_size) { ++ DEBUG(5, ++ ("get_xattr_value: for EA '%s' failed to allocate %lu bytes\n", ++ ea_name, (unsigned long)attr_size) ++ ); ++ return NT_STATUS_NO_MEMORY; ++ } ++ ++ attr_size = SMB_VFS_GETXATTR(conn, smb_fname, ea_name, pea->value.data, pea->value.length); ++ ++ if (attr_size == -1) { ++ return map_nt_error_from_unix(errno); ++ } ++ ++ if(pea->value.length != attr_size) { ++ DEBUG(5, ++ ("get_xattr_value: for EA '%s' requested %lu, read %lu bytes\n", ++ ea_name, (unsigned long)pea->value.length, (unsigned long)attr_size) ++ ); ++ return NT_STATUS_UNSUCCESSFUL; ++ } ++ ++ DEBUG(10,("get_xattr_value: EA '%s' is of length %lu\n", ea_name, (unsigned long)attr_size)); ++ /* ++ * This can dump huge amount of data multiple times. For example ++ * for 1Mb ADS and chunk size 64Kb the same 1Mb dump will be ++ * logged 16 times! ++ */ ++ dump_data(50, (uint8_t *)pea->value.data, pea->value.length); ++ ++ pea->flags = 0; ++ // ? user. ++ if (strnequal(ea_name, "user.", 5)) { ++ pea->name = talloc_strdup(mem_ctx, &ea_name[5]); ++ } else { ++ pea->name = talloc_strdup(mem_ctx, ea_name); ++ } ++ ++ if (pea->name == NULL) { ++ data_blob_free(&pea->value); ++ return NT_STATUS_NO_MEMORY; ++ } ++ ++ return NT_STATUS_OK; + } + ++ + /** + * Given a stream name, populate xattr_name with the xattr name to use for + * accessing the stream. +@@ -114,6 +168,7 @@ static NTSTATUS streams_xattr_get_name(v + SMB_VFS_HANDLE_GET_DATA(handle, config, struct streams_xattr_config, + return NT_STATUS_UNSUCCESSFUL); + ++ // stream_name is passed as ':stream', so skip leading ':' + sname = talloc_strdup(ctx, stream_name + 1); + if (sname == NULL) { + return NT_STATUS_NO_MEMORY; +@@ -125,7 +180,7 @@ static NTSTATUS streams_xattr_get_name(v + * characters from their on-the-wire Unicode Private Range + * encoding to their native ASCII representation. + * +- * As as result the name of xattrs storing the streams (via ++ * As a result the name of xattrs storing the streams (via + * vfs_streams_xattr) may contain a colon, so we have to use + * strrchr_m() instead of strchr_m() for matching the stream + * type suffix. +@@ -157,7 +212,7 @@ static NTSTATUS streams_xattr_get_name(v + return NT_STATUS_NO_MEMORY; + } + +- DEBUG(10, ("xattr_name: %s, stream_name: %s\n", *xattr_name, ++ DEBUG(10, ("xattr_name: '%s', stream_name: '%s'\n", *xattr_name, + stream_name)); + + talloc_free(sname); +@@ -265,8 +320,8 @@ static int streams_xattr_fstat(vfs_handl + return -1; + } + +- sbuf->st_ex_size = get_xattr_size(handle->conn, +- smb_fname_base, io->xattr_name); ++ sbuf->st_ex_size = get_xattr_size(handle->conn, smb_fname_base, ++ io->xattr_name); + if (sbuf->st_ex_size == -1) { + TALLOC_FREE(smb_fname_base); + SET_STAT_INVALID(*sbuf); +@@ -441,10 +496,10 @@ static int streams_xattr_open(vfs_handle + goto fail; + } + +- status = get_ea_value(talloc_tos(), handle->conn, NULL, +- smb_fname, xattr_name, &ea); ++ status = get_xattr_value(talloc_tos(), handle->conn, ++ smb_fname, xattr_name, &ea); + +- DEBUG(10, ("get_ea_value returned %s\n", nt_errstr(status))); ++ DEBUG(10, ("get_xattr_value returned %s\n", nt_errstr(status))); + + if (!NT_STATUS_IS_OK(status)) { + if (!NT_STATUS_EQUAL(status, NT_STATUS_NOT_FOUND)) { +@@ -475,19 +530,13 @@ static int streams_xattr_open(vfs_handle + /* + * The attribute does not exist or needs to be truncated + */ +- +- /* +- * Darn, xattrs need at least 1 byte +- */ +- char null = '\0'; +- + DEBUG(10, ("creating or truncating attribute %s on file %s\n", + xattr_name, smb_fname->base_name)); + + ret = SMB_VFS_SETXATTR(fsp->conn, + smb_fname, + xattr_name, +- &null, sizeof(null), ++ NULL, 0, + flags & O_EXCL ? XATTR_CREATE : 0); + if (ret != 0) { + goto fail; +@@ -643,8 +692,8 @@ static int streams_xattr_rename(vfs_hand + } + + /* read the old stream */ +- status = get_ea_value(talloc_tos(), handle->conn, NULL, +- smb_fname_src, src_xattr_name, &ea); ++ status = get_xattr_value(talloc_tos(), handle->conn, ++ smb_fname_src, src_xattr_name, &ea); + if (!NT_STATUS_IS_OK(status)) { + errno = ENOENT; + goto fail; +@@ -731,14 +780,13 @@ static NTSTATUS walk_xattr_streams(vfs_h + continue; + } + +- status = get_ea_value(names, ++ status = get_xattr_value(names, + handle->conn, +- NULL, + smb_fname, + names[i], + &ea); + if (!NT_STATUS_IS_OK(status)) { +- DEBUG(10, ("Could not get ea %s for file %s: %s\n", ++ DEBUG(10, ("Could not get EA %s for file %s: %s\n", + names[i], + smb_fname->base_name, + nt_errstr(status))); +@@ -800,16 +848,17 @@ struct streaminfo_state { + NTSTATUS status; + }; + +-static bool collect_one_stream(struct ea_struct *ea, void *private_data) ++static bool collect_one_stream(struct ea_struct *pea, void *private_data) + { + struct streaminfo_state *state = + (struct streaminfo_state *)private_data; + ++ // ? -1 + if (!add_one_stream(state->mem_ctx, + &state->num_streams, &state->streams, +- ea->name, ea->value.length-1, ++ pea->name, pea->value.length, + smb_roundup(state->handle->conn, +- ea->value.length-1))) { ++ pea->value.length))) { + state->status = NT_STATUS_NO_MEMORY; + return false; + } +@@ -929,14 +978,17 @@ static ssize_t streams_xattr_pwrite(vfs_ + files_struct *fsp, const void *data, + size_t n, off_t offset) + { +- struct stream_io *sio = ++ struct stream_io *sio = + (struct stream_io *)VFS_FETCH_FSP_EXTENSION(handle, fsp); ++ struct smb_filename *smb_fname_base = NULL; ++ TALLOC_CTX *frame = NULL; ++ + struct ea_struct ea; + NTSTATUS status; +- struct smb_filename *smb_fname_base = NULL; + int ret; + +- DEBUG(10, ("streams_xattr_pwrite called for %d bytes\n", (int)n)); ++ DEBUG(10, ("streams_xattr_pwrite: offset=%lu, size=%lu\n", ++ (unsigned long)offset, (unsigned long)n)); + + if (sio == NULL) { + return SMB_VFS_NEXT_PWRITE(handle, fsp, data, n, offset); +@@ -946,6 +998,8 @@ static ssize_t streams_xattr_pwrite(vfs_ + return -1; + } + ++ frame = talloc_stackframe(); ++ + /* Create an smb_filename with stream_name == NULL. */ + smb_fname_base = synthetic_smb_fname(talloc_tos(), + sio->base, +@@ -953,39 +1007,55 @@ static ssize_t streams_xattr_pwrite(vfs_ + NULL, + fsp->fsp_name->flags); + if (smb_fname_base == NULL) { ++ TALLOC_FREE(frame); + errno = ENOMEM; + return -1; + } + +- status = get_ea_value(talloc_tos(), handle->conn, NULL, +- smb_fname_base, sio->xattr_name, &ea); +- if (!NT_STATUS_IS_OK(status)) { +- return -1; +- } +- +- if ((offset + n) > ea.value.length-1) { +- uint8_t *tmp; ++ status = get_xattr_value(talloc_tos(), handle->conn, ++ smb_fname_base, sio->xattr_name, &ea); + +- tmp = talloc_realloc(talloc_tos(), ea.value.data, uint8_t, +- offset + n + 1); ++ if (NT_STATUS_EQUAL(status, NT_STATUS_NOT_FOUND)) { ++ /* ++ * This can happen if we sit behind vfs_fruit: ++ * fruit_ftruncate calls UNLINK on an attribute ++ * truncating the "file" to zero length. A later ++ * pwrite faces a non-existing attribute, we need to ++ * cope with that here. ++ * ++ * This might be not the last word on this. ++ */ + +- if (tmp == NULL) { +- TALLOC_FREE(ea.value.data); +- errno = ENOMEM; +- return -1; +- } +- ea.value.data = tmp; +- ea.value.length = offset + n + 1; +- ea.value.data[offset+n] = 0; +- } ++ ea = (struct ea_struct) {0}; ++ ea.name = talloc_strdup(talloc_tos(), sio->xattr_name); ++ if (ea.name == NULL) { ++ TALLOC_FREE(frame); ++ errno = ENOMEM; ++ return -1; ++ } ++ status = NT_STATUS_OK; ++ } + +- memcpy(ea.value.data + offset, data, n); ++ if (!NT_STATUS_IS_OK(status)) { ++ TALLOC_FREE(frame); ++ return -1; ++ } ++ // ? -1 ++ if ((offset + n) > ea.value.length) { ++ if(!data_blob_realloc(talloc_tos(), &ea.value, offset + n)) { ++ TALLOC_FREE(frame); ++ errno = ENOMEM; ++ return -1; ++ } ++ } ++ memcpy(ea.value.data + offset, data, n); + + ret = SMB_VFS_SETXATTR(fsp->conn, + fsp->fsp_name, + sio->xattr_name, + ea.value.data, ea.value.length, 0); +- TALLOC_FREE(ea.value.data); ++ ++ TALLOC_FREE(frame); + + if (ret == -1) { + return -1; +@@ -998,15 +1068,17 @@ static ssize_t streams_xattr_pread(vfs_h + files_struct *fsp, void *data, + size_t n, off_t offset) + { +- struct stream_io *sio = ++ struct stream_io *sio = + (struct stream_io *)VFS_FETCH_FSP_EXTENSION(handle, fsp); ++ struct smb_filename *smb_fname_base = NULL; ++ TALLOC_CTX *frame = NULL; ++ + struct ea_struct ea; + NTSTATUS status; +- size_t length, overlap; +- struct smb_filename *smb_fname_base = NULL; ++ size_t overlap; + +- DEBUG(10, ("streams_xattr_pread: offset=%d, size=%d\n", +- (int)offset, (int)n)); ++ DEBUG(10, ("streams_xattr_pread: offset=%lu, size=%lu\n", ++ (unsigned long)offset, (unsigned long)n)); + + if (sio == NULL) { + return SMB_VFS_NEXT_PREAD(handle, fsp, data, n, offset); +@@ -1016,6 +1088,8 @@ static ssize_t streams_xattr_pread(vfs_h + return -1; + } + ++ frame = talloc_stackframe(); ++ + /* Create an smb_filename with stream_name == NULL. */ + smb_fname_base = synthetic_smb_fname(talloc_tos(), + sio->base, +@@ -1023,31 +1097,35 @@ static ssize_t streams_xattr_pread(vfs_h + NULL, + fsp->fsp_name->flags); + if (smb_fname_base == NULL) { ++ TALLOC_FREE(frame); + errno = ENOMEM; + return -1; + } + +- status = get_ea_value(talloc_tos(), handle->conn, NULL, +- smb_fname_base, sio->xattr_name, &ea); ++ status = get_xattr_value(talloc_tos(), handle->conn, ++ smb_fname_base, sio->xattr_name, &ea); + if (!NT_STATUS_IS_OK(status)) { ++ TALLOC_FREE(frame); + return -1; + } ++ // ? -1 ++ //length = ea.value.length-1; + +- length = ea.value.length-1; ++ DEBUG(10, ("streams_xattr_pread: get_xattr_value() returned %lu bytes\n", ++ (unsigned long)ea.value.length)); + +- DEBUG(10, ("streams_xattr_pread: get_ea_value returned %d bytes\n", +- (int)length)); ++ /* Attempt to read past EOF. */ ++ if (ea.value.length <= offset) { ++ TALLOC_FREE(frame); ++ return 0; ++ } + +- /* Attempt to read past EOF. */ +- if (length <= offset) { +- return 0; +- } ++ overlap = (offset + n) > ea.value.length ? (ea.value.length - offset) : n; ++ memcpy(data, ea.value.data + offset, overlap); + +- overlap = (offset + n) > length ? (length - offset) : n; +- memcpy(data, ea.value.data + offset, overlap); ++ TALLOC_FREE(frame); + +- TALLOC_FREE(ea.value.data); +- return overlap; ++ return overlap; + } + + struct streams_xattr_pread_state { +@@ -1214,16 +1292,18 @@ static int streams_xattr_ftruncate(struc + struct files_struct *fsp, + off_t offset) + { +- int ret; +- uint8_t *tmp; +- struct ea_struct ea; +- NTSTATUS status; +- struct stream_io *sio = ++ struct stream_io *sio = + (struct stream_io *)VFS_FETCH_FSP_EXTENSION(handle, fsp); + struct smb_filename *smb_fname_base = NULL; ++ TALLOC_CTX *frame = NULL; + +- DEBUG(10, ("streams_xattr_ftruncate called for file %s offset %.0f\n", +- fsp_str_dbg(fsp), (double)offset)); ++ struct ea_struct ea; ++ NTSTATUS status; ++ size_t orig_length; ++ int ret; ++ ++ DEBUG(10, ("streams_xattr_ftruncate: called for file '%s' with offset %lu\n", ++ fsp_str_dbg(fsp), (unsigned long)offset)); + + if (sio == NULL) { + return SMB_VFS_NEXT_FTRUNCATE(handle, fsp, offset); +@@ -1233,6 +1313,8 @@ static int streams_xattr_ftruncate(struc + return -1; + } + ++ frame = talloc_stackframe(); ++ + /* Create an smb_filename with stream_name == NULL. */ + smb_fname_base = synthetic_smb_fname(talloc_tos(), + sio->base, +@@ -1240,40 +1322,46 @@ static int streams_xattr_ftruncate(struc + NULL, + fsp->fsp_name->flags); + if (smb_fname_base == NULL) { ++ TALLOC_FREE(frame); + errno = ENOMEM; + return -1; + } + +- status = get_ea_value(talloc_tos(), handle->conn, NULL, +- smb_fname_base, sio->xattr_name, &ea); ++ status = get_xattr_value(talloc_tos(), handle->conn, ++ smb_fname_base, sio->xattr_name, &ea); + if (!NT_STATUS_IS_OK(status)) { ++ TALLOC_FREE(frame); + return -1; + } ++ orig_length = ea.value.length; + +- tmp = talloc_realloc(talloc_tos(), ea.value.data, uint8_t, +- offset + 1); ++ /* Requested size matches the original size */ ++ if(orig_length == offset) { ++ TALLOC_FREE(frame); ++ return 0; ++ } + +- if (tmp == NULL) { +- TALLOC_FREE(ea.value.data); ++ /* That can both shrink and expand */ ++ /* XXX: If offset == 0 the result of talloc_realloc is NULL, but still valid */ ++ if(offset && !data_blob_realloc(talloc_tos(), &ea.value, offset)) { ++ TALLOC_FREE(frame); + errno = ENOMEM; + return -1; + } + +- /* Did we expand ? */ +- if (ea.value.length < offset + 1) { +- memset(&tmp[ea.value.length], '\0', +- offset + 1 - ea.value.length); ++ /* If we expanded, fill up extra space with zeros */ ++ if (orig_length < offset) { ++ memset(ea.value.data + orig_length, 0, ++ offset - orig_length); + } + +- ea.value.data = tmp; +- ea.value.length = offset + 1; +- ea.value.data[offset] = 0; +- ++ /* XXX: We should use ea.value.length here, but when offset == 0 ++ it's not reset to 0 in data_blob_realloc() */ + ret = SMB_VFS_SETXATTR(fsp->conn, + fsp->fsp_name, + sio->xattr_name, +- ea.value.data, ea.value.length, 0); +- TALLOC_FREE(ea.value.data); ++ ea.value.data, offset, 0); ++ TALLOC_FREE(frame); + + if (ret == -1) { + return -1; +@@ -1291,9 +1379,9 @@ static int streams_xattr_fallocate(struc + struct stream_io *sio = + (struct stream_io *)VFS_FETCH_FSP_EXTENSION(handle, fsp); + +- DEBUG(10, ("streams_xattr_fallocate called for file %s offset %.0f" +- "len = %.0f\n", +- fsp_str_dbg(fsp), (double)offset, (double)len)); ++ DEBUG(10, ("streams_xattr_fallocate: called for file '%s' with offset %lu" ++ "len = %lu\n", ++ fsp_str_dbg(fsp), (unsigned long)offset, (unsigned long)len)); + + if (sio == NULL) { + return SMB_VFS_NEXT_FALLOCATE(handle, fsp, mode, offset, len); Property changes on: head/net/samba48/files/patch-source3_modules_vfs__streams__xattr.c ___________________________________________________________________ Added: fbsd:nokeywords ## -0,0 +1 ## +yes \ No newline at end of property Added: svn:eol-style ## -0,0 +1 ## +native \ No newline at end of property Added: svn:mime-type ## -0,0 +1 ## +text/plain \ No newline at end of property Index: head/net/samba48/files/patch-source4_setup_named.conf.dlz =================================================================== --- head/net/samba48/files/patch-source4_setup_named.conf.dlz (nonexistent) +++ head/net/samba48/files/patch-source4_setup_named.conf.dlz (revision 492474) @@ -0,0 +1,11 @@ +--- source4/setup/named.conf.dlz.orig 2018-01-14 22:41:59 UTC ++++ source4/setup/named.conf.dlz +@@ -21,5 +21,8 @@ dlz "AD DNS Zone" { + + # For BIND 9.11.x + ${BIND9_11} database "dlopen ${MODULESDIR}/bind9/dlz_bind9_11.so"; ++ ++ # For BIND 9.12.x ++ ${BIND9_12} database "dlopen ${MODULESDIR}/bind9/dlz_bind9_12.so"; + }; + Property changes on: head/net/samba48/files/patch-source4_setup_named.conf.dlz ___________________________________________________________________ Added: fbsd:nokeywords ## -0,0 +1 ## +yes \ No newline at end of property Added: svn:eol-style ## -0,0 +1 ## +native \ No newline at end of property Added: svn:mime-type ## -0,0 +1 ## +text/plain \ No newline at end of property Index: head/net/samba48/files/samba_server.in =================================================================== --- head/net/samba48/files/samba_server.in (revision 492473) +++ head/net/samba48/files/samba_server.in (revision 492474) @@ -1,199 +1,199 @@ #!/bin/sh # # $FreeBSD: head/net/samba43/files/samba_server.in 402642 2015-11-30 01:35:36Z timur $ # # PROVIDE: samba_server -# REQUIRE: NETWORKING SERVERS DAEMON ldconfig resolv ntpd +# REQUIRE: NETWORKING SERVERS DAEMON ldconfig resolv ntpd %%SAMBA4_SERVICES%% # BEFORE: LOGIN # KEYWORD: shutdown # # Add the following lines to /etc/rc.conf.local or /etc/rc.conf # to enable this service: # #samba_server_enable="YES" # # You can disable/enable any of the Samba daemons by specifying: #samba_enable="NO" #nmbd_enable="NO" #smbd_enable="NO" # You need to enable winbindd separately, by adding: #winbindd_enable="YES" # Configuration file can be set with: #samba_server_config="%%SAMBA4_CONFDIR%%/%%SAMBA4_CONFIG%%" # . /etc/rc.subr name="samba_server" rcvar=${name}_enable # Defaults samba_server_config_default="%%SAMBA4_CONFDIR%%/%%SAMBA4_CONFIG%%" smbcontrol_command="%%PREFIX%%/bin/smbcontrol" # Custom commands extra_commands="reload status configtest" start_precmd="samba_server_prestart" restart_precmd="samba_server_checkconfig" reload_precmd="samba_server_checkconfig" start_cmd="samba_server_cmd" stop_cmd="samba_server_cmd" status_cmd="samba_server_cmd" configtest_cmd="samba_server_checkconfig" reload_cmd="samba_server_reload_cmd" rcvar_cmd="samba_server_rcvar_cmd" samba_server_checkconfig() { echo -n "Performing sanity check on Samba configuration: " if ${testparm_command} >/dev/null 2>&1; then echo "OK" else echo "FAILED" return 1 fi } samba_server_prestart() { # Make sure we have our RUNDIR, even if it's on a tmpfs if [ -d "${samba_server_piddir}" -o ! -e "${samba_server_piddir}" ]; then install -d -m 0755 "${samba_server_piddir}" fi # https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=200186 if [ -d "${samba_server_privatedir}" -o ! -e "${samba_server_privatedir}" ]; then install -d -m 0700 "${samba_server_privatedir}" fi samba_server_checkconfig } samba_server_rcvar_cmd() { local name rcvar rcvar=${name}_enable # Prevent recursive calling unset "${rc_arg}_cmd" "${rc_arg}_precmd" "${rc_arg}_postcmd" # Check master variable run_rc_command "${_rc_prefix}${rc_arg}" ${rc_extra_args} # Check dependent variables for name in ${samba_daemons}; do # XXX rcvars=''; v='' rcvar=${name}_enable run_rc_command "${_rc_prefix}${rc_arg}" ${rc_extra_args} done } samba_server_reload_cmd() { local name rcvar command pidfile force_run # Prevent recursive calling unset "${rc_arg}_cmd" "${rc_arg}_precmd" "${rc_arg}_postcmd" # Ignore rcvar and run command if [ -n "${_rc_prefix}" -a "${_rc_prefix}" = "one" ] || [ -n "${rc_force}" ] || [ -n "${rc_fast}" ]; then force_run=yes fi # Apply to all daemons for name in ${samba_daemons}; do rcvar=${name}_enable command="%%PREFIX%%/sbin/${name}" pidfile="${samba_server_piddir}/${name}.pid" # Daemon should be enabled and running if ( [ -n "${rcvar}" ] && checkyesno "${rcvar}" ) || [ -n "$force_run" ]; then if [ -n "$(check_pidfile "${pidfile}" "${command}")" ]; then debug "reloading ${name} configuration" echo "Reloading ${name}." ${smbcontrol_command} "${name}" 'reload-config' ${command_args} >/dev/null 2>&1 fi fi done } samba_server_cmd() { local name rcvar rcvars v command pidfile samba_daemons result force_run # Prevent recursive calling unset "${rc_arg}_cmd" "${rc_arg}_precmd" "${rc_arg}_postcmd" # Stop processes in the reverse order if [ "${rc_arg}" = "stop" ] ; then samba_daemons=$(reverse_list ${samba_daemons}) fi # Ignore rcvar and run command if [ -n "${_rc_prefix}" -a "${_rc_prefix}" = "one" ] || [ -n "${rc_force}" ] || [ -n "${rc_fast}" ]; then force_run=yes fi # Assume success result=0 # Apply to all daemons for name in ${samba_daemons}; do # XXX rcvars=''; v='' rcvar=${name}_enable command="%%PREFIX%%/sbin/${name}" pidfile="${samba_server_piddir}/${name}.pid" # Daemon should be enabled and running if ( [ -n "${rcvar}" ] && checkyesno "${rcvar}" ) || [ -n "$force_run" ]; then run_rc_command "${_rc_prefix}${rc_arg}" ${rc_extra_args} # If any of the commands failed, take it as a global result result=$((${result} || $?)) fi done return ${result} } samba_server_config_init() { local name # Load configuration load_rc_config "${name}" # Defaults samba_server_enable=${samba_server_enable:=NO} samba_server_config=${samba_server_config=${samba_server_config_default}} samba_server_configfile_arg=${samba_server_config:+--configfile="${samba_server_config}"} #" #testparm_command="%%PREFIX%%/bin/samba-tool testparm --suppress-prompt --verbose ${samba_server_configfile_arg}" testparm_command="%%PREFIX%%/bin/testparm --suppress-prompt --verbose ${samba_server_config}" # Determine what daemons are necessary to run Samba in the current role samba_server_role=$(${testparm_command} --parameter-name='server role' 2>/dev/null) case "${samba_server_role}" in active\ directory\ domain\ controller) samba_daemons="samba" ;; auto|*) samba_daemons="nmbd smbd winbindd" ;; esac # Load daemons configuration for name in ${samba_daemons}; do load_rc_config "${name}" # If samba_server_enable is 'YES' if [ -n "${rcvar}" ] && checkyesno "${rcvar}"; then if [ "${name}" != "winbindd" ]; then # Set variable to 'YES' only if it is unset eval ${name}_enable=\${${name}_enable-YES} else # Winbindd samba_server_idmap=$(${testparm_command} --parameter-name='idmap uid' 2>/dev/null) if [ -n "${samba_server_idmap}" ]; then winbindd_enable="YES" fi fi fi # If variable is empty, set it to 'NO' eval ${name}_enable=\${${name}_enable:-NO} done # Fetch parameters from configuration file samba_server_lockdir="$(${testparm_command} --parameter-name='lock directory' 2>/dev/null)" samba_server_lockdir=${samba_server_lockdir:=%%SAMBA4_LOCKDIR%%} samba_server_piddir="$(${testparm_command} --parameter-name='pid directory' 2>/dev/null)" samba_server_piddir=${samba_server_piddir:=%%SAMBA4_RUNDIR%%} samba_server_privatedir="$(${testparm_command} --parameter-name='private dir' 2>/dev/null)" samba_server_privatedir=${samba_server_privatedir:=%%SAMBA4_PRIVATEDIR%%} } # Load configuration variables samba_server_config_init # Common flags command_args=${samba_server_configfile_arg} samba_flags=${samba_flags="--daemon"} nmbd_flags=${nmbd_flags="--daemon"} smbd_flags=${smbd_flags="--daemon"} winbindd_flags=${winbindd_flags="--daemon"} # Requirements required_files="${samba_server_config}" required_dirs="${samba_server_lockdir}" run_rc_command "$1" Index: head/net/samba48/pkg-plist =================================================================== --- head/net/samba48/pkg-plist (revision 492473) +++ head/net/samba48/pkg-plist (revision 492474) @@ -1,1339 +1,1343 @@ bin/cifsdd bin/dbwrap_tool bin/eventlogadm bin/findsmb bin/gentest bin/locktest bin/masktest bin/mvxattr bin/ndrdump bin/net bin/nmblookup bin/ntlm_auth bin/oLschema2ldif bin/pdbedit bin/pidl bin/profiles bin/regdiff bin/regpatch bin/regshell bin/regtree bin/rpcclient bin/samba-regedit %%AD_DC%%bin/samba-tool bin/sharesec bin/smbcacls bin/smbclient bin/smbcontrol bin/smbcquotas bin/smbget bin/smbpasswd bin/smbspool bin/smbstatus bin/smbtar %%SAMBA4_PYTHON2%%bin/smbtorture bin/smbtree bin/testparm bin/vfstest bin/wbinfo sbin/nmbd sbin/smbd sbin/winbindd %%AD_DC%%sbin/samba %%AD_DC%%sbin/samba_dnsupdate %%AD_DC%%sbin/samba_gpoupdate %%AD_DC%%sbin/samba_kcc %%AD_DC%%sbin/samba_spnupdate %%AD_DC%%sbin/samba_upgradedns include/samba4/charset.h include/samba4/core/doserr.h include/samba4/core/error.h include/samba4/core/hresult.h include/samba4/core/ntstatus_gen.h include/samba4/core/ntstatus.h include/samba4/core/werror_gen.h include/samba4/core/werror.h include/samba4/credentials.h include/samba4/dcerpc.h %%AD_DC%%include/samba4/dcerpc_server.h %%LDAP%%include/samba4/smb_ldap.h %%LDAP%%include/samba4/smbldap.h include/samba4/domain_credentials.h include/samba4/gen_ndr/atsvc.h include/samba4/gen_ndr/auth.h include/samba4/gen_ndr/dcerpc.h include/samba4/gen_ndr/drsblobs.h include/samba4/gen_ndr/drsuapi.h include/samba4/gen_ndr/krb5pac.h include/samba4/gen_ndr/lsa.h include/samba4/gen_ndr/misc.h include/samba4/gen_ndr/nbt.h include/samba4/gen_ndr/ndr_atsvc.h include/samba4/gen_ndr/ndr_dcerpc.h include/samba4/gen_ndr/ndr_drsblobs.h include/samba4/gen_ndr/ndr_drsuapi.h include/samba4/gen_ndr/ndr_krb5pac.h include/samba4/gen_ndr/ndr_misc.h include/samba4/gen_ndr/ndr_nbt.h include/samba4/gen_ndr/ndr_samr_c.h include/samba4/gen_ndr/ndr_samr.h include/samba4/gen_ndr/ndr_svcctl_c.h include/samba4/gen_ndr/ndr_svcctl.h include/samba4/gen_ndr/netlogon.h include/samba4/gen_ndr/samr.h include/samba4/gen_ndr/security.h include/samba4/gen_ndr/server_id.h include/samba4/gen_ndr/svcctl.h include/samba4/ldb_wrap.h include/samba4/libsmbclient.h include/samba4/lookup_sid.h include/samba4/machine_sid.h include/samba4/ndr.h include/samba4/ndr/ndr_dcerpc.h include/samba4/ndr/ndr_drsblobs.h include/samba4/ndr/ndr_drsuapi.h include/samba4/ndr/ndr_krb5pac.h include/samba4/ndr/ndr_nbt.h include/samba4/ndr/ndr_svcctl.h include/samba4/netapi.h include/samba4/param.h include/samba4/passdb.h %%SAMBA4_PYTHON2%%include/samba4/policy.h include/samba4/rpc_common.h include/samba4/samba/session.h include/samba4/samba/version.h include/samba4/share.h include/samba4/smb2_lease_struct.h include/samba4/smbconf.h include/samba4/tdr.h include/samba4/tsocket_internal.h include/samba4/tsocket.h include/samba4/util_ldb.h include/samba4/util/attr.h include/samba4/util/blocking.h include/samba4/util/byteorder.h include/samba4/util/data_blob.h include/samba4/util/debug.h include/samba4/util/fault.h include/samba4/util/genrand.h include/samba4/util/idtree_random.h include/samba4/util/idtree.h include/samba4/util/memory.h include/samba4/util/safe_string.h include/samba4/util/signal.h include/samba4/util/string_wrappers.h include/samba4/util/substitute.h include/samba4/util/talloc_stack.h include/samba4/util/tevent_ntstatus.h include/samba4/util/tevent_unix.h include/samba4/util/tevent_werror.h include/samba4/util/tfork.h include/samba4/util/time.h include/samba4/wbclient.h @dir include/samba4/util @dir include/samba4/samba @dir include/samba4/ndr @dir include/samba4/gen_ndr @dir include/samba4/core @dir include/samba4 lib/samba4/libdcerpc-binding.so lib/samba4/libdcerpc-binding.so.0 lib/samba4/libdcerpc-samr.so lib/samba4/libdcerpc-samr.so.0 %%AD_DC%%lib/samba4/libdcerpc-server.so %%AD_DC%%lib/samba4/libdcerpc-server.so.0 lib/samba4/libdcerpc.so lib/samba4/libdcerpc.so.0 lib/samba4/libndr-krb5pac.so lib/samba4/libndr-krb5pac.so.0 lib/samba4/libndr-nbt.so lib/samba4/libndr-nbt.so.0 lib/samba4/libndr-standard.so lib/samba4/libndr-standard.so.0 lib/samba4/libndr.so lib/samba4/libndr.so.0 lib/samba4/libnetapi.so lib/samba4/libnetapi.so.0 lib/samba4/libsamba-credentials.so lib/samba4/libsamba-credentials.so.0 lib/samba4/libsamba-errors.so lib/samba4/libsamba-errors.so.1 lib/samba4/libsamba-hostconfig.so lib/samba4/libsamba-hostconfig.so.0 lib/samba4/libsamba-passdb.so lib/samba4/libsamba-passdb.so.0 %%SAMBA4_PYTHON2%%lib/samba4/libsamba-policy.so %%SAMBA4_PYTHON2%%lib/samba4/libsamba-policy.so.0 lib/samba4/libsamba-util.so lib/samba4/libsamba-util.so.0 lib/samba4/libsamdb.so lib/samba4/libsamdb.so.0 lib/samba4/libsmbclient.so lib/samba4/libsmbclient.so.0 lib/samba4/libsmbconf.so lib/samba4/libsmbconf.so.0 %%LDAP%%lib/samba4/libsmbldap.so %%LDAP%%lib/samba4/libsmbldap.so.2 lib/samba4/libtevent-util.so lib/samba4/libtevent-util.so.0 lib/samba4/libwbclient.so lib/samba4/libwbclient.so.0 lib/nss_winbind.so.1 lib/nss_wins.so.1 lib/pam_winbind.so %%CUPS%%libexec/samba/smbspool_krb5_wrapper %%AD_DC%%lib/samba4/private/libdlz-bind9-for-torture-samba4.so %%AD_DC%%lib/samba4/private/libposix-eadb-samba4.so %%AD_DC%%lib/samba4/private/libprocess-model-samba4.so %%AD_DC%%lib/samba4/private/libservice-samba4.so lib/samba4/private/libCHARSET3-samba4.so %%AD_DC%%%%GSSAPI_BUILTIN%%lib/samba4/private/libHDB-SAMBA4-samba4.so lib/samba4/private/libLIBWBCLIENT-OLD-samba4.so lib/samba4/private/libMESSAGING-samba4.so lib/samba4/private/libMESSAGING-SEND-samba4.so lib/samba4/private/libaddns-samba4.so lib/samba4/private/libads-samba4.so %%GSSAPI_BUILTIN%%lib/samba4/private/libasn1-samba4.so.8 lib/samba4/private/libasn1util-samba4.so lib/samba4/private/libauth-samba4.so lib/samba4/private/libauth-unix-token-samba4.so lib/samba4/private/libauth4-samba4.so lib/samba4/private/libauthkrb5-samba4.so lib/samba4/private/libcli-cldap-samba4.so lib/samba4/private/libcli-ldap-common-samba4.so lib/samba4/private/libcli-ldap-samba4.so lib/samba4/private/libcli-nbt-samba4.so lib/samba4/private/libcli-smb-common-samba4.so lib/samba4/private/libcli-spoolss-samba4.so lib/samba4/private/libcliauth-samba4.so lib/samba4/private/libcluster-samba4.so lib/samba4/private/libcmdline-credentials-samba4.so +lib/samba4/private/libcmdline-contexts-samba4.so %%GSSAPI_BUILTIN%%lib/samba4/private/libcom_err-samba4.so.0 lib/samba4/private/libcommon-auth-samba4.so %%AD_DC%%lib/samba4/private/libdb-glue-samba4.so lib/samba4/private/libdbwrap-samba4.so lib/samba4/private/libdcerpc-samba-samba4.so lib/samba4/private/libdcerpc-samba4.so %%AD_DC%%lib/samba4/private/libdfs-server-ad-samba4.so %%AD_DC%%lib/samba4/private/libdnsserver-common-samba4.so lib/samba4/private/libdsdb-garbage-collect-tombstones-samba4.so lib/samba4/private/libdsdb-module-samba4.so lib/samba4/private/libevents-samba4.so lib/samba4/private/libflag-mapping-samba4.so lib/samba4/private/libgenrand-samba4.so lib/samba4/private/libgensec-samba4.so lib/samba4/private/libgpext-samba4.so lib/samba4/private/libgse-samba4.so %%GSSAPI_BUILTIN%%lib/samba4/private/libgssapi-samba4.so.2 %%GSSAPI_BUILTIN%%lib/samba4/private/libhcrypto-samba4.so.5 %%GSSAPI_BUILTIN%%lib/samba4/private/libhdb-samba4.so.11 %%GSSAPI_BUILTIN%%lib/samba4/private/libheimbase-samba4.so.1 %%GSSAPI_BUILTIN%%lib/samba4/private/libheimntlm-samba4.so.1 lib/samba4/private/libhttp-samba4.so %%GSSAPI_BUILTIN%%lib/samba4/private/libhx509-samba4.so.5 lib/samba4/private/libidmap-samba4.so lib/samba4/private/libinterfaces-samba4.so lib/samba4/private/libiov-buf-samba4.so %%GSSAPI_BUILTIN%%lib/samba4/private/libkdc-samba4.so.2 %%GSSAPI_BUILTIN%%lib/samba4/private/libkrb5-samba4.so.26 lib/samba4/private/libkrb5samba-samba4.so lib/samba4/private/libldbsamba-samba4.so lib/samba4/private/liblibcli-lsa3-samba4.so lib/samba4/private/liblibcli-netlogon3-samba4.so lib/samba4/private/liblibsmb-samba4.so lib/samba4/private/libmessages-dgm-samba4.so lib/samba4/private/libmessages-util-samba4.so lib/samba4/private/libmsghdr-samba4.so lib/samba4/private/libmsrpc3-samba4.so lib/samba4/private/libndr-samba-samba4.so lib/samba4/private/libndr-samba4.so lib/samba4/private/libnet-keytab-samba4.so lib/samba4/private/libnetif-samba4.so lib/samba4/private/libnon-posix-acls-samba4.so lib/samba4/private/libnpa-tstream-samba4.so lib/samba4/private/libnss-info-samba4.so %%AD_DC%%lib/samba4/private/libpac-samba4.so lib/samba4/private/libpopt-samba3-samba4.so +lib/samba4/private/libpopt-samba3-cmdline-samba4.so lib/samba4/private/libprinting-migrate-samba4.so lib/samba4/private/libregistry-samba4.so lib/samba4/private/libreplace-samba4.so %%GSSAPI_BUILTIN%%lib/samba4/private/libroken-samba4.so.19 lib/samba4/private/libsamba-cluster-support-samba4.so lib/samba4/private/libsamba-debug-samba4.so lib/samba4/private/libsamba-modules-samba4.so %%SAMBA4_PYTHON2%%lib/samba4/private/libsamba-net-samba4.so %%SAMBA4_PYTHON2%%lib/samba4/private/libsamba-python-samba4.so lib/samba4/private/libsamba-security-samba4.so lib/samba4/private/libsamba-sockets-samba4.so lib/samba4/private/libsamba3-util-samba4.so lib/samba4/private/libsamdb-common-samba4.so lib/samba4/private/libsecrets3-samba4.so lib/samba4/private/libserver-id-db-samba4.so lib/samba4/private/libserver-role-samba4.so lib/samba4/private/libshares-samba4.so lib/samba4/private/libsmb-transport-samba4.so lib/samba4/private/libsmbclient-raw-samba4.so lib/samba4/private/libsmbd-base-samba4.so lib/samba4/private/libsmbd-conn-samba4.so lib/samba4/private/libsmbd-shim-samba4.so %%LDAP%%lib/samba4/private/libsmbldaphelper-samba4.so lib/samba4/private/libsmbpasswdparser-samba4.so lib/samba4/private/libsocket-blocking-samba4.so lib/samba4/private/libsys-rw-samba4.so lib/samba4/private/libtalloc-report-samba4.so lib/samba4/private/libtdb-wrap-samba4.so lib/samba4/private/libtime-basic-samba4.so lib/samba4/private/libtorture-samba4.so lib/samba4/private/libtrusts-util-samba4.so lib/samba4/private/libutil-cmdline-samba4.so lib/samba4/private/libutil-reg-samba4.so lib/samba4/private/libutil-setid-samba4.so lib/samba4/private/libutil-tdb-samba4.so lib/samba4/private/libwinbind-client-samba4.so %%GSSAPI_BUILTIN%%lib/samba4/private/libwind-samba4.so.0 lib/samba4/private/libxattr-tdb-samba4.so %%AD_DC%%lib/shared-modules/bind9/dlz_bind9_10.so %%AD_DC%%lib/shared-modules/bind9/dlz_bind9_11.so %%AD_DC%%lib/shared-modules/bind9/dlz_bind9_9.so %%AD_DC%%lib/shared-modules/bind9/dlz_bind9.so %%AD_DC%%lib/shared-modules/gensec/krb5.so %%AD_DC%%lib/shared-modules/krb5/winbind_krb5_locator.so %%AD_DC%%lib/shared-modules/ldb/acl.so %%AD_DC%%lib/shared-modules/ldb/aclread.so %%AD_DC%%lib/shared-modules/ldb/anr.so %%AD_DC%%lib/shared-modules/ldb/descriptor.so %%AD_DC%%lib/shared-modules/ldb/dirsync.so %%AD_DC%%lib/shared-modules/ldb/dns_notify.so %%AD_DC%%lib/shared-modules/ldb/dsdb_notification.so %%AD_DC%%lib/shared-modules/ldb/encrypted_secrets.so %%AD_DC%%lib/shared-modules/ldb/extended_dn_in.so %%AD_DC%%lib/shared-modules/ldb/extended_dn_out.so %%AD_DC%%lib/shared-modules/ldb/extended_dn_store.so %%AD_DC%%lib/shared-modules/ldb/ildap.so %%AD_DC%%lib/shared-modules/ldb/instancetype.so %%AD_DC%%lib/shared-modules/ldb/lazy_commit.so %%AD_DC%%lib/shared-modules/ldb/ldbsamba_extensions.so %%AD_DC%%lib/shared-modules/ldb/linked_attributes.so %%AD_DC%%lib/shared-modules/ldb/local_password.so %%AD_DC%%lib/shared-modules/ldb/new_partition.so %%AD_DC%%lib/shared-modules/ldb/objectclass_attrs.so %%AD_DC%%lib/shared-modules/ldb/objectclass.so %%AD_DC%%lib/shared-modules/ldb/objectguid.so %%AD_DC%%lib/shared-modules/ldb/operational.so %%AD_DC%%lib/shared-modules/ldb/partition.so %%AD_DC%%lib/shared-modules/ldb/password_hash.so %%AD_DC%%lib/shared-modules/ldb/ranged_results.so %%AD_DC%%lib/shared-modules/ldb/repl_meta_data.so %%AD_DC%%lib/shared-modules/ldb/resolve_oids.so %%AD_DC%%lib/shared-modules/ldb/rootdse.so %%AD_DC%%lib/shared-modules/ldb/samba_dsdb.so %%AD_DC%%lib/shared-modules/ldb/samba_secrets.so %%AD_DC%%lib/shared-modules/ldb/samba3sam.so %%AD_DC%%lib/shared-modules/ldb/samba3sid.so %%AD_DC%%lib/shared-modules/ldb/samldb.so %%AD_DC%%lib/shared-modules/ldb/schema_data.so %%AD_DC%%lib/shared-modules/ldb/schema_load.so %%AD_DC%%lib/shared-modules/ldb/secrets_tdb_sync.so %%AD_DC%%lib/shared-modules/ldb/show_deleted.so %%AD_DC%%lib/shared-modules/ldb/simple_dn.so %%AD_DC%%lib/shared-modules/ldb/simple_ldap_map.so %%AD_DC%%lib/shared-modules/ldb/subtree_delete.so %%AD_DC%%lib/shared-modules/ldb/subtree_rename.so %%AD_DC%%lib/shared-modules/ldb/tombstone_reanimate.so %%AD_DC%%lib/shared-modules/ldb/unique_object_sids.so %%AD_DC%%lib/shared-modules/ldb/update_keytab.so %%AD_DC%%lib/shared-modules/ldb/vlv.so %%AD_DC%%lib/shared-modules/ldb/wins_ldb.so %%AD_DC%%lib/shared-modules/process_model/prefork.so %%AD_DC%%lib/shared-modules/process_model/standard.so %%AD_DC%%lib/shared-modules/service/cldap.so %%AD_DC%%lib/shared-modules/service/dcerpc.so %%AD_DC%%lib/shared-modules/service/dns_update.so %%AD_DC%%lib/shared-modules/service/dns.so %%AD_DC%%lib/shared-modules/service/drepl.so %%AD_DC%%lib/shared-modules/service/kcc.so %%AD_DC%%lib/shared-modules/service/kdc.so %%AD_DC%%lib/shared-modules/service/ldap.so %%AD_DC%%lib/shared-modules/service/nbtd.so %%AD_DC%%lib/shared-modules/service/ntp_signd.so %%AD_DC%%lib/shared-modules/service/s3fs.so %%AD_DC%%lib/shared-modules/service/web.so %%AD_DC%%lib/shared-modules/service/winbindd.so %%AD_DC%%lib/shared-modules/service/wrepl.so %%AD_DC%%lib/shared-modules/vfs/posix_eadb.so lib/shared-modules/auth/script.so lib/shared-modules/vfs/acl_tdb.so lib/shared-modules/vfs/acl_xattr.so lib/shared-modules/vfs/aio_fork.so lib/shared-modules/vfs/aio_pthread.so lib/shared-modules/vfs/audit.so lib/shared-modules/vfs/cap.so lib/shared-modules/vfs/catia.so lib/shared-modules/vfs/commit.so lib/shared-modules/vfs/crossrename.so lib/shared-modules/vfs/default_quota.so lib/shared-modules/vfs/dirsort.so lib/shared-modules/vfs/expand_msdfs.so lib/shared-modules/vfs/extd_audit.so lib/shared-modules/vfs/fake_perms.so lib/shared-modules/vfs/fruit.so lib/shared-modules/vfs/full_audit.so +lib/shared-modules/vfs/glusterfs_fuse.so lib/shared-modules/vfs/linux_xfs_sgid.so lib/shared-modules/vfs/media_harmony.so lib/shared-modules/vfs/netatalk.so lib/shared-modules/vfs/offline.so lib/shared-modules/vfs/preopen.so lib/shared-modules/vfs/readahead.so lib/shared-modules/vfs/readonly.so lib/shared-modules/vfs/recycle.so lib/shared-modules/vfs/shadow_copy.so lib/shared-modules/vfs/shadow_copy2.so lib/shared-modules/vfs/shell_snap.so lib/shared-modules/vfs/streams_depot.so lib/shared-modules/vfs/streams_xattr.so lib/shared-modules/vfs/syncops.so lib/shared-modules/vfs/time_audit.so lib/shared-modules/vfs/unityed_media.so lib/shared-modules/vfs/virusfilter.so lib/shared-modules/vfs/worm.so lib/shared-modules/vfs/xattr_tdb.so lib/shared-modules/vfs/zfsacl.so @dir lib/shared-modules/vfs %%AD_DC%%@dir lib/shared-modules/service %%AD_DC%%@dir lib/shared-modules/process_model @dir lib/shared-modules/perfcount @dir lib/shared-modules/pdb @dir lib/shared-modules/nss_info @dir lib/shared-modules/ldb @dir lib/shared-modules/idmap @dir lib/shared-modules/gpext @dir lib/shared-modules/gensec @dir lib/shared-modules/bind9 @dir lib/shared-modules/auth @dir lib/shared-modules @dir lib/samba4/private @dir lib/samba4 %%PKGCONFIGDIR%%/dcerpc.pc %%PKGCONFIGDIR%%/dcerpc_samr.pc %%AD_DC%%%%PKGCONFIGDIR%%/dcerpc_server.pc %%PKGCONFIGDIR%%/ndr.pc %%PKGCONFIGDIR%%/ndr_krb5pac.pc %%PKGCONFIGDIR%%/ndr_nbt.pc %%PKGCONFIGDIR%%/ndr_standard.pc %%PKGCONFIGDIR%%/netapi.pc %%PKGCONFIGDIR%%/samba-credentials.pc %%PKGCONFIGDIR%%/samba-hostconfig.pc %%SAMBA4_PYTHON2%%%%PKGCONFIGDIR%%/samba-policy.pc %%PKGCONFIGDIR%%/samba-util.pc %%PKGCONFIGDIR%%/samdb.pc %%PKGCONFIGDIR%%/smbclient.pc %%PKGCONFIGDIR%%/wbclient.pc @comment Python2 block %%SAMBA4_PYTHON2%%%%AD_DC%%%%PYTHON_SITELIBDIR%%/samba/dckeytab.so %%SAMBA4_PYTHON2%%%%AD_DC%%%%PYTHON_SITELIBDIR%%/samba/posix_eadb.so %%SAMBA4_PYTHON2%%%%AD_DC%%%%PYTHON_SITELIBDIR%%/samba/xattr_native.so %%SAMBA4_PYTHON2%%%%AD_DC%%%%PYTHON_SITELIBDIR%%/samba/xattr_tdb.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/_glue.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/_ldb.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/auth.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/colour.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/common.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/compat.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/credentials.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/crypto.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dbchecker.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/atsvc.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/auth.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/base.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/dcerpc.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/dfs.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/dns.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/dnsp.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/dnsserver.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/drsblobs.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/drsuapi.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/echo.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/epmapper.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/idmap.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/initshutdown.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/irpc.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/krb5pac.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/lsa.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/messaging.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/mgmt.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/misc.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/nbt.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/netlogon.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/ntlmssp.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/samr.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/security.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/server_id.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/smb_acl.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/srvsvc.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/svcctl.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/unixinfo.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/winbind.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/winreg.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/wkssvc.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dcerpc/xattr.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/descriptor.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dnsserver.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/domain_update.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/drs_utils.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dsdb_dns.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/dsdb.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/emulate/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/emulate/traffic_packets.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/emulate/traffic.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/forest_update.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/gensec.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/getopt.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/gpclass.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/gpo.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/graph.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/hostconfig.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/idmap.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/join.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/kcc/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/kcc/debug.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/kcc/graph_utils.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/kcc/graph.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/kcc/kcc_utils.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/kcc/ldif_import_export.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/messaging.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/ms_display_specifiers.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/ms_forest_updates_markdown.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/ms_schema_markdown.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/ms_schema.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/ndr.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/net.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netbios.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/common.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/dbcheck.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/delegation.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/dns.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/domain.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/drs.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/dsacl.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/fsmo.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/gpo.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/group.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/ldapcmp.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/main.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/nettime.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/ntacl.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/processes.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/rodc.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/sites.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/spn.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/testparm.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/user.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/netcmd/visualize.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/ntacls.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/ntstatus.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/param.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/policy.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/provision/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/provision/backend.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/provision/common.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/provision/kerberos_implementation.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/provision/kerberos.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/provision/sambadns.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/registry.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/remove_dc.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/samba3/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/samba3/libsmb_samba_internal.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/samba3/param.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/samba3/passdb.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/samba3/smbd.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/samdb.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/schema.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/sd_utils.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/security.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/sites.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/smb.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/subnets.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/subunit/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/subunit/run.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tdb_util.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/auth_log_base.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/auth_log_ncalrpc.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/auth_log_netlogon_bad_creds.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/auth_log_netlogon.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/auth_log_pass_change.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/auth_log_samlogon.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/auth_log.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/auth.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/blackbox/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/blackbox/check_output.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/blackbox/ndrdump.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/blackbox/samba_dnsupdate.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/blackbox/smbcontrol.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/blackbox/traffic_learner.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/blackbox/traffic_replay.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/blackbox/traffic_summary.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/common.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/core.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/credentials.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/array.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/bare.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/dnsserver.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/integer.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/misc.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/raw_protocol.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/raw_testcase.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/registry.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/rpc_talloc.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/rpcecho.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/sam.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/srvsvc.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/string.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/testrpc.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dcerpc/unix.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dns_base.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dns_forwarder_helpers/server.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dns_forwarder.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dns_invalid.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dns_tkey.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dns_wildcard.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dns.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/docs.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dsdb_lock.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dsdb_schema_attributes.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/dsdb.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/emulate/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/emulate/traffic_packet.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/emulate/traffic.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/encrypted_secrets.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/gensec.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/get_opt.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/glue.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/graph.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/hostconfig.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/join.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/kcc/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/kcc/graph_utils.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/kcc/graph.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/kcc/kcc_utils.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/kcc/ldif_import_export.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/krb5_credentials.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/libsmb_samba_internal.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/lsa_string.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/messaging.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/net_join_no_spnego.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/net_join.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/netcmd.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/netlogonsvc.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/ntacls.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/ntlmdisabled.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/pam_winbind_warn_pwd_expire.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/pam_winbind.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/param.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/password_hash_fl2003.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/password_hash_fl2008.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/password_hash_gpgme.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/password_hash_ldap.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/password_hash.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/password_quality.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/policy.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/posixacl.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/provision.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/py_credentials.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/registry.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/base.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/dnscmd.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/fsmo.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/gpo.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/group.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/help.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/join.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/ntacl.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/processes.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/provision_password_check.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/rodc.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/sites.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/timecmd.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/user_check_password_script.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/user_virtualCryptSHA.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/user_wdigest.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/user.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/visualize_drs.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba_tool/visualize.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba3.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samba3sam.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/samdb.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/security.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/source.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/strings.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/subunitrun.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/tdb_util.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/unicodenames.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/upgrade.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/upgradeprovision.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/upgradeprovisionneeddc.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/tests/xattr.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/third_party/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/upgrade.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/upgradehelpers.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/web_server/__init__.py %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/werror.so %%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/samba/xattr.py %%SAMBA4_PYTHON2%%@unexec find %D/%%PYTHON_SITELIBDIR%%/samba -name '*.py[co]' -delete >/dev/null 2>&1 %%SAMBA4_PYTHON2%%@dir %%PYTHON_SITELIBDIR%%/samba/web_server %%SAMBA4_PYTHON2%%@dir %%PYTHON_SITELIBDIR%%/samba/tests/samba_tool %%SAMBA4_PYTHON2%%@dir %%PYTHON_SITELIBDIR%%/samba/tests/dcerpc %%SAMBA4_PYTHON2%%@dir %%PYTHON_SITELIBDIR%%/samba/tests/blackbox %%SAMBA4_PYTHON2%%@dir %%PYTHON_SITELIBDIR%%/samba/tests %%SAMBA4_PYTHON2%%@dir %%PYTHON_SITELIBDIR%%/samba/samba3 %%SAMBA4_PYTHON2%%@dir %%PYTHON_SITELIBDIR%%/samba/provision %%SAMBA4_PYTHON2%%@dir %%PYTHON_SITELIBDIR%%/samba/netcmd %%SAMBA4_PYTHON2%%@dir %%PYTHON_SITELIBDIR%%/samba/dcerpc %%SAMBA4_PYTHON2%%@dir %%PYTHON_SITELIBDIR%%/samba @comment Python3 block %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/_glue.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/_ldb.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/auth.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/colour.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/common.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/compat.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/credentials.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/crypto.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dbchecker.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/atsvc.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/auth.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/base.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/dcerpc.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/dfs.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/dns.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/dnsp.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/dnsserver.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/drsblobs.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/drsuapi.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/echo.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/epmapper.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/idmap.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/initshutdown.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/irpc.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/krb5pac.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/lsa.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/messaging.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/mgmt.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/misc.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/nbt.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/netlogon.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/ntlmssp.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/samr.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/security.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/server_id.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/smb_acl.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/srvsvc.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/svcctl.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/unixinfo.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/winbind.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/winreg.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/wkssvc.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc/xattr.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/descriptor.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dnsserver.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/domain_update.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/drs_utils.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/emulate/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/emulate/traffic_packets.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/emulate/traffic.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/forest_update.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/gensec.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/getopt.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/gpclass.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/graph.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/hostconfig.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/idmap.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/join.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/kcc/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/kcc/debug.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/kcc/graph_utils.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/kcc/graph.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/kcc/kcc_utils.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/kcc/ldif_import_export.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/messaging.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/ms_display_specifiers.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/ms_forest_updates_markdown.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/ms_schema_markdown.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/ms_schema.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/ndr.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/net.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/common.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/dbcheck.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/delegation.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/dns.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/domain.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/drs.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/dsacl.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/fsmo.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/gpo.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/group.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/ldapcmp.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/main.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/nettime.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/ntacl.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/processes.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/rodc.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/sites.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/spn.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/testparm.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/user.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd/visualize.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/ntacls.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/ntstatus.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/param.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/posix_eadb.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/provision/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/provision/backend.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/provision/common.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/provision/kerberos_implementation.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/provision/kerberos.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/provision/sambadns.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/registry.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/remove_dc.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/samba3/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/samdb.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/schema.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/sd_utils.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/security.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/sites.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/subnets.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/subunit/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/subunit/run.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tdb_util.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/auth_log_base.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/auth_log_ncalrpc.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/auth_log_netlogon_bad_creds.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/auth_log_netlogon.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/auth_log_pass_change.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/auth_log_samlogon.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/auth_log.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/auth.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/blackbox/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/blackbox/check_output.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/blackbox/ndrdump.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/blackbox/samba_dnsupdate.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/blackbox/smbcontrol.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/blackbox/traffic_learner.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/blackbox/traffic_replay.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/blackbox/traffic_summary.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/common.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/core.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/credentials.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/array.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/bare.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/dnsserver.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/integer.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/misc.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/raw_protocol.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/raw_testcase.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/registry.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/rpc_talloc.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/rpcecho.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/sam.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/srvsvc.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/string.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/testrpc.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc/unix.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dns_base.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dns_forwarder_helpers/server.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dns_forwarder.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dns_invalid.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dns_tkey.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dns_wildcard.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dns.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/docs.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dsdb_lock.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dsdb_schema_attributes.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dsdb.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/emulate/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/emulate/traffic_packet.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/emulate/traffic.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/encrypted_secrets.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/gensec.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/get_opt.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/glue.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/graph.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/hostconfig.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/join.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/kcc/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/kcc/graph_utils.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/kcc/graph.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/kcc/kcc_utils.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/kcc/ldif_import_export.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/krb5_credentials.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/libsmb_samba_internal.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/lsa_string.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/messaging.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/net_join_no_spnego.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/net_join.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/netcmd.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/netlogonsvc.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/ntacls.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/ntlmdisabled.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/pam_winbind_warn_pwd_expire.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/pam_winbind.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/param.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/password_hash_fl2003.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/password_hash_fl2008.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/password_hash_gpgme.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/password_hash_ldap.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/password_hash.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/password_quality.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/policy.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/posixacl.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/provision.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/py_credentials.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/registry.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/base.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/dnscmd.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/fsmo.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/gpo.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/group.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/help.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/join.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/ntacl.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/processes.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/provision_password_check.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/rodc.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/sites.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/timecmd.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/user_check_password_script.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/user_virtualCryptSHA.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/user_wdigest.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/user.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/visualize_drs.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool/visualize.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba3.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba3sam.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samdb.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/security.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/source.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/strings.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/subunitrun.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/tdb_util.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/unicodenames.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/upgrade.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/upgradeprovision.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/upgradeprovisionneeddc.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/xattr.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/upgrade.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/upgradehelpers.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/web_server/__init__.py %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/werror.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/xattr_native.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/xattr_tdb.cpython-36m.so %%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/samba/xattr.py %%SAMBA4_PYTHON3%%@unexec find %D/%%PYTHON_SITELIBDIR%%/samba -name '*.py[co]' -delete >/dev/null 2>&1 %%SAMBA4_PYTHON3%%@dir %%SAMBA4_PYTHON3_SITELIBDIR%%/samba/web_server %%SAMBA4_PYTHON3%%@dir %%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/samba_tool %%SAMBA4_PYTHON3%%@dir %%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/dcerpc %%SAMBA4_PYTHON3%%@dir %%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests/blackbox %%SAMBA4_PYTHON3%%@dir %%SAMBA4_PYTHON3_SITELIBDIR%%/samba/tests %%SAMBA4_PYTHON3%%@dir %%SAMBA4_PYTHON3_SITELIBDIR%%/samba/samba3 %%SAMBA4_PYTHON3%%@dir %%SAMBA4_PYTHON3_SITELIBDIR%%/samba/provision %%SAMBA4_PYTHON3%%@dir %%SAMBA4_PYTHON3_SITELIBDIR%%/samba/netcmd %%SAMBA4_PYTHON3%%@dir %%SAMBA4_PYTHON3_SITELIBDIR%%/samba/dcerpc %%SAMBA4_PYTHON3%%@dir %%SAMBA4_PYTHON3_SITELIBDIR%%/samba @comment Pidl block %%DATADIR%%/perl5/Parse/Pidl.pm %%DATADIR%%/perl5/Parse/Pidl/CUtil.pm %%DATADIR%%/perl5/Parse/Pidl/Compat.pm %%DATADIR%%/perl5/Parse/Pidl/Dump.pm %%DATADIR%%/perl5/Parse/Pidl/Expr.pm %%DATADIR%%/perl5/Parse/Pidl/IDL.pm %%DATADIR%%/perl5/Parse/Pidl/NDR.pm %%DATADIR%%/perl5/Parse/Pidl/ODL.pm %%DATADIR%%/perl5/Parse/Pidl/Samba3/ClientNDR.pm %%DATADIR%%/perl5/Parse/Pidl/Samba3/ServerNDR.pm %%DATADIR%%/perl5/Parse/Pidl/Samba4.pm %%DATADIR%%/perl5/Parse/Pidl/Samba4/COM/Header.pm %%DATADIR%%/perl5/Parse/Pidl/Samba4/COM/Proxy.pm %%DATADIR%%/perl5/Parse/Pidl/Samba4/COM/Stub.pm %%DATADIR%%/perl5/Parse/Pidl/Samba4/Header.pm %%DATADIR%%/perl5/Parse/Pidl/Samba4/NDR/Client.pm %%DATADIR%%/perl5/Parse/Pidl/Samba4/NDR/Parser.pm %%DATADIR%%/perl5/Parse/Pidl/Samba4/NDR/Server.pm %%DATADIR%%/perl5/Parse/Pidl/Samba4/Python.pm %%DATADIR%%/perl5/Parse/Pidl/Samba4/TDR.pm %%DATADIR%%/perl5/Parse/Pidl/Samba4/Template.pm %%DATADIR%%/perl5/Parse/Pidl/Typelist.pm %%DATADIR%%/perl5/Parse/Pidl/Util.pm %%DATADIR%%/perl5/Parse/Pidl/Wireshark/Conformance.pm %%DATADIR%%/perl5/Parse/Pidl/Wireshark/NDR.pm @dir %%DATADIR%%/perl5/Parse/Pidl/Wireshark @dir %%DATADIR%%/perl5/Parse/Pidl/Samba4/NDR @dir %%DATADIR%%/perl5/Parse/Pidl/Samba4/COM @dir %%DATADIR%%/perl5/Parse/Pidl/Samba4 @dir %%DATADIR%%/perl5/Parse/Pidl/Samba3 @dir %%DATADIR%%/perl5/Parse/Pidl @dir %%DATADIR%%/perl5/Parse @dir %%DATADIR%%/perl5 %%AD_DC%%%%DATADIR%%/setup/ad-schema/AD_DS_Attributes__Windows_Server_2012_R2.ldf %%AD_DC%%%%DATADIR%%/setup/ad-schema/AD_DS_Attributes__Windows_Server_2016.ldf %%AD_DC%%%%DATADIR%%/setup/ad-schema/AD_DS_Classes__Windows_Server_2012_R2.ldf %%AD_DC%%%%DATADIR%%/setup/ad-schema/AD_DS_Classes__Windows_Server_2016.ldf %%AD_DC%%%%DATADIR%%/setup/ad-schema/Attributes_for_AD_DS__Windows_Server_2008_R2.ldf %%AD_DC%%%%DATADIR%%/setup/ad-schema/Attributes_for_AD_DS__Windows_Server_2012.ldf %%AD_DC%%%%DATADIR%%/setup/ad-schema/Classes_for_AD_DS__Windows_Server_2008_R2.ldf %%AD_DC%%%%DATADIR%%/setup/ad-schema/Classes_for_AD_DS__Windows_Server_2012.ldf %%AD_DC%%%%DATADIR%%/setup/ad-schema/licence.txt %%AD_DC%%%%DATADIR%%/setup/ad-schema/MS-AD_Schema_2K8_Attributes.txt %%AD_DC%%%%DATADIR%%/setup/ad-schema/MS-AD_Schema_2K8_Classes.txt %%AD_DC%%%%DATADIR%%/setup/ad-schema/MS-AD_Schema_2K8_R2_Attributes.txt %%AD_DC%%%%DATADIR%%/setup/ad-schema/MS-AD_Schema_2K8_R2_Classes.txt %%AD_DC%%%%DATADIR%%/setup/adprep/fix-forest-rev.ldf %%AD_DC%%%%DATADIR%%/setup/adprep/WindowsServerDocs/Forest-Wide-Updates.md %%AD_DC%%%%DATADIR%%/setup/adprep/WindowsServerDocs/Sch49.ldf.diff %%AD_DC%%%%DATADIR%%/setup/adprep/WindowsServerDocs/Sch50.ldf.diff %%AD_DC%%%%DATADIR%%/setup/adprep/WindowsServerDocs/Sch51.ldf.diff %%AD_DC%%%%DATADIR%%/setup/adprep/WindowsServerDocs/Sch57.ldf.diff %%AD_DC%%%%DATADIR%%/setup/adprep/WindowsServerDocs/Sch59.ldf.diff %%AD_DC%%%%DATADIR%%/setup/adprep/WindowsServerDocs/Schema-Updates.md %%AD_DC%%%%DATADIR%%/setup/aggregate_schema.ldif %%AD_DC%%%%DATADIR%%/setup/cn=samba.ldif %%AD_DC%%%%DATADIR%%/setup/DB_CONFIG %%AD_DC%%%%DATADIR%%/setup/display-specifiers/DisplaySpecifiers-Win2k0.txt %%AD_DC%%%%DATADIR%%/setup/display-specifiers/DisplaySpecifiers-Win2k3.txt %%AD_DC%%%%DATADIR%%/setup/display-specifiers/DisplaySpecifiers-Win2k3R2.txt %%AD_DC%%%%DATADIR%%/setup/display-specifiers/DisplaySpecifiers-Win2k8.txt %%AD_DC%%%%DATADIR%%/setup/display-specifiers/DisplaySpecifiers-Win2k8R2.txt %%AD_DC%%%%DATADIR%%/setup/dns_update_list %%AD_DC%%%%DATADIR%%/setup/extended-rights.ldif %%AD_DC%%%%DATADIR%%/setup/fedora-ds-init.ldif %%AD_DC%%%%DATADIR%%/setup/fedorads-dna.ldif %%AD_DC%%%%DATADIR%%/setup/fedorads-index.ldif %%AD_DC%%%%DATADIR%%/setup/fedorads-linked-attributes.ldif %%AD_DC%%%%DATADIR%%/setup/fedorads-pam.ldif %%AD_DC%%%%DATADIR%%/setup/fedorads-partitions.ldif %%AD_DC%%%%DATADIR%%/setup/fedorads-refint-add.ldif %%AD_DC%%%%DATADIR%%/setup/fedorads-refint-delete.ldif %%AD_DC%%%%DATADIR%%/setup/fedorads-samba.ldif %%AD_DC%%%%DATADIR%%/setup/fedorads-sasl.ldif %%AD_DC%%%%DATADIR%%/setup/fedorads.inf %%AD_DC%%%%DATADIR%%/setup/idmap_init.ldif %%AD_DC%%%%DATADIR%%/setup/krb5.conf %%AD_DC%%%%DATADIR%%/setup/memberof.conf %%AD_DC%%%%DATADIR%%/setup/mmr_serverids.conf %%AD_DC%%%%DATADIR%%/setup/mmr_syncrepl.conf %%AD_DC%%%%DATADIR%%/setup/modules.conf %%AD_DC%%%%DATADIR%%/setup/named.conf %%AD_DC%%%%DATADIR%%/setup/named.conf.dlz %%AD_DC%%%%DATADIR%%/setup/named.conf.update %%AD_DC%%%%DATADIR%%/setup/named.txt %%AD_DC%%%%DATADIR%%/setup/olc_mmr.conf %%AD_DC%%%%DATADIR%%/setup/olc_seed.ldif %%AD_DC%%%%DATADIR%%/setup/olc_serverid.conf %%AD_DC%%%%DATADIR%%/setup/olc_syncrepl_seed.conf %%AD_DC%%%%DATADIR%%/setup/olc_syncrepl.conf %%AD_DC%%%%DATADIR%%/setup/prefixMap.txt %%AD_DC%%%%DATADIR%%/setup/provision_basedn_modify.ldif %%AD_DC%%%%DATADIR%%/setup/provision_basedn_options.ldif %%AD_DC%%%%DATADIR%%/setup/provision_basedn_references.ldif %%AD_DC%%%%DATADIR%%/setup/provision_basedn.ldif %%AD_DC%%%%DATADIR%%/setup/provision_computers_add.ldif %%AD_DC%%%%DATADIR%%/setup/provision_computers_modify.ldif %%AD_DC%%%%DATADIR%%/setup/provision_configuration_basedn.ldif %%AD_DC%%%%DATADIR%%/setup/provision_configuration_modify.ldif %%AD_DC%%%%DATADIR%%/setup/provision_configuration_references.ldif %%AD_DC%%%%DATADIR%%/setup/provision_configuration.ldif %%AD_DC%%%%DATADIR%%/setup/provision_dns_accounts_add.ldif %%AD_DC%%%%DATADIR%%/setup/provision_dns_add_samba.ldif %%AD_DC%%%%DATADIR%%/setup/provision_dnszones_add.ldif %%AD_DC%%%%DATADIR%%/setup/provision_dnszones_modify.ldif %%AD_DC%%%%DATADIR%%/setup/provision_dnszones_partitions.ldif %%AD_DC%%%%DATADIR%%/setup/provision_group_policy.ldif %%AD_DC%%%%DATADIR%%/setup/provision_init.ldif %%AD_DC%%%%DATADIR%%/setup/provision_partitions.ldif %%AD_DC%%%%DATADIR%%/setup/provision_privilege.ldif %%AD_DC%%%%DATADIR%%/setup/provision_rootdse_add.ldif %%AD_DC%%%%DATADIR%%/setup/provision_rootdse_modify.ldif %%AD_DC%%%%DATADIR%%/setup/provision_schema_basedn_modify.ldif %%AD_DC%%%%DATADIR%%/setup/provision_schema_basedn.ldif %%AD_DC%%%%DATADIR%%/setup/provision_self_join_config.ldif %%AD_DC%%%%DATADIR%%/setup/provision_self_join_modify_config.ldif %%AD_DC%%%%DATADIR%%/setup/provision_self_join_modify.ldif %%AD_DC%%%%DATADIR%%/setup/provision_self_join.ldif %%AD_DC%%%%DATADIR%%/setup/provision_users_add.ldif %%AD_DC%%%%DATADIR%%/setup/provision_users_modify.ldif %%AD_DC%%%%DATADIR%%/setup/provision_users.ldif %%AD_DC%%%%DATADIR%%/setup/provision_well_known_sec_princ.ldif %%AD_DC%%%%DATADIR%%/setup/provision.ldif %%AD_DC%%%%DATADIR%%/setup/provision.reg %%AD_DC%%%%DATADIR%%/setup/provision.zone %%AD_DC%%%%DATADIR%%/setup/refint.conf %%AD_DC%%%%DATADIR%%/setup/schema_samba4.ldif %%AD_DC%%%%DATADIR%%/setup/schema-map-fedora-ds-1.0 %%AD_DC%%%%DATADIR%%/setup/schema-map-openldap-2.3 %%AD_DC%%%%DATADIR%%/setup/secrets_dns.ldif %%AD_DC%%%%DATADIR%%/setup/secrets_init.ldif %%AD_DC%%%%DATADIR%%/setup/secrets_sasl_ldap.ldif %%AD_DC%%%%DATADIR%%/setup/secrets_simple_ldap.ldif %%AD_DC%%%%DATADIR%%/setup/secrets.ldif %%AD_DC%%%%DATADIR%%/setup/share.ldif %%AD_DC%%%%DATADIR%%/setup/slapd.conf %%AD_DC%%%%DATADIR%%/setup/spn_update_list %%AD_DC%%%%DATADIR%%/setup/ypServ30.ldif %%AD_DC%%@dir %%DATADIR%%/setup/display-specifiers %%AD_DC%%@dir %%DATADIR%%/setup/ad-schema %%AD_DC%%@dir %%DATADIR%%/setup %%AD_DC%%@dir %%DATADIR%% @comment Man pages man/man1/dbwrap_tool.1.gz man/man1/findsmb.1.gz man/man1/gentest.1.gz man/man1/locktest.1.gz man/man1/log2pcap.1.gz man/man1/masktest.1.gz man/man1/mvxattr.1.gz man/man1/ndrdump.1.gz man/man1/nmblookup.1.gz man/man1/ntlm_auth.1.gz man/man1/oLschema2ldif.1.gz man/man1/pidl.1.gz man/man1/profiles.1.gz man/man1/regdiff.1.gz man/man1/regpatch.1.gz man/man1/regshell.1.gz man/man1/regtree.1.gz man/man1/rpcclient.1.gz man/man1/sharesec.1.gz man/man1/smbcacls.1.gz man/man1/smbclient.1.gz man/man1/smbcontrol.1.gz man/man1/smbcquotas.1.gz man/man1/smbget.1.gz man/man1/smbstatus.1.gz man/man1/smbtar.1.gz %%SAMBA4_PYTHON2%%man/man1/smbtorture.1.gz man/man1/smbtree.1.gz man/man1/testparm.1.gz man/man1/vfstest.1.gz man/man1/wbinfo.1.gz man/man3/Parse::Pidl::Dump.3.gz man/man3/Parse::Pidl::NDR.3.gz man/man3/Parse::Pidl::Util.3.gz man/man3/Parse::Pidl::Wireshark::Conformance.3.gz man/man3/Parse::Pidl::Wireshark::NDR.3.gz man/man5/lmhosts.5.gz man/man5/pam_winbind.conf.5.gz man/man5/smb.conf.5.gz man/man5/smb4.conf.5.gz man/man5/smbgetrc.5.gz man/man5/smbpasswd.5.gz man/man7/libsmbclient.7.gz man/man7/samba.7.gz man/man7/traffic_learner.7.gz man/man7/traffic_replay.7.gz man/man8/cifsdd.8.gz man/man8/eventlogadm.8.gz man/man8/idmap_ad.8.gz man/man8/idmap_autorid.8.gz man/man8/idmap_hash.8.gz man/man8/idmap_ldap.8.gz man/man8/idmap_nss.8.gz man/man8/idmap_rfc2307.8.gz man/man8/idmap_rid.8.gz man/man8/idmap_script.8.gz man/man8/idmap_tdb.8.gz man/man8/idmap_tdb2.8.gz man/man8/net.8.gz man/man8/nmbd.8.gz man/man8/pam_winbind.8.gz man/man8/pdbedit.8.gz man/man8/samba_gpoupdate.8.gz man/man8/samba-regedit.8.gz man/man8/samba-tool.8.gz man/man8/samba.8.gz man/man8/smbd.8.gz man/man8/smbpasswd.8.gz man/man8/smbspool_krb5_wrapper.8.gz man/man8/smbspool.8.gz man/man8/vfs_acl_tdb.8.gz man/man8/vfs_acl_xattr.8.gz man/man8/vfs_aio_fork.8.gz man/man8/vfs_aio_pthread.8.gz man/man8/vfs_audit.8.gz man/man8/vfs_cacheprime.8.gz man/man8/vfs_cap.8.gz man/man8/vfs_catia.8.gz man/man8/vfs_commit.8.gz man/man8/vfs_crossrename.8.gz man/man8/vfs_default_quota.8.gz man/man8/vfs_dirsort.8.gz man/man8/vfs_extd_audit.8.gz man/man8/vfs_fake_perms.8.gz man/man8/vfs_fileid.8.gz man/man8/vfs_fruit.8.gz man/man8/vfs_full_audit.8.gz man/man8/vfs_glusterfs.8.gz +man/man8/vfs_glusterfs_fuse.8.gz man/man8/vfs_linux_xfs_sgid.8.gz man/man8/vfs_media_harmony.8.gz man/man8/vfs_netatalk.8.gz man/man8/vfs_nfs4acl_xattr.8.gz man/man8/vfs_offline.8.gz man/man8/vfs_prealloc.8.gz man/man8/vfs_preopen.8.gz man/man8/vfs_readahead.8.gz man/man8/vfs_readonly.8.gz man/man8/vfs_recycle.8.gz man/man8/vfs_shadow_copy.8.gz man/man8/vfs_shadow_copy2.8.gz man/man8/vfs_shell_snap.8.gz man/man8/vfs_snapper.8.gz man/man8/vfs_streams_depot.8.gz man/man8/vfs_streams_xattr.8.gz man/man8/vfs_syncops.8.gz man/man8/vfs_time_audit.8.gz man/man8/vfs_tsmsm.8.gz man/man8/vfs_unityed_media.8.gz man/man8/vfs_virusfilter.8.gz man/man8/vfs_worm.8.gz man/man8/vfs_xattr_tdb.8.gz man/man8/vfs_zfsacl.8.gz man/man8/winbind_krb5_locator.8.gz man/man8/winbindd.8.gz @dir %%SAMBA4_RUNDIR%% @dir %%SAMBA4_LOGDIR%% @dir %%SAMBA4_LOCKDIR%% @dir %%SAMBA4_PRIVATEDIR%% @dir %%SAMBA4_BINDDNSDIR%% @comment Cluster %%CLUSTER%%bin/ctdb %%CLUSTER%%bin/ctdb_diagnostics %%CLUSTER%%bin/ltdbtool %%CLUSTER%%bin/onnode %%CLUSTER%%bin/ping_pong %%CLUSTER%%sbin/ctdbd %%CLUSTER%%sbin/ctdbd_wrapper %%CLUSTER%%etc/ctdb/ctdb-crash-cleanup.sh %%CLUSTER%%etc/ctdb/debug-hung-script.sh %%CLUSTER%%etc/ctdb/debug_locks.sh %%CLUSTER%%etc/ctdb/events.d/00.ctdb %%CLUSTER%%etc/ctdb/events.d/01.reclock %%CLUSTER%%etc/ctdb/events.d/05.system %%CLUSTER%%etc/ctdb/events.d/06.nfs %%CLUSTER%%etc/ctdb/events.d/10.external %%CLUSTER%%etc/ctdb/events.d/10.interface %%CLUSTER%%etc/ctdb/events.d/11.natgw %%CLUSTER%%etc/ctdb/events.d/11.routing %%CLUSTER%%etc/ctdb/events.d/13.per_ip_routing %%CLUSTER%%etc/ctdb/events.d/20.multipathd %%CLUSTER%%etc/ctdb/events.d/31.clamd %%CLUSTER%%etc/ctdb/events.d/40.vsftpd %%CLUSTER%%etc/ctdb/events.d/41.httpd %%CLUSTER%%etc/ctdb/events.d/49.winbind %%CLUSTER%%etc/ctdb/events.d/50.samba %%CLUSTER%%etc/ctdb/events.d/60.nfs %%CLUSTER%%etc/ctdb/events.d/70.iscsi %%CLUSTER%%etc/ctdb/events.d/91.lvs %%CLUSTER%%etc/ctdb/events.d/99.timeout %%CLUSTER%%etc/ctdb/events.d/README %%CLUSTER%%etc/ctdb/functions %%CLUSTER%%etc/ctdb/gcore_trace.sh %%CLUSTER%%etc/ctdb/nfs-checks.d/00.portmapper.check %%CLUSTER%%etc/ctdb/nfs-checks.d/10.status.check %%CLUSTER%%etc/ctdb/nfs-checks.d/20.nfs.check %%CLUSTER%%etc/ctdb/nfs-checks.d/30.nlockmgr.check %%CLUSTER%%etc/ctdb/nfs-checks.d/40.mountd.check %%CLUSTER%%etc/ctdb/nfs-checks.d/50.rquotad.check %%CLUSTER%%etc/ctdb/nfs-checks.d/README %%CLUSTER%%etc/ctdb/nfs-linux-kernel-callout %%CLUSTER%%etc/ctdb/notify.d/README %%CLUSTER%%etc/ctdb/notify.sh %%CLUSTER%%etc/ctdb/statd-callout %%CLUSTER%%etc/sudoers.d/ctdb %%CLUSTER%%libexec/ctdb/ctdb_event %%CLUSTER%%libexec/ctdb/ctdb_eventd %%CLUSTER%%libexec/ctdb/ctdb_killtcp %%CLUSTER%%libexec/ctdb/ctdb_lock_helper %%CLUSTER%%libexec/ctdb/ctdb_lvs %%CLUSTER%%libexec/ctdb/ctdb_mutex_fcntl_helper %%CLUSTER%%libexec/ctdb/ctdb_natgw %%CLUSTER%%libexec/ctdb/ctdb_recovery_helper %%CLUSTER%%libexec/ctdb/ctdb_takeover_helper %%CLUSTER%%libexec/ctdb/smnotify %%CLUSTER%%man/man1/ctdb.1.gz %%CLUSTER%%man/man1/ctdb_diagnostics.1.gz %%CLUSTER%%man/man1/ctdbd.1.gz %%CLUSTER%%man/man1/ctdbd_wrapper.1.gz %%CLUSTER%%man/man1/ltdbtool.1.gz %%CLUSTER%%man/man1/onnode.1.gz %%CLUSTER%%man/man1/ping_pong.1.gz %%CLUSTER%%man/man5/ctdbd.conf.5.gz %%CLUSTER%%man/man7/ctdb-statistics.7.gz %%CLUSTER%%man/man7/ctdb-tunables.7.gz %%CLUSTER%%man/man7/ctdb.7.gz %%CLUSTER%%@dir /var/lib/ctdb %%CLUSTER%%@dir /var/lib %%CLUSTER%%@dir /var/run/ctdb @comment Use bundled libraries %%SAMBA4_BUNDLED_LDB%%bin/ldbadd %%SAMBA4_BUNDLED_LDB%%bin/ldbdel %%SAMBA4_BUNDLED_LDB%%bin/ldbedit %%SAMBA4_BUNDLED_LDB%%bin/ldbmodify %%SAMBA4_BUNDLED_LDB%%bin/ldbrename %%SAMBA4_BUNDLED_LDB%%bin/ldbsearch %%SAMBA4_BUNDLED_TDB%%bin/tdbbackup %%SAMBA4_BUNDLED_TDB%%bin/tdbdump %%SAMBA4_BUNDLED_TDB%%bin/tdbrestore %%SAMBA4_BUNDLED_TDB%%bin/tdbtool %%SAMBA4_BUNDLED_LDB%%%%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/_ldb_text.py %%SAMBA4_BUNDLED_TDB%%%%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/_tdb_text.py %%SAMBA4_BUNDLED_TEVENT%%%%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/_tevent.so %%SAMBA4_BUNDLED_LDB%%%%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/ldb.so %%SAMBA4_BUNDLED_TALLOC%%%%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/talloc.so %%SAMBA4_BUNDLED_TDB%%%%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/tdb.so %%SAMBA4_BUNDLED_TEVENT%%%%SAMBA4_PYTHON2%%%%PYTHON_SITELIBDIR%%/tevent.py %%SAMBA4_BUNDLED_LDB%%%%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/_ldb_text.py %%SAMBA4_BUNDLED_TDB%%%%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/_tdb_text.py %%SAMBA4_BUNDLED_TEVENT%%%%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/_tevent.cpython-36m.so %%SAMBA4_BUNDLED_LDB%%%%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/ldb.cpython-36m.so %%SAMBA4_BUNDLED_TALLOC%%%%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/talloc.cpython-36m.so %%SAMBA4_BUNDLED_TDB%%%%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/tdb.cpython-36m.so %%SAMBA4_BUNDLED_TEVENT%%%%SAMBA4_PYTHON3%%%%SAMBA4_PYTHON3_SITELIBDIR%%/tevent.py %%SAMBA4_BUNDLED_CMOCKA%%lib/samba4/private/libcmocka-samba4.so %%SAMBA4_BUNDLED_LDB%%lib/samba4/private/libldb-cmdline-samba4.so %%SAMBA4_BUNDLED_LDB%%lib/samba4/private/libldb.so.1 %%SAMBA4_BUNDLED_LDB%%%%SAMBA4_PYTHON3%%lib/samba4/private/libpyldb-util.cpython-36m.so.1 %%SAMBA4_BUNDLED_LDB%%%%SAMBA4_PYTHON2%%lib/samba4/private/libpyldb-util.so.1 %%SAMBA4_BUNDLED_TALLOC%%%%SAMBA4_PYTHON3%%lib/samba4/private/libpytalloc-util.cpython-36m.so.2 %%SAMBA4_BUNDLED_TALLOC%%%%SAMBA4_PYTHON2%%lib/samba4/private/libpytalloc-util.so.2 %%SAMBA4_BUNDLED_TALLOC%%lib/samba4/private/libtalloc.so.2 %%SAMBA4_BUNDLED_TDB%%lib/samba4/private/libtdb.so.1 %%SAMBA4_BUNDLED_TEVENT%%lib/samba4/private/libtevent.so.0 %%SAMBA4_BUNDLED_LDB%%lib/shared-modules/ldb/asq.so %%SAMBA4_BUNDLED_LDB%%lib/shared-modules/ldb/paged_results.so %%SAMBA4_BUNDLED_LDB%%lib/shared-modules/ldb/paged_searches.so %%SAMBA4_BUNDLED_LDB%%lib/shared-modules/ldb/rdn_name.so %%SAMBA4_BUNDLED_LDB%%lib/shared-modules/ldb/sample.so %%SAMBA4_BUNDLED_LDB%%lib/shared-modules/ldb/server_sort.so %%SAMBA4_BUNDLED_LDB%%lib/shared-modules/ldb/skel.so %%SAMBA4_BUNDLED_LDB%%lib/shared-modules/ldb/tdb.so %%SAMBA4_BUNDLED_LDB%%man/man1/ldbadd.1.gz %%SAMBA4_BUNDLED_LDB%%man/man1/ldbdel.1.gz %%SAMBA4_BUNDLED_LDB%%man/man1/ldbedit.1.gz %%SAMBA4_BUNDLED_LDB%%man/man1/ldbmodify.1.gz %%SAMBA4_BUNDLED_LDB%%man/man1/ldbrename.1.gz %%SAMBA4_BUNDLED_LDB%%man/man1/ldbsearch.1.gz %%SAMBA4_BUNDLED_LDB%%man/man3/ldb.3.gz %%SAMBA4_BUNDLED_TALLOC%%man/man3/talloc.3.gz %%SAMBA4_BUNDLED_TDB%%man/man8/tdbbackup.8.gz %%SAMBA4_BUNDLED_TDB%%man/man8/tdbdump.8.gz %%SAMBA4_BUNDLED_TDB%%man/man8/tdbrestore.8.gz %%SAMBA4_BUNDLED_TDB%%man/man8/tdbtool.8.gz