forked from gentoo/gentoo
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
net-fs/samba: commit samba-4.4rc2 with proper Manifest
Recommit bedb32a but with proper Manifest Package-Manager: portage-2.2.26
- Loading branch information
1 parent
64749b6
commit e005579
Showing
5 changed files
with
358 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
# Add "winbind" to the daemon_list if you also want winbind to start. | ||
# Replace "smbd nmbd" by "samba4" if you want the active directory domain controller part or the ntvfs | ||
# file server part or the rpc proxy to start. | ||
# Note that samba4 controls 'smbd' by itself, thus it can't be started manually. You can, however, | ||
# tweak the behaviour of a samba4-controlled smbd by modifying your '/etc/samba/smb.conf' file | ||
# accordingly. | ||
daemon_list="smbd nmbd" | ||
|
||
#---------------------------------------------------------------------------- | ||
# Daemons calls: <daemon_name>_<command_option> | ||
#---------------------------------------------------------------------------- | ||
my_service_name="samba" | ||
my_service_PRE="unset TMP TMPDIR" | ||
my_service_POST="" | ||
|
||
#---------------------------------------------------------------------------- | ||
# Daemons calls: <daemon_name>_<command_option> | ||
#---------------------------------------------------------------------------- | ||
smbd_start_options="-D" | ||
smbd_start="start-stop-daemon --start --exec /usr/sbin/smbd -- ${smbd_start_options}" | ||
smbd_stop="start-stop-daemon --stop --exec /usr/sbin/smbd" | ||
smbd_reload="killall -HUP smbd" | ||
|
||
nmbd_start_options="-D" | ||
nmbd_start="start-stop-daemon --start --exec /usr/sbin/nmbd -- ${nmbd_start_options}" | ||
nmbd_stop="start-stop-daemon --stop --exec /usr/sbin/nmbd" | ||
nmbd_reload="killall -HUP nmbd" | ||
|
||
samba4_start_options="" | ||
samba4_start="start-stop-daemon --start --exec /usr/sbin/samba -- ${samba4_start_options}" | ||
samba4_stop="start-stop-daemon --stop --exec /usr/sbin/samba" | ||
samba4_reload="killall -HUP samba" | ||
|
||
winbind_start_options="" | ||
winbind_start="start-stop-daemon --start --exec /usr/sbin/winbindd -- ${winbind_start_options}" | ||
winbind_stop="start-stop-daemon --stop --exec /usr/sbin/winbindd" | ||
winbind_reload="killall -HUP winbindd" | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
#!/sbin/runscript | ||
# Copyright 1999-2015 Gentoo Foundation | ||
# Distributed under the terms of the GNU General Public License, v2 or later | ||
# $Id$ | ||
|
||
extra_started_commands="reload" | ||
piddir="/var/run/samba" | ||
|
||
depend() { | ||
after slapd | ||
need net | ||
use cupsd | ||
} | ||
|
||
DAEMONNAME="${SVCNAME##samba.}" | ||
[ "${DAEMONNAME}" != "samba" ] && daemon_list=${DAEMONNAME} | ||
|
||
signal_do() { | ||
local signal="$1" | ||
[ -z "${signal}" ] && return 0 | ||
|
||
local result=0 last_result=0 daemon= cmd_exec= | ||
for daemon in ${daemon_list} ; do | ||
eval cmd_exec=\$${daemon}_${signal} | ||
if [ -n "${cmd_exec}" ]; then | ||
ebegin "${my_service_name} -> ${signal}: ${daemon}" | ||
#echo ${cmd} '->' ${!cmd} | ||
${cmd_exec} > /dev/null | ||
last_result=$? | ||
eend ${last_result} | ||
fi | ||
result=$(( ${result} + ${last_result} )) | ||
done | ||
return ${result} | ||
} | ||
|
||
start() { | ||
${my_service_PRE} | ||
[ -d "${piddir}" ] || mkdir -p "${piddir}" | ||
signal_do start && return 0 | ||
|
||
eerror "Error: starting services (see system logs)" | ||
signal_do stop | ||
return 1 | ||
} | ||
stop() { | ||
${my_service_PRE} | ||
if signal_do stop ; then | ||
${my_service_POST} | ||
return 0 | ||
fi | ||
} | ||
reload() { | ||
${my_service_PRE} | ||
signal_do reload | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
--- a/samba-4.4.0rc2/source3/wscript 2016-01-26 15:25:54.000000000 -0500 | ||
+++ b/samba-4.4.0rc2/source3/wscript 2016-02-09 14:37:46.385279942 -0500 | ||
@@ -870,7 +870,7 @@ | ||
if conf.env.with_iconv: | ||
conf.DEFINE('HAVE_ICONV', 1) | ||
|
||
- if Options.options.with_pam: | ||
+ if Options.options.with_pam != False: | ||
use_pam=True | ||
conf.CHECK_HEADERS('security/pam_appl.h pam/pam_appl.h') | ||
if not conf.CONFIG_SET('HAVE_SECURITY_PAM_APPL_H') and not conf.CONFIG_SET('HAVE_PAM_PAM_APPL_H'): | ||
@@ -943,6 +943,17 @@ | ||
conf.DEFINE('WITH_PAM', 1) | ||
conf.DEFINE('WITH_PAM_MODULES', 1) | ||
|
||
+ else: | ||
+ Logs.warn("PAM disabled") | ||
+ use_pam=False | ||
+ conf.undefine('WITH_PAM') | ||
+ conf.undefine('WITH_PAM_MODULES') | ||
+ conf.undefine('HAVE_SECURITY_PAM_APPL_H') | ||
+ conf.undefine('PAM_RHOST') | ||
+ conf.undefine('PAM_TTY') | ||
+ conf.undefine('HAVE_PAM_PAM_APPL_H') | ||
+ | ||
+ | ||
seteuid = False | ||
|
||
# |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,233 @@ | ||
# Copyright 1999-2016 Gentoo Foundation | ||
# Distributed under the terms of the GNU General Public License v2 | ||
# $Id$ | ||
|
||
EAPI=5 | ||
PYTHON_COMPAT=( python2_7 ) | ||
PYTHON_REQ_USE='threads(+),xml(+)' | ||
|
||
inherit python-single-r1 waf-utils multilib-minimal linux-info systemd eutils | ||
|
||
MY_PV="${PV/_rc/rc}" | ||
MY_P="${PN}-${MY_PV}" | ||
|
||
SRC_PATH="stable" | ||
[[ ${PV} = *_rc* ]] && SRC_PATH="rc" | ||
|
||
SRC_URI="mirror://samba/${SRC_PATH}/${MY_P}.tar.gz | ||
https://dev.gentoo.org/~axs/distfiles/samba-disable-python-patches-4.4.0.tar.xz" | ||
KEYWORDS="~amd64 ~hppa ~x86" | ||
[[ ${PV} = *_rc* ]] && KEYWORDS="~hppa" | ||
|
||
DESCRIPTION="Samba Suite Version 4" | ||
HOMEPAGE="http://www.samba.org/" | ||
LICENSE="GPL-3" | ||
|
||
SLOT="0" | ||
|
||
IUSE="acl addc addns ads avahi client cluster cups dmapi fam gnutls iprint | ||
ldap pam quota selinux syslog +system-mitkrb5 systemd test winbind" | ||
|
||
MULTILIB_WRAPPED_HEADERS=( | ||
/usr/include/samba-4.0/policy.h | ||
/usr/include/samba-4.0/dcerpc_server.h | ||
/usr/include/samba-4.0/ctdb.h | ||
/usr/include/samba-4.0/ctdb_client.h | ||
/usr/include/samba-4.0/ctdb_protocol.h | ||
/usr/include/samba-4.0/ctdb_private.h | ||
/usr/include/samba-4.0/ctdb_typesafe_cb.h | ||
/usr/include/samba-4.0/ctdb_version.h | ||
) | ||
|
||
# sys-apps/attr is an automagic dependency (see bug #489748) | ||
CDEPEND="${PYTHON_DEPS} | ||
>=app-arch/libarchive-3.1.2[${MULTILIB_USEDEP}] | ||
dev-libs/libbsd[${MULTILIB_USEDEP}] | ||
dev-libs/iniparser:0 | ||
dev-libs/popt[${MULTILIB_USEDEP}] | ||
sys-libs/readline:= | ||
virtual/libiconv | ||
dev-python/subunit[${PYTHON_USEDEP},${MULTILIB_USEDEP}] | ||
>=net-libs/socket_wrapper-1.1.3[${MULTILIB_USEDEP}] | ||
sys-apps/attr[${MULTILIB_USEDEP}] | ||
sys-libs/libcap | ||
>=sys-libs/ldb-1.1.25[${MULTILIB_USEDEP}] | ||
sys-libs/ncurses:0=[${MULTILIB_USEDEP}] | ||
>=sys-libs/nss_wrapper-1.0.3[${MULTILIB_USEDEP}] | ||
>=sys-libs/talloc-2.1.3[python,${PYTHON_USEDEP},${MULTILIB_USEDEP}] | ||
>=sys-libs/tdb-1.3.7[python,${PYTHON_USEDEP},${MULTILIB_USEDEP}] | ||
>=sys-libs/tevent-0.9.25[${MULTILIB_USEDEP}] | ||
>=sys-libs/uid_wrapper-1.1.0[${MULTILIB_USEDEP}] | ||
sys-libs/zlib[${MULTILIB_USEDEP}] | ||
virtual/pam | ||
acl? ( virtual/acl ) | ||
addns? ( net-dns/bind-tools[gssapi] ) | ||
cluster? ( !dev-db/ctdb ) | ||
cups? ( net-print/cups ) | ||
dmapi? ( sys-apps/dmapi ) | ||
fam? ( virtual/fam ) | ||
gnutls? ( dev-libs/libgcrypt:0 | ||
>=net-libs/gnutls-1.4.0 ) | ||
ldap? ( net-nds/openldap[${MULTILIB_USEDEP}] ) | ||
system-mitkrb5? ( app-crypt/mit-krb5[${MULTILIB_USEDEP}] ) | ||
!system-mitkrb5? ( >=app-crypt/heimdal-1.5[-ssl,${MULTILIB_USEDEP}] ) | ||
systemd? ( sys-apps/systemd:0= )" | ||
DEPEND="${CDEPEND} | ||
virtual/pkgconfig" | ||
RDEPEND="${CDEPEND} | ||
client? ( net-fs/cifs-utils[ads?] ) | ||
selinux? ( sec-policy/selinux-samba ) | ||
" | ||
|
||
REQUIRED_USE="addc? ( gnutls !system-mitkrb5 ) | ||
ads? ( acl gnutls ldap ) | ||
${PYTHON_REQUIRED_USE}" | ||
|
||
S="${WORKDIR}/${MY_P}" | ||
|
||
PATCHES=( | ||
"${FILESDIR}/${PN}-4.2.3-heimdal_compilefix.patch" | ||
"${FILESDIR}/${PN}-4.4.0-pam.patch" | ||
) | ||
|
||
CONFDIR="${FILESDIR}/$(get_version_component_range 1-2)" | ||
|
||
WAF_BINARY="${S}/buildtools/bin/waf" | ||
|
||
SHAREDMODS="" | ||
|
||
pkg_setup() { | ||
python-single-r1_pkg_setup | ||
if use cluster ; then | ||
SHAREDMODS="${SHAREDMODS}idmap_rid,idmap_tdb2,idmap_ad" | ||
fi | ||
} | ||
|
||
src_prepare() { | ||
epatch ${PATCHES[@]} | ||
|
||
# install the patches from tarball(s) | ||
EPATCH_SUFFIX="patch" \ | ||
EPATCH_FORCE="yes" \ | ||
epatch "${WORKDIR}/patches" | ||
|
||
# Allow user patches | ||
epatch_user | ||
multilib_copy_sources | ||
} | ||
|
||
multilib_src_configure() { | ||
local myconf=() | ||
myconf=( | ||
--enable-fhs | ||
--sysconfdir=/etc | ||
--localstatedir=/var | ||
--with-modulesdir=/usr/$(get_libdir)/samba | ||
--with-piddir=/var/run/${PN} | ||
--bundled-libraries=NONE | ||
--builtin-libraries=NONE | ||
--disable-rpath | ||
--disable-rpath-install | ||
--nopyc | ||
--nopyo | ||
) | ||
if multilib_is_native_abi ; then | ||
myconf+=( | ||
$(use_with acl acl-support) | ||
$(usex addc '' '--without-ad-dc') | ||
$(use_with addns dnsupdate) | ||
$(use_with ads) | ||
$(usex ads '--with-shared-modules=idmap_ad' '') | ||
$(use_enable avahi) | ||
$(use_with cluster cluster-support) | ||
$(use_enable cups) | ||
$(use_with dmapi) | ||
$(use_with fam) | ||
$(use_enable gnutls) | ||
$(use_enable iprint) | ||
$(use_with ldap) | ||
$(use_with pam) | ||
$(usex pam "--with-pammodulesdir=/$(get_libdir)/security" '') | ||
$(use_with quota quotas) | ||
$(use_with syslog) | ||
$(use_with systemd) | ||
$(usex system-mitkrb5 '--with-system-mitkrb5' '') | ||
$(use_with winbind) | ||
$(usex test '--enable-selftest' '') | ||
--with-shared-modules=${SHAREDMODS} | ||
) | ||
else | ||
myconf+=( | ||
--without-acl-support | ||
--without-ad-dc | ||
--without-dnsupdate | ||
--without-ads | ||
--disable-avahi | ||
--without-cluster-support | ||
--disable-cups | ||
--without-dmapi | ||
--without-fam | ||
--disable-gnutls | ||
--disable-iprint | ||
$(use_with ldap) | ||
--without-pam | ||
--without-quotas | ||
--without-syslog | ||
--without-systemd | ||
$(usex system-mitkrb5 '--with-system-mitkrb5' '') | ||
--without-winbind | ||
--disable-python | ||
) | ||
fi | ||
|
||
CPPFLAGS="-I${SYSROOT}/usr/include/et ${CPPFLAGS}" \ | ||
waf-utils_src_configure ${myconf[@]} | ||
} | ||
|
||
multilib_src_install() { | ||
waf-utils_src_install | ||
|
||
# Make all .so files executable | ||
find "${D}" -type f -name "*.so" -exec chmod +x {} + | ||
|
||
if multilib_is_native_abi; then | ||
# install ldap schema for server (bug #491002) | ||
if use ldap ; then | ||
insinto /etc/openldap/schema | ||
doins examples/LDAP/samba.schema | ||
fi | ||
|
||
# install example config file | ||
insinto /etc/samba | ||
doins examples/smb.conf.default | ||
|
||
# Install init script and conf.d file | ||
newinitd "${CONFDIR}/samba4.initd-r1" samba | ||
newconfd "${CONFDIR}/samba4.confd" samba | ||
|
||
systemd_dotmpfilesd "${FILESDIR}"/samba.conf | ||
systemd_dounit "${FILESDIR}"/nmbd.service | ||
systemd_dounit "${FILESDIR}"/smbd.{service,socket} | ||
systemd_newunit "${FILESDIR}"/smbd_at.service '[email protected]' | ||
systemd_dounit "${FILESDIR}"/winbindd.service | ||
systemd_dounit "${FILESDIR}"/samba.service | ||
fi | ||
} | ||
|
||
multilib_src_test() { | ||
if multilib_is_native_abi ; then | ||
"${WAF_BINARY}" test || die "test failed" | ||
fi | ||
} | ||
|
||
pkg_postinst() { | ||
ewarn "Be aware the this release contains the best of all of Samba's" | ||
ewarn "technology parts, both a file server (that you can reasonably expect" | ||
ewarn "to upgrade existing Samba 3.x releases to) and the AD domain" | ||
ewarn "controller work previously known as 'samba4'." | ||
|
||
elog "For further information and migration steps make sure to read " | ||
elog "http://samba.org/samba/history/${P}.html " | ||
elog "http://samba.org/samba/history/${PN}-4.2.0.html and" | ||
elog "http://wiki.samba.org/index.php/Samba4/HOWTO " | ||
} |