diff options
author | Tony Vroon <chainsaw@gentoo.org> | 2009-10-28 12:26:05 +0000 |
---|---|---|
committer | Tony Vroon <chainsaw@gentoo.org> | 2009-10-28 12:26:05 +0000 |
commit | 9503cd33725f0534783e5985c4319194b812ca8a (patch) | |
tree | 39da5c0ca697e96471c096b360e98988cddf58de /net-misc/asterisk | |
parent | moved terminfo generation to ncurses wrt bug #192083 (diff) | |
download | gentoo-2-9503cd33725f0534783e5985c4319194b812ca8a.tar.gz gentoo-2-9503cd33725f0534783e5985c4319194b812ca8a.tar.bz2 gentoo-2-9503cd33725f0534783e5985c4319194b812ca8a.zip |
H323 depends on pwlib which is going away. Unable to migrate to ptlib as libopenh323 *also* depends on pwlib. You can still get H323 support through asterisk-addons. As requested by Mounir "volkmar" Lamouri in bug #290065.
(Portage version: 2.1.7.1/cvs/Linux x86_64)
Diffstat (limited to 'net-misc/asterisk')
6 files changed, 415 insertions, 47 deletions
diff --git a/net-misc/asterisk/ChangeLog b/net-misc/asterisk/ChangeLog index 57667d61ff9d..7ad3e32b282d 100644 --- a/net-misc/asterisk/ChangeLog +++ b/net-misc/asterisk/ChangeLog @@ -1,6 +1,18 @@ # ChangeLog for net-misc/asterisk # Copyright 1999-2009 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/net-misc/asterisk/ChangeLog,v 1.220 2009/10/28 11:31:03 chainsaw Exp $ +# $Header: /var/cvsroot/gentoo-x86/net-misc/asterisk/ChangeLog,v 1.221 2009/10/28 12:26:04 chainsaw Exp $ + +*asterisk-1.2.35-r1 (28 Oct 2009) + + 28 Oct 2009; <chainsaw@gentoo.org> + -files/1.2.0/asterisk-1.2.31.1-bri-fixups.diff, + -files/1.2.0/asterisk-1.2.31.1-svn89254.diff, + -files/1.2.0/asterisk-1.2.32-comma-is-not-pipe.diff, + -files/1.2.0/asterisk-1.2.32-svn89254.diff, +asterisk-1.2.35-r1.ebuild: + H323 depends on pwlib which is going away. Unable to migrate to ptlib as + libopenh323 *also* depends on pwlib. You can still get H323 support + through asterisk-addons. As requested by Mounir "volkmar" Lamouri in bug + #290065. 28 Oct 2009; <chainsaw@gentoo.org> asterisk-1.6.1.8.ebuild: Explicitly block zaptel prior to unmasking. diff --git a/net-misc/asterisk/asterisk-1.2.35-r1.ebuild b/net-misc/asterisk/asterisk-1.2.35-r1.ebuild new file mode 100644 index 000000000000..6ecde727d50d --- /dev/null +++ b/net-misc/asterisk/asterisk-1.2.35-r1.ebuild @@ -0,0 +1,402 @@ +# Copyright 1999-2009 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/net-misc/asterisk/asterisk-1.2.35-r1.ebuild,v 1.1 2009/10/28 12:26:04 chainsaw Exp $ + +EAPI=2 +inherit eutils multilib toolchain-funcs + +IUSE="alsa curl debug doc gtk hardened lowmem mmx nosamples \ + odbc osp postgres pri sqlite ssl speex zaptel elibc_uclibc" + +AST_PATCHES="1.2.27-patches-1.0" + +MY_P="${P/_p/.}" + +DESCRIPTION="Asterisk: A Modular Open Source PBX System" +HOMEPAGE="http://www.asterisk.org/" +SRC_URI="http://downloads.digium.com/pub/asterisk/releases/${MY_P}.tar.gz + mirror://gentoo/${PN}-${AST_PATCHES}.tar.bz2" + +S="${WORKDIR}/${MY_P}" + +SLOT="0" +LICENSE="GPL-2" +KEYWORDS="~alpha ~amd64 ~hppa ~ppc ~sparc ~x86" + +RDEPEND="dev-libs/newt + media-sound/sox + ssl? ( dev-libs/openssl ) + gtk? ( =x11-libs/gtk+-1.2* ) + pri? ( =net-libs/libpri-1.2*[-bri] ) + alsa? ( media-libs/alsa-lib ) + curl? ( net-misc/curl ) + odbc? ( dev-db/unixODBC ) + speex? ( media-libs/speex ) + sqlite? ( <dev-db/sqlite-3.0.0 ) + zaptel? ( >=net-misc/zaptel-1.2.16 ) + postgres? ( virtual/postgresql-base ) + osp? ( >=net-libs/osptoolkit-3.3.4 )" + +DEPEND="${RDEPEND} + sys-devel/flex + sys-devel/bison + doc? ( app-doc/doxygen ) + virtual/logger" + +#asterisk uses special mpg123 functions and does not work with mpeg321, bug #42703 +PDEPEND="|| ( media-sound/mpg123 net-misc/asterisk-addons )" + +QA_TEXTRELS_x86="usr/lib/asterisk/modules/codec_gsm.so" +QA_EXECSTACK_x86="usr/lib/asterisk/modules/codec_gsm.so" + +# +# List of modules to ignore during scan (because they have been removed in 1.2.x) +# +SCAN_IGNORE_MODS=" + app_qcall + chan_modem + chan_modem_i4l + chan_modem_bestdata + chan_modme_aopen" + +# +# shortcuts +# +is_ast10update() { + return $(has_version "=net-misc/asterisk-1.0*") +} + +is_astupdate() { + if ! is_ast10update; then + return $(has_version "<net-misc/asterisk-${PV}") + fi + return 0 +} + +# +# Scan for asterisk-1.0.x modules that will have to be updated +# +scan_modules() { + local modules_list="" + local n + + for x in $(ls -1 "${ROOT}"usr/$(get_libdir)/asterisk/modules/*.so); do + echo -en "Scanning.... $(basename ${x}) \r" + + # skip blacklisted modules + hasq $(basename ${x//.so}) ${SCAN_IGNORE_MODS} && continue + + if $(readelf -s "${x}" | grep -q "\(ast_load\|ast_destroy\)$"); then + modules_list="${modules_list} $(basename ${x//.so})" + fi + done + + if [[ -n "${modules_list}" ]]; then + echo " ========================================================" + ewarn "Please update or unmerge the following modules:" + echo + + n=0 + for x in ${modules_list}; do + ewarn " - ${x}" + (( n++ )) + done + + echo + ewarn "Warning: $n outdated module(s) found!" + ewarn "Warning: asterisk may not work if you don't update them!" + echo " ========================================================" + echo + einfo "You can use the \"asterisk-updater\" script to update the modules" + epause + echo + return 1 + else + einfo "No asterisk-1.0.x modules found!" + return 0 + fi +} + +pkg_setup() { + local checkfailed=0 waitaftermsg=0 + + if is_ast10update; then + ewarn " Asterisk UPGRADE Warning" + ewarn "" + ewarn "- Please read "${ROOT}"usr/share/doc/${PF}/UPGRADE.txt.gz after the installation!" + ewarn "" + ewarn " Asterisk UPGRADE Warning" + echo + waitaftermsg=1 + fi + + # + # Regular checks + # + einfo "Running some pre-flight checks..." + echo + +} + +src_prepare() { + # + # gentoo patchset + # + for x in $(grep -v "^#\| \+" "${WORKDIR}"/patches/patches.list); do + epatch "${WORKDIR}"/patches/${x} + done + + if use mmx; then + if ! use hardened; then + einfo "Enabling mmx optimization" + sed -i -e "s:^#\(K6OPT[\t ]\+= -DK6OPT\):\1:" \ + Makefile + else + ewarn "Hardened use-flag is set, not enabling mmx optimization for codec_gsm!" + fi + fi + + if ! use debug; then + einfo "Disabling debug support" + sed -i -e "s:^\(DEBUG=\):#\1:" \ + Makefile + fi + + if ! use ssl; then + einfo "Disabling crypto support" + sed -i -e 's:^#\(NOCRYPTO=yes\):\1:' \ + -e '/^LIBS+=-lssl/d' Makefile || die + fi + + epatch "${FILESDIR}/1.2.0/${P}-lpc10-prototypes.diff" + + # + # uclibc patch + # + if use elibc_uclibc; then + einfo "Patching asterisk for uclibc..." + epatch "${FILESDIR}"/1.0.0/${PN}-1.0.5-uclibc-dns.diff + epatch "${FILESDIR}"/1.2.0/${PN}-1.2.1-uclibc-getloadavg.diff + fi + + # + # Disable AEL, security bug #171884 + # Re-enable at your own risk (no USE since it can be critical) + # + sed -i -e 's/pbx_ael.so//' pbx/Makefile || die + + # codecs/Makefile does not add -lspeexdsp needed for speex 1.2, bug #206463 + if use speex && has_version ">=media-libs/speex-1.2"; then + sed -i -e "s/-lspeex/-lspeex -lspeexdsp/" codecs/Makefile \ + || die "patching codecs/Makefile failed" + fi +} + +src_compile() { + local myopts + + use lowmem && \ + myopts="-DLOW_MEMORY" + + einfo "Building Asterisk..." + if use debug; then + unset CFLAGS + make \ + CC=$(tc-getCC) \ + NOTRACE=1 \ + PWLIBDIR=/usr/share/pwlib \ + OPTIONS="${myopts}" \ + dont-optimize=1 || die "Make failed" + else + make \ + CC=$(tc-getCC) \ + NOTRACE=1 \ + OPTIMIZE="${CFLAGS}" \ + PWLIBDIR=/usr/share/pwlib \ + OPTIONS="${myopts}" || die "Make failed" + fi + + # create api docs + use doc && \ + make progdocs +} + +src_install() { + + # install asterisk + make DESTDIR="${D}" ASTLIBDIR="\$(INSTALL_PREFIX)/usr/$(get_libdir)/asterisk" install || die "Make install failed" + make DESTDIR="${D}" ASTLIBDIR="\$(INSTALL_PREFIX)/usr/$(get_libdir)/asterisk" samples || die "Failed to create sample files" + + # remove installed sample files if nosamples flag is set + if use nosamples; then + einfo "Skipping installation of sample files..." + rm -rf "${D}"var/spool/asterisk/voicemail/default + rm -f "${D}"var/lib/asterisk/mohmp3/* + rm -f "${D}"var/lib/asterisk/sounds/demo-* + rm -f "${D}"var/lib/asterisk/agi-bin/* + else + einfo "Sample files have been installed" + keepdir /var/spool/asterisk/voicemail/default/1234/INBOX + fi + + # move sample configuration files to doc directory + if is_ast10update; then + elog "Updating from old (pre-1.2) asterisk version, new configuration files have been installed" + elog "into "${ROOT}"etc/asterisk, use etc-update or dispatch-conf to update them" + elif has_version "net-misc/asterisk"; then + elog "Configuration samples have been moved to: $ROOT/usr/share/doc/${PF}/conf" + insinto /usr/share/doc/${PF}/conf + doins "${D}"etc/asterisk/*.conf* + rm -f "${D}"etc/asterisk/*.conf* 2>/dev/null + fi + + # don't delete these directories, even if they are empty + for x in voicemail meetme system dictate monitor tmp; do + keepdir /var/spool/asterisk/${x} + done + keepdir /var/lib/asterisk/sounds/priv-callerintros + keepdir /var/lib/asterisk/mohmp3 + keepdir /var/lib/asterisk/agi-bin + keepdir /var/log/asterisk/cdr-csv + keepdir /var/log/asterisk/cdr-custom + keepdir /var/run/asterisk + + # install astxs + dobin contrib/scripts/astxs + + newinitd "${FILESDIR}"/1.2.0/asterisk.rc6 asterisk + newconfd "${FILESDIR}"/1.2.0/asterisk.confd asterisk + + # install standard docs... + dodoc BUGS CREDITS ChangeLog HARDWARE README + dodoc SECURITY doc/CODING-GUIDELINES doc/linkedlists.README UPGRADE.txt + dodoc doc/README.* + dodoc doc/*.txt + + docinto scripts + dodoc contrib/scripts/* + + docinto utils + dodoc contrib/utils/* + + docinto configs + dodoc configs/* + + # install api docs + if use doc; then + insinto /usr/share/doc/${PF}/api/html + doins doc/api/html/* + fi + + insinto /usr/share/doc/${PF}/cgi + doins contrib/scripts/vmail.cgi + doins images/*.gif + + # install asterisk-updater + dosbin "${FILESDIR}"/1.2.0/asterisk-updater + + # install asterisk.h, a lot of external modules need this + insinto /usr/include/asterisk + doins include/asterisk.h + + # make sure misdn/capi stuff is not installed, provided by asterisk-chan_.. + rm -f "${D}"/etc/asterisk/misdn.conf "${D}"/usr/lib/asterisk/modules/chan_misdn.so \ + "${D}"/usr/share/doc/${PF}/{conf/misdn.conf,configs/misdn.conf.sample.gz,README.misdn.gz} + rm -f "${D}"/usr/include/asterisk/chan_capi{,_app}.h \ + "${D}"/usr/share/doc/${PF}/{conf/capi.conf,configs/capi.conf.sample.gz} + + # make sure the broken speex support does not keep Asterisk from starting up + # bug #206463 if you care about this. solution needs to work with --as-needed + rm -f "${D}"usr/$(get_libdir)/asterisk/modules/codec_speex.so || die "Unable to remove fatally flawed codec_speex.so" +} + +pkg_preinst() { + enewgroup asterisk + enewuser asterisk -1 -1 /var/lib/asterisk "asterisk,dialout" +} + +pkg_postinst() { + einfo "Fixing permissions" + chown -R asterisk:asterisk "${ROOT}"var/log/asterisk + chmod -R u=rwX,g=rX,o= "${ROOT}"var/log/asterisk + + for x in lib run spool; do + chown -R asterisk:asterisk "${ROOT}"var/${x}/asterisk + chmod -R u=rwX,g=rwX,o= "${ROOT}"var/${x}/asterisk + done + + chown asterisk:asterisk "${ROOT}"etc/asterisk/ + chown asterisk:asterisk "${ROOT}"etc/asterisk/*.adsi + chown asterisk:asterisk "${ROOT}"etc/asterisk/extensions.ael + chmod u=rwX,g=rwX,o= "${ROOT}"etc/asterisk/ + chmod u=rwX,g=rwX,o= "${ROOT}"etc/asterisk/*.adsi + chmod u=rwX,g=rwX,o= "${ROOT}"etc/asterisk/extensions.ael + echo + + # + # Announcements, warnings, reminders... + # + einfo "Asterisk has been installed" + einfo "" + elog "If you want to know more about asterisk, visit these sites:" + elog "http://www.asteriskdocs.org/" + elog "http://www.voip-info.org/wiki-Asterisk" + elog + elog "http://www.automated.it/guidetoasterisk.htm" + elog + elog "Gentoo VoIP IRC Channel:" + elog "#gentoo-voip @ irc.freenode.net" + elog + elog "Please note that AEL is no longer built because of security bugs" + elog "See http://bugs.gentoo.org/show_bug.cgi?id=171884" + elog + echo + echo + + # + # Warning about 1.0 -> 1.2 changes... + # + if is_ast10update; then + ewarn "" + ewarn "- Please read "${ROOT}"usr/share/doc/${PF}/UPGRADE.txt.gz before continuing" + ewarn "" + fi + + if is_astupdate; then + ewarn "" + ewarn " - The initgroups patch has been dropped, please update your" + ewarn " \"conf.d/asterisk\" and \"init.d/asterisk\" file!" + ewarn "" + fi + + # scan for old modules + if is_ast10update; then + einfo "Asterisk has been updated from pre-1.2.x, scanning for old modules" + scan_modules + fi +} + +pkg_config() { + einfo "Do you want to reset file permissions and ownerships (y/N)?" + + read tmp + tmp="$(echo $tmp | tr [:upper:] [:lower:])" + + if [[ "$tmp" = "y" ]] ||\ + [[ "$tmp" = "yes" ]] + then + einfo "Resetting permissions to defaults..." + + for x in spool run lib log; do + chown -R asterisk:asterisk "${ROOT}"var/${x}/asterisk + chmod -R u=rwX,g=rX,o= "${ROOT}"var/${x}/asterisk + done + + chown -R root:asterisk "${ROOT}"etc/asterisk + chmod -R u=rwX,g=rX,o= "${ROOT}"etc/asterisk + + einfo "done" + else + einfo "skipping" + fi +} diff --git a/net-misc/asterisk/files/1.2.0/asterisk-1.2.31.1-bri-fixups.diff b/net-misc/asterisk/files/1.2.0/asterisk-1.2.31.1-bri-fixups.diff deleted file mode 100644 index 95e288c8f0d4..000000000000 --- a/net-misc/asterisk/files/1.2.0/asterisk-1.2.31.1-bri-fixups.diff +++ /dev/null @@ -1,11 +0,0 @@ -diff -uNr patches.ORIG/asterisk/102-asterisk_version.diff patches/asterisk/102-asterisk_version.diff ---- patches.ORIG/asterisk/102-asterisk_version.diff 2009-03-11 14:56:42.000000000 +0000 -+++ patches/asterisk/102-asterisk_version.diff 2009-03-11 14:57:23.000000000 +0000 -@@ -3,5 +3,5 @@ - --- asterisk-1.2.30.orig/.version - +++ asterisk-1.2.30/.version - @@ -1 +1 @@ ---1.2.30.4 --+1.2.30.4-BRIstuffed-0.3.0-PRE-1y-w -+-1.2.31.1 -++1.2.31.1-BRIstuffed-0.3.0-PRE-1y-w diff --git a/net-misc/asterisk/files/1.2.0/asterisk-1.2.31.1-svn89254.diff b/net-misc/asterisk/files/1.2.0/asterisk-1.2.31.1-svn89254.diff deleted file mode 100644 index 3a77eda9260c..000000000000 --- a/net-misc/asterisk/files/1.2.0/asterisk-1.2.31.1-svn89254.diff +++ /dev/null @@ -1,11 +0,0 @@ ---- branches/1.4/channels/chan_iax2.c 2007/11/04 22:38:13 88471 -+++ branches/1.4/channels/chan_iax2.c 2007/11/13 21:07:08 89254 -@@ -1569,7 +1569,7 @@ - ast_log(LOG_WARNING, "Cannot open '%s': %s\n", s, strerror(errno)); - return -1; - } -- fd = open(s2, O_RDWR | O_CREAT | O_EXCL); -+ fd = open(s2, O_RDWR | O_CREAT | O_EXCL, 0600); - if (fd < 0) { - ast_log(LOG_WARNING, "Cannot open '%s' for writing: %s\n", s2, strerror(errno)); - close(ifd); diff --git a/net-misc/asterisk/files/1.2.0/asterisk-1.2.32-comma-is-not-pipe.diff b/net-misc/asterisk/files/1.2.0/asterisk-1.2.32-comma-is-not-pipe.diff deleted file mode 100644 index 803cd79c5a87..000000000000 --- a/net-misc/asterisk/files/1.2.0/asterisk-1.2.32-comma-is-not-pipe.diff +++ /dev/null @@ -1,12 +0,0 @@ -diff -uNr asterisk-1.2.32.ORIG/apps/app_chanspy.c asterisk-1.2.32/apps/app_chanspy.c ---- asterisk-1.2.32.ORIG/apps/app_chanspy.c 2009-04-03 15:08:26.000000000 +0100 -+++ asterisk-1.2.32/apps/app_chanspy.c 2009-04-03 15:10:40.000000000 +0100 -@@ -438,7 +438,7 @@ - if (recbase) { - char filename[512]; - snprintf(filename,sizeof(filename),"%s/%s.%d.raw",ast_config_AST_MONITOR_DIR, recbase, (int)time(NULL)); -- if ((fd = open(filename, O_CREAT | O_WRONLY, O_TRUNC, 0644)) <= 0) { -+ if ((fd = open(filename, O_CREAT | O_WRONLY | O_TRUNC, 0644)) <= 0) { - ast_log(LOG_WARNING, "Cannot open %s for recording\n", filename); - fd = 0; - } diff --git a/net-misc/asterisk/files/1.2.0/asterisk-1.2.32-svn89254.diff b/net-misc/asterisk/files/1.2.0/asterisk-1.2.32-svn89254.diff deleted file mode 100644 index a061fc9d1300..000000000000 --- a/net-misc/asterisk/files/1.2.0/asterisk-1.2.32-svn89254.diff +++ /dev/null @@ -1,12 +0,0 @@ -diff -uNr asterisk-1.2.32.ORIG/channels/chan_iax2.c asterisk-1.2.32/channels/chan_iax2.c ---- asterisk-1.2.32.ORIG/channels/chan_iax2.c 2009-04-03 14:55:59.000000000 +0100 -+++ asterisk-1.2.32/channels/chan_iax2.c 2009-04-03 14:57:05.000000000 +0100 -@@ -1445,7 +1445,7 @@ - ast_log(LOG_WARNING, "Cannot open '%s': %s\n", s, strerror(errno)); - return -1; - } -- fd = open(s2, O_RDWR | O_CREAT | O_EXCL); -+ fd = open(s2, O_RDWR | O_CREAT | O_EXCL, 0600); - if (fd < 0) { - ast_log(LOG_WARNING, "Cannot open '%s' for writing: %s\n", s2, strerror(errno)); - close(ifd); |