# Copyright 1999-2016 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # $Id$ EAPI=6 PYTHON_COMPAT=( python2_7 python3_4 ) inherit distutils-r1 linux-info user DESCRIPTION="A virtual network service for Openstack" HOMEPAGE="https://launchpad.net/neutron" SRC_URI="https://tarballs.openstack.org/${PN}/${P}.tar.gz https://dev.gentoo.org/~prometheanfire/dist/openstack/neutron/mitaka/configs.tar.gz -> neutron-configs-${PV}.tar.gz https://dev.gentoo.org/~prometheanfire/dist/openstack/neutron/mitaka/ml2_plugins.tar.gz -> neutron-ml2-plugins-${PV}.tar.gz" LICENSE="Apache-2.0" SLOT="0" KEYWORDS="amd64 ~arm64 x86" IUSE="compute-only dhcp ipv6 l3 metadata openvswitch linuxbridge server sqlite mysql postgres" REQUIRED_USE="!compute-only? ( || ( mysql postgres sqlite ) ) compute-only? ( !mysql !postgres !sqlite !dhcp !l3 !metadata !server || ( openvswitch linuxbridge ) )" CDEPEND=">=dev-python/pbr-1.8[${PYTHON_USEDEP}]" DEPEND=" dev-python/setuptools[${PYTHON_USEDEP}] ${CDEPEND} app-admin/sudo" RDEPEND=" ${CDEPEND} dev-python/paste[${PYTHON_USEDEP}] >=dev-python/pastedeploy-1.5.0-r1[${PYTHON_USEDEP}] >=dev-python/routes-1.12.3[${PYTHON_USEDEP}] !~dev-python/routes-2.0[${PYTHON_USEDEP}] !~dev-python/routes-2.1[$(python_gen_usedep 'python2_7')] <=dev-python/routes-2.2[${PYTHON_USEDEP}] >=dev-python/debtcollector-1.2.0[${PYTHON_USEDEP}] >=dev-python/eventlet-0.18.4[${PYTHON_USEDEP}] >=dev-python/pecan-1.0.0[${PYTHON_USEDEP}] >=dev-python/greenlet-0.3.2[${PYTHON_USEDEP}] >=dev-python/httplib2-0.7.5[${PYTHON_USEDEP}] >=dev-python/requests-2.8.1[${PYTHON_USEDEP}] !~dev-python/requests-2.9.0[${PYTHON_USEDEP}] >=dev-python/jinja-2.8[${PYTHON_USEDEP}] >=dev-python/keystonemiddleware-4.0.0[${PYTHON_USEDEP}] !=dev-python/keystonemiddleware-4.1.0[${PYTHON_USEDEP}] >=dev-python/netaddr-0.7.12[${PYTHON_USEDEP}] !~dev-python/netaddr-0.7.16[${PYTHON_USEDEP}] >=dev-python/netifaces-0.10.4[${PYTHON_USEDEP}] >=dev-python/neutron-lib-0.0.1[${PYTHON_USEDEP}] >=dev-python/python-neutronclient-2.6.0[${PYTHON_USEDEP}] !~dev-python/python-neutronclient-4.1.0[${PYTHON_USEDEP}] >=dev-python/retrying-1.2.3[${PYTHON_USEDEP}] !~dev-python/retrying-1.3.0[${PYTHON_USEDEP}] >=dev-python/ryu-3.30[${PYTHON_USEDEP}] compute-only? ( >=dev-python/sqlalchemy-1.0.10[${PYTHON_USEDEP}] <dev-python/sqlalchemy-1.1.0[${PYTHON_USEDEP}] ) sqlite? ( >=dev-python/sqlalchemy-1.0.10[sqlite,${PYTHON_USEDEP}] <dev-python/sqlalchemy-1.1.0[sqlite,${PYTHON_USEDEP}] ) mysql? ( dev-python/mysql-python >=dev-python/sqlalchemy-1.0.10[${PYTHON_USEDEP}] <dev-python/sqlalchemy-1.1.0[${PYTHON_USEDEP}] ) postgres? ( dev-python/psycopg:2 >=dev-python/sqlalchemy-1.0.10[${PYTHON_USEDEP}] <dev-python/sqlalchemy-1.1.0[${PYTHON_USEDEP}] ) >=dev-python/webob-1.2.3[${PYTHON_USEDEP}] >=dev-python/keystoneauth-2.1.0[${PYTHON_USEDEP}] >=dev-python/alembic-0.8.0[${PYTHON_USEDEP}] >=dev-python/six-1.9.0[${PYTHON_USEDEP}] >=dev-python/stevedore-1.5.0[${PYTHON_USEDEP}] >=dev-python/oslo-concurrency-3.5.0[${PYTHON_USEDEP}] >=dev-python/oslo-config-3.7.0[${PYTHON_USEDEP}] >=dev-python/oslo-context-0.2.0[${PYTHON_USEDEP}] >=dev-python/oslo-db-4.1.0[${PYTHON_USEDEP}] >=dev-python/oslo-i18n-2.1.0[${PYTHON_USEDEP}] >=dev-python/oslo-log-1.14.0[${PYTHON_USEDEP}] >=dev-python/oslo-messaging-4.0.0[${PYTHON_USEDEP}] >=dev-python/oslo-middleware-3.0.0[${PYTHON_USEDEP}] >=dev-python/oslo-policy-0.5.0[${PYTHON_USEDEP}] >=dev-python/oslo-reports-0.6.0[${PYTHON_USEDEP}] >=dev-python/oslo-rootwrap-2.0.0[${PYTHON_USEDEP}] >=dev-python/oslo-serialization-1.10.0[${PYTHON_USEDEP}] >=dev-python/oslo-service-1.0.0[${PYTHON_USEDEP}] >=dev-python/oslo-utils-3.5.0[${PYTHON_USEDEP}] >=dev-python/oslo-versionedobjects-1.5.0[${PYTHON_USEDEP}] >=dev-python/ovs-2.4.0[$(python_gen_usedep 'python2_7')] >=dev-python/python-novaclient-2.29.0[${PYTHON_USEDEP}] !~dev-python/python-novaclient-2.33.0[${PYTHON_USEDEP}] >=dev-python/python-designateclient-1.5.0[${PYTHON_USEDEP}] dev-python/pyudev[${PYTHON_USEDEP}] sys-apps/iproute2 net-misc/bridge-utils net-firewall/ipset net-firewall/iptables net-firewall/ebtables net-firewall/conntrack-tools openvswitch? ( <=net-misc/openvswitch-2.5.9999 ) ipv6? ( net-misc/radvd >=net-misc/dibbler-1.0.1 ) dhcp? ( net-dns/dnsmasq[dhcp-tools] )" #PATCHES=( #) pkg_setup() { linux-info_pkg_setup CONFIG_CHECK_MODULES="VLAN_8021Q IP6_NF_FILTER IP6_NF_IPTABLES IP_NF_TARGET_REJECT \ IP_NF_MANGLE IP_NF_TARGET_MASQUERADE NF_NAT_IPV4 NF_CONNTRACK_IPV4 NF_DEFRAG_IPV4 \ NF_NAT_IPV4 NF_NAT NF_CONNTRACK IP_NF_FILTER IP_NF_IPTABLES NETFILTER_XTABLES" if linux_config_exists; then for module in ${CONFIG_CHECK_MODULES}; do linux_chkconfig_present ${module} || ewarn "${module} needs to be enabled in kernel" done fi enewgroup neutron enewuser neutron -1 -1 /var/lib/neutron neutron } pkg_config() { fperms 0700 /var/log/neutron fowners neutron:neutron /var/log neutron } src_prepare() { sed -i '/^hacking/d' test-requirements.txt || die # it's /bin/ip not /sbin/ip sed -i 's/sbin\/ip\,/bin\/ip\,/g' etc/neutron/rootwrap.d/* || die distutils-r1_python_prepare_all } python_install() { distutils-r1_python_install if use server; then newinitd "${FILESDIR}/neutron.initd" "neutron-server" newconfd "${FILESDIR}/neutron-server.confd" "neutron-server" dosym /etc/neutron/plugin.ini /etc/neutron/plugins/ml2/ml2_conf.ini fi if use dhcp; then newinitd "${FILESDIR}/neutron.initd" "neutron-dhcp-agent" newconfd "${FILESDIR}/neutron-dhcp-agent.confd" "neutron-dhcp-agent" fi if use l3; then newinitd "${FILESDIR}/neutron.initd" "neutron-l3-agent" newconfd "${FILESDIR}/neutron-l3-agent.confd" "neutron-l3-agent" fi if use metadata; then newinitd "${FILESDIR}/neutron.initd" "neutron-metadata-agent" newconfd "${FILESDIR}/neutron-metadata-agent.confd" "neutron-metadata-agent" fi if use openvswitch; then newinitd "${FILESDIR}/neutron.initd" "neutron-openvswitch-agent" newconfd "${FILESDIR}/neutron-openvswitch-agent.confd" "neutron-openvswitch-agent" newinitd "${FILESDIR}/neutron.initd" "neutron-ovs-cleanup" newconfd "${FILESDIR}/neutron-openvswitch-agent.confd" "neutron-ovs-cleanup" fi if use linuxbridge; then newinitd "${FILESDIR}/neutron.initd" "neutron-linuxbridge-agent" newconfd "${FILESDIR}/neutron-linuxbridge-agent.confd.liberty" "neutron-linuxbridge-agent" fi diropts -m 755 -o neutron -g neutron dodir /var/log/neutron /var/lib/neutron keepdir /etc/neutron insinto /etc/neutron insopts -m 0640 -o neutron -g neutron doins etc/* # stupid renames insinto /etc/neutron doins -r "etc/neutron/plugins" insopts -m 0640 -o root -g root doins "etc/rootwrap.conf" doins -r "etc/neutron/rootwrap.d" insopts -m 0644 insinto "/usr/lib64/python2.7/site-packages/neutron/db/migration/alembic_migrations/" doins -r "neutron/db/migration/alembic_migrations/versions" #add sudoers definitions for user neutron insinto /etc/sudoers.d/ insopts -m 0440 -o root -g root newins "${FILESDIR}/neutron.sudoersd" neutron # add generated configs cd "${D}/etc/neutron" || die unpack "neutron-configs-${PV}.tar.gz" cd "${D}/etc/neutron/plugins/ml2" || die unpack "neutron-ml2-plugins-${PV}.tar.gz" # correcting perms fowners neutron:neutron -R "/etc/neutron" fperms o-rwx -R "/etc/neutron/" #remove superfluous stuff rm -R "${D}/usr/etc/" } pkg_postinst() { elog elog "neutron-server's conf.d file may need updating to include additional ini files" elog "We currently assume the ml2 plugin will be used but do not make assumptions" elog "on if you will use openvswitch or linuxbridge (or something else)" elog elog "Other conf.d files may need updating too, but should be good for the default use case" elog }