%define gitPatch() \ cd %1; \ git init && git config user.name "openstack-plugin" && git config user.email "openstack-plugin"; \ git add . && git commit -m "openstack-plugin init"; \ git apply --check %2 || exit 1 && git apply %2; \ git add . && git commit -m "openstack-plugin patch" %define gitUnPatch() \ cd %1;\ git reset --hard HEAD~;\ rm -rf %1/.git %{!?upstream_version: %global upstream_version %{version}%{?milestone}} %global service neutron %define cleanup_orphan_rootwrap_daemons() \ for pid in $(ps -f --ppid 1 | awk '/.*neutron-rootwrap-daemon/ { print $2 }'); do \ kill $(ps --ppid $pid -o pid=) \ done \ %nil %global common_desc \ Neutron is a virtual network service for Openstack. Just like \ OpenStack Nova provides an API to dynamically request and configure \ virtual servers, Neutron provides an API to dynamically request and \ configure virtual networks. These networks connect "interfaces" from \ other OpenStack services (e.g., virtual NICs from Nova VMs). The \ Neutron API supports extensions to provide advanced network \ capabilities (e.g., QoS, ACLs, network monitoring, etc.) Name: openstack-%{service} Version: 15.3.4 Release: 3 Summary: OpenStack Networking Service License: ASL 2.0 URL: http://launchpad.net/%{service}/ Source0: https://tarballs.openstack.org/%{service}/%{service}-%{upstream_version}.tar.gz Source1: %{service}.logrotate Source2: %{service}-sudoers Source10: neutron-server.service Source11: neutron-linuxbridge-agent.service Source12: neutron-openvswitch-agent.service Source15: neutron-dhcp-agent.service Source16: neutron-l3-agent.service Source17: neutron-metadata-agent.service Source18: neutron-ovs-cleanup.service Source19: neutron-macvtap-agent.service Source20: neutron-metering-agent.service Source21: neutron-sriov-nic-agent.service Source22: neutron-netns-cleanup.service Source29: neutron-rpc-server.service Source30: %{service}-dist.conf Source31: conf.README Source32: neutron-linuxbridge-cleanup.service Source33: neutron-enable-bridge-firewall.sh Source34: neutron-l2-agent-sysctl.conf # We use the legacy service to load modules because it allows to gracefully # ignore a missing kernel module (f.e. br_netfilter on earlier kernels). It's # essentially because .modules files are shell scripts. Source35: neutron-l2-agent.modules Source36: neutron-destroy-patch-ports.service Source37: 0001-add-distributed-traffic-feature-support.patch # Required for tarball sources verification BuildArch: noarch BuildRequires: git-core BuildRequires: openstack-macros BuildRequires: python3-devel BuildRequires: python3-babel BuildRequires: python3-keystoneauth1 BuildRequires: python3-keystonemiddleware BuildRequires: python3-neutron-lib BuildRequires: python3-novaclient BuildRequires: python3-oslo-cache BuildRequires: python3-oslo-concurrency BuildRequires: python3-oslo-config BuildRequires: python3-oslo-db BuildRequires: python3-oslo-log BuildRequires: python3-oslo-messaging BuildRequires: python3-oslo-policy BuildRequires: python3-oslo-privsep BuildRequires: python3-oslo-rootwrap BuildRequires: python3-oslo-service BuildRequires: python3-oslo-upgradecheck BuildRequires: python3-oslo-versionedobjects BuildRequires: python3-osprofiler BuildRequires: python3-ovsdbapp BuildRequires: python3-pbr BuildRequires: python3-psutil BuildRequires: python3-pyroute2 BuildRequires: python3-pecan BuildRequires: python3-tenacity BuildRequires: python3-os-vif BuildRequires: systemd Requires: openstack-%{service}-common = %{version}-%{release} # dnsmasq is not a hard requirement, but is currently the only option # when neutron-dhcp-agent is deployed. Requires: dnsmasq Requires: dnsmasq-utils # radvd is not a hard requirement, but is currently the only option # for IPv6 deployments. Requires: radvd # dibbler is not a hard requirement, but is currently the default option # for IPv6 prefix delegation. Requires: dibbler-client # conntrack is not a hard requirement, but is currently used by L3 agent # to immediately drop connections after a floating IP is disassociated Requires: conntrack-tools # keepalived is not a hard requirement, but is currently used by DVR L3 # agent Requires: keepalived # haproxy implements metadata proxy process Requires: haproxy # Those are not hard requirements, ipset is used by ipset-cleanup in the subpackage, # iptables is used by the l3-agent which currently is not in a separate package, # iputils provides tools like arping which are used by l3-agent and iproute-tc # (or iproute in case of CentOS 7 and RHEL 7), provides tc binary which is # used by e.g. l3-agent and openvswitch-agent when QoS extension is enabled # in agent's config. Requires: ipset Requires: iptables Requires: iputils Requires: iproute-tc %{?systemd_ordering} %description %{common_desc} %package -n python3-%{service} Summary: Neutron Python libraries %{?python_provide:%python_provide python3-%{service}} Requires: python3-alembic Requires: python3-debtcollector Requires: python3-designateclient Requires: python3-eventlet Requires: python3-greenlet Requires: python3-futurist Requires: python3-jinja2 Requires: python3-keystoneauth1 Requires: python3-keystonemiddleware Requires: python3-netaddr Requires: python3-neutronclient Requires: python3-neutron-lib Requires: python3-novaclient Requires: python3-os-vif Requires: python3-oslo-cache Requires: python3-oslo-concurrency Requires: python3-oslo-config Requires: python3-oslo-context Requires: python3-oslo-db Requires: python3-oslo-i18n Requires: python3-oslo-log Requires: python3-oslo-messaging Requires: python3-oslo-middleware Requires: python3-oslo-policy Requires: python3-oslo-privsep Requires: python3-oslo-reports Requires: python3-oslo-rootwrap Requires: python3-oslo-serialization Requires: python3-oslo-service Requires: python3-oslo-upgradecheck Requires: python3-oslo-utils Requires: python3-oslo-versionedobjects Requires: python3-osprofiler Requires: python3-ovsdbapp Requires: python3-pecan Requires: python3-pbr Requires: python3-psutil Requires: python3-pyroute2 Requires: python3-requests Requires: python3-tenacity Requires: python3-routes Requires: python3-os-ken Requires: python3-sqlalchemy Requires: python3-stevedore Requires: python3-tooz Requires: python3-webob Requires: python3-openstacksdk Requires: python3-pyOpenSSL Requires: python3-packaging Requires: python3-httplib2 Requires: python3-netifaces Requires: python3-paste Requires: python3-paste-deploy Requires: python3-decorator Requires: python3-os-xenapi %description -n python3-%{service} %{common_desc} This package contains the Neutron Python library. %package -n python3-%{service}-tests Summary: Neutron tests %{?python_provide:%python_provide python3-%{service}-tests} Requires: python3-%{service} = %{version}-%{release} Requires: python3-ddt Requires: python3-fixtures Requires: python3-mock Requires: python3-subunit Requires: python3-testrepository Requires: python3-testtools Requires: python3-testresources Requires: python3-testscenarios Requires: python3-oslotest Requires: python3-os-testr Requires: python3-PyMySQL Requires: python3-tempest Requires: python3-webtest # pstree is used during functional testing to ensure our internal # libraries managing processes work correctly. Requires: psmisc # nfs-utils is needed because it creates user with uid 65534 which # is required by neutron functional tests. Requires: nfs-utils %description -n python3-%{service}-tests %{common_desc} This package contains Neutron test files. %package common Summary: Neutron common files Requires(pre): shadow-utils Requires: python3-%{service} = %{version}-%{release} Requires: sudo %description common %{common_desc} This package contains Neutron common files. %package linuxbridge Summary: Neutron Linuxbridge agent Requires: ebtables Requires: ipset Requires: iproute Requires: iptables Requires: conntrack-tools # kmod is needed to get access to /usr/sbin/modprobe needed by # neutron-enable-bridge-firewall.sh triggered by the service unit file Requires: kmod Requires: openstack-%{service}-common = %{version}-%{release} %description linuxbridge %{common_desc} This package contains the Neutron agent that implements virtual networks using VLAN or VXLAN using Linuxbridge technology. %package macvtap-agent Summary: Neutron macvtap agent Requires: openstack-%{service}-common = %{version}-%{release} %description macvtap-agent %{common_desc} This package contains the Neutron agent that implements macvtap attachments for libvirt qemu/kvm instances. %package ml2 Summary: Neutron ML2 plugin Requires: openstack-%{service}-common = %{version}-%{release} # needed for brocade and cisco drivers #(TODO) ncclient is not in reuirement projects so it should be requirement in neutron # plugin packages, not in main neutron. Remove this lines completely if everythin keeps # working. #Requires: python3-ncclient %description ml2 %{common_desc} This package contains a Neutron plugin that allows the use of drivers to support separately extensible sets of network types and the mechanisms for accessing those types. %package openvswitch Summary: Neutron openvswitch plugin Requires: openstack-%{service}-common = %{version}-%{release} # We require openvswitch when using vsctl to access ovsdb; # but if we use native access, then we just need python bindings. # since we don't know what users actually use, we depend on both. Requires: ipset Requires: iptables Requires: openvswitch Requires: python3-openvswitch # kmod is needed to get access to /usr/sbin/modprobe needed by # neutron-enable-bridge-firewall.sh triggered by the service unit file Requires: kmod %description openvswitch %{common_desc} This package contains the Neutron plugin that implements virtual networks using Open vSwitch. %package metering-agent Summary: Neutron bandwidth metering agent Requires: iptables Requires: openstack-%{service}-common = %{version}-%{release} %description metering-agent %{common_desc} This package contains the Neutron agent responsible for generating bandwidth utilization notifications. %package rpc-server Summary: Neutron (RPC only) Server Requires: openstack-%{service}-common = %{version}-%{release} %description rpc-server %{common_desc} This package contains an alternative Neutron server that handles AMQP RPC workload only. %package sriov-nic-agent Summary: Neutron SR-IOV NIC agent Requires: openstack-%{service}-common = %{version}-%{release} %description sriov-nic-agent %{common_desc} This package contains the Neutron agent to support advanced features of SR-IOV network cards. %package distributed-traffic Summary: The plug-in package of openstack-neutron for router gateway portforwarding feature Requires: git Requires: python3-crudini Requires: openstack-neutron %description distributed-traffic The plug-in package of openstack-neutron for router gateway portforwarding feature %prep %autosetup -n %{service}-%{upstream_version} -S git sed -i 's/\/usr\/bin\/python/\/usr\/bin\/python3/' %{SOURCE36} find %{service} -name \*.py -exec sed -i '/\/usr\/bin\/env python/{d;q}' {} + # Let's handle dependencies ourseleves %py_req_cleanup # Kill egg-info in order to generate new SOURCES.txt rm -rf neutron.egg-info %build export SKIP_PIP_INSTALL=1 %{py3_build} # Generate i18n files # (amoralej) we can remove '-D neutron' once https://review.openstack.org/#/c/485070/ is merged %{__python3} setup.py compile_catalog -d build/lib/%{service}/locale -D neutron # Generate configuration files PYTHONPATH=. for file in `ls etc/oslo-config-generator/*`; do oslo-config-generator --config-file=$file done find etc -name *.sample | while read filename do filedir=$(dirname $filename) file=$(basename $filename .sample) mv ${filename} ${filedir}/${file} done # Loop through values in neutron-dist.conf and make sure that the values # are substituted into the neutron.conf as comments. Some of these values # will have been uncommented as a way of upstream setting defaults outside # of the code. For notification_driver, there are commented examples # above uncommented settings, so this specifically skips those comments # and instead comments out the actual settings and substitutes the # correct default values. while read name eq value; do test "$name" && test "$value" || continue if [ "$name" = "notification_driver" ]; then sed -ri "0,/^$name *=/{s!^$name *=.*!# $name = $value!}" etc/%{service}.conf else sed -ri "0,/^(#)? *$name *=/{s!^(#)? *$name *=.*!# $name = $value!}" etc/%{service}.conf fi done < %{SOURCE30} %install %{py3_install} # Remove unused files rm -rf %{buildroot}%{python3_sitelib}/bin rm -rf %{buildroot}%{python3_sitelib}/doc rm -rf %{buildroot}%{python3_sitelib}/tools # Move rootwrap files to proper location install -d -m 755 %{buildroot}%{_datarootdir}/%{service}/rootwrap mv %{buildroot}/usr/etc/%{service}/rootwrap.d/*.filters %{buildroot}%{_datarootdir}/%{service}/rootwrap # Move config files to proper location install -d -m 755 %{buildroot}%{_sysconfdir}/%{service} mv %{buildroot}/usr/etc/%{service}/* %{buildroot}%{_sysconfdir}/%{service} mv %{buildroot}%{_sysconfdir}/%{service}/api-paste.ini %{buildroot}%{_datadir}/%{service}/api-paste.ini # The generated config files are not moved automatically by setup.py install -d -m 755 %{buildroot}%{_sysconfdir}/%{service}/plugins/ml2 mv etc/%{service}.conf %{buildroot}%{_sysconfdir}/%{service}/%{service}.conf for agent in dhcp l3 metadata metering do mv etc/${agent}_agent.ini %{buildroot}%{_sysconfdir}/%{service}/${agent}_agent.ini done for file in linuxbridge_agent ml2_conf openvswitch_agent sriov_agent do mv etc/%{service}/plugins/ml2/${file}.ini %{buildroot}%{_sysconfdir}/%{service}/plugins/ml2/${file}.ini done # Install logrotate install -p -D -m 644 %{SOURCE1} %{buildroot}%{_sysconfdir}/logrotate.d/openstack-%{service} # Install sudoers install -p -D -m 440 %{SOURCE2} %{buildroot}%{_sysconfdir}/sudoers.d/%{service} # Install systemd units install -p -D -m 644 %{SOURCE10} %{buildroot}%{_unitdir}/neutron-server.service install -p -D -m 644 %{SOURCE11} %{buildroot}%{_unitdir}/neutron-linuxbridge-agent.service install -p -D -m 644 %{SOURCE12} %{buildroot}%{_unitdir}/neutron-openvswitch-agent.service install -p -D -m 644 %{SOURCE15} %{buildroot}%{_unitdir}/neutron-dhcp-agent.service install -p -D -m 644 %{SOURCE16} %{buildroot}%{_unitdir}/neutron-l3-agent.service install -p -D -m 644 %{SOURCE17} %{buildroot}%{_unitdir}/neutron-metadata-agent.service install -p -D -m 644 %{SOURCE18} %{buildroot}%{_unitdir}/neutron-ovs-cleanup.service install -p -D -m 644 %{SOURCE19} %{buildroot}%{_unitdir}/neutron-macvtap-agent.service install -p -D -m 644 %{SOURCE20} %{buildroot}%{_unitdir}/neutron-metering-agent.service install -p -D -m 644 %{SOURCE21} %{buildroot}%{_unitdir}/neutron-sriov-nic-agent.service install -p -D -m 644 %{SOURCE22} %{buildroot}%{_unitdir}/neutron-netns-cleanup.service install -p -D -m 644 %{SOURCE29} %{buildroot}%{_unitdir}/neutron-rpc-server.service install -p -D -m 644 %{SOURCE32} %{buildroot}%{_unitdir}/neutron-linuxbridge-cleanup.service install -p -D -m 644 %{SOURCE36} %{buildroot}%{_unitdir}/neutron-destroy-patch-ports.service # Install helper scripts install -p -D -m 755 %{SOURCE33} %{buildroot}%{_bindir}/neutron-enable-bridge-firewall.sh # Install sysctl and modprobe config files to enable bridge firewalling # NOTE(ihrachys) we effectively duplicate same settings for each affected l2 # agent. This can be revisited later. install -p -D -m 644 %{SOURCE34} %{buildroot}%{_sysctldir}/99-neutron-openvswitch-agent.conf install -p -D -m 644 %{SOURCE34} %{buildroot}%{_sysctldir}/99-neutron-linuxbridge-agent.conf install -p -D -m 755 %{SOURCE35} %{buildroot}%{_sysconfdir}/sysconfig/modules/neutron-openvswitch-agent.modules install -p -D -m 755 %{SOURCE35} %{buildroot}%{_sysconfdir}/sysconfig/modules/neutron-linuxbridge-agent.modules # Install README file that describes how to configure services with custom configuration files install -p -D -m 755 %{SOURCE31} %{buildroot}%{_sysconfdir}/%{service}/conf.d/README # Setup directories install -d -m 755 %{buildroot}%{_datadir}/%{service} install -d -m 755 %{buildroot}%{_sharedstatedir}/%{service} install -d -m 755 %{buildroot}%{_localstatedir}/log/%{service} install -d -m 755 %{buildroot}%{_localstatedir}/run/%{service} install -d -m 755 %{buildroot}%{_sysconfdir}/%{service}/kill_scripts # Install dist conf install -p -D -m 640 %{SOURCE30} %{buildroot}%{_datadir}/%{service}/%{service}-dist.conf # Create and populate configuration directory for L3 agent that is not accessible for user modification mkdir -p %{buildroot}%{_datadir}/%{service}/l3_agent ln -s %{_sysconfdir}/%{service}/l3_agent.ini %{buildroot}%{_datadir}/%{service}/l3_agent/l3_agent.conf # Create dist configuration directory for neutron-server (may be filled by advanced services) mkdir -p %{buildroot}%{_datadir}/%{service}/server # Create configuration directories for all services that can be populated by users with custom *.conf files mkdir -p %{buildroot}/%{_sysconfdir}/%{service}/conf.d/common for service in server rpc-server ovs-cleanup netns-cleanup linuxbridge-cleanup macvtap-agent; do mkdir -p %{buildroot}/%{_sysconfdir}/%{service}/conf.d/%{service}-$service done for service in linuxbridge openvswitch dhcp l3 metadata metering sriov-nic; do mkdir -p %{buildroot}/%{_sysconfdir}/%{service}/conf.d/%{service}-$service-agent done # Install i18n .mo files (.po and .pot are not required) install -d -m 755 %{buildroot}%{_datadir} rm -f %{buildroot}%{python3_sitelib}/%{service}/locale/*/LC_*/%{service}*po rm -f %{buildroot}%{python3_sitelib}/%{service}/locale/*pot mv %{buildroot}%{python3_sitelib}/%{service}/locale %{buildroot}%{_datadir}/locale # Install router gateway portforwarding feature patch install -D -p -m 644 %{SOURCE37} %{buildroot}%{python3_sitelib}/openstack-plugin/neutron/$(basename %{SOURCE37}) # Find language files %find_lang %{service} --all-name %pre common getent group %{service} >/dev/null || groupadd -r %{service} getent passwd %{service} >/dev/null || \ useradd -r -g %{service} -d %{_sharedstatedir}/%{service} -s /sbin/nologin \ -c "OpenStack Neutron Daemons" %{service} exit 0 %post %systemd_post neutron-dhcp-agent.service %systemd_post neutron-l3-agent.service %systemd_post neutron-metadata-agent.service %systemd_post neutron-server.service %systemd_post neutron-netns-cleanup.service %systemd_post neutron-ovs-cleanup.service %systemd_post neutron-linuxbridge-cleanup.service %preun %systemd_preun neutron-dhcp-agent.service %systemd_preun neutron-l3-agent.service %systemd_preun neutron-metadata-agent.service %systemd_preun neutron-server.service %systemd_preun neutron-netns-cleanup.service %systemd_preun neutron-ovs-cleanup.service %systemd_preun neutron-linuxbridge-cleanup.service %postun %systemd_postun_with_restart neutron-dhcp-agent.service %systemd_postun_with_restart neutron-l3-agent.service %systemd_postun_with_restart neutron-metadata-agent.service %systemd_postun_with_restart neutron-server.service %cleanup_orphan_rootwrap_daemons %post macvtap-agent %systemd_post neutron-macvtap-agent.service %preun macvtap-agent %systemd_preun neutron-macvtap-agent.service %postun macvtap-agent %systemd_postun_with_restart neutron-macvtap-agent.service %cleanup_orphan_rootwrap_daemons %post linuxbridge %systemd_post neutron-linuxbridge-agent.service %preun linuxbridge %systemd_preun neutron-linuxbridge-agent.service %postun linuxbridge %systemd_postun_with_restart neutron-linuxbridge-agent.service %cleanup_orphan_rootwrap_daemons %post openvswitch %systemd_post neutron-openvswitch-agent.service %systemd_post neutron-destroy-patch-ports.service if [ $1 -ge 2 ]; then # We're upgrading # Detect if the neutron-openvswitch-agent is running ovs_agent_running=0 systemctl status neutron-openvswitch-agent > /dev/null 2>&1 && ovs_agent_running=1 || : # If agent is running, stop it [ $ovs_agent_running -eq 1 ] && systemctl stop neutron-openvswitch-agent > /dev/null 2>&1 || : # Search all orphaned neutron-rootwrap-daemon processes and since all are triggered by sudo, # get the actual rootwrap-daemon process. %cleanup_orphan_rootwrap_daemons # If agent was running, start it back with new code [ $ovs_agent_running -eq 1 ] && systemctl start neutron-openvswitch-agent > /dev/null 2>&1 || : fi %preun openvswitch %systemd_preun neutron-openvswitch-agent.service %systemd_preun neutron-destroy-patch-ports.service %post metering-agent %systemd_post neutron-metering-agent.service %preun metering-agent %systemd_preun neutron-metering-agent.service %postun metering-agent %systemd_postun_with_restart neutron-metering-agent.service %cleanup_orphan_rootwrap_daemons %post sriov-nic-agent %systemd_post neutron-sriov-nic-agent.service %preun sriov-nic-agent %systemd_preun neutron-sriov-nic-agent.service %postun sriov-nic-agent %systemd_postun_with_restart neutron-sriov-nic-agent.service %cleanup_orphan_rootwrap_daemons %post distributed-traffic export patch_name=$(basename %{SOURCE37}) %gitPatch %{python3_sitelib}/neutron %{python3_sitelib}/openstack-plugin/neutron/$patch_name crudini --set %{python3_sitelib}/neutron-*.egg-info/entry_points.txt neutron.objects RGPortForwarding neutron.objects.rg_port_forwarding:RGPortForwarding crudini --set %{python3_sitelib}/neutron-*.egg-info/entry_points.txt neutron.service_plugins rg_port_forwarding neutron.services.rg_portforwarding.pf_plugin:RGPortForwardingPlugin crudini --set %{python3_sitelib}/neutron-*.egg-info/entry_points.txt neutron.agent.l3.extensions rg_port_forwarding neutron.agent.l3.extensions.rg_port_forwarding:RGPortForwardingAgentExtension %preun distributed-traffic %gitUnPatch %{python3_sitelib}/neutron crudini --del %{python3_sitelib}/neutron-*.egg-info/entry_points.txt neutron.objects RGPortForwarding crudini --del %{python3_sitelib}/neutron-*.egg-info/entry_points.txt neutron.service_plugins rg_port_forwarding crudini --del %{python3_sitelib}/neutron-*.egg-info/entry_points.txt neutron.agent.l3.extensions rg_port_forwarding %files %license LICENSE %{_bindir}/neutron-api %{_bindir}/neutron-db-manage %{_bindir}/neutron-debug %{_bindir}/neutron-dhcp-agent %{_bindir}/neutron-ipset-cleanup %{_bindir}/neutron-keepalived-state-change %{_bindir}/neutron-l3-agent %{_bindir}/neutron-linuxbridge-cleanup %{_bindir}/neutron-metadata-agent %{_bindir}/neutron-netns-cleanup %{_bindir}/neutron-ovs-cleanup %{_bindir}/neutron-pd-notify %{_bindir}/neutron-sanity-check %{_bindir}/neutron-status %{_bindir}/neutron-server %{_bindir}/neutron-usage-audit %{_bindir}/neutron-rootwrap-xen-dom0 %{_unitdir}/neutron-dhcp-agent.service %{_unitdir}/neutron-l3-agent.service %{_unitdir}/neutron-metadata-agent.service %{_unitdir}/neutron-server.service %{_unitdir}/neutron-netns-cleanup.service %{_unitdir}/neutron-ovs-cleanup.service %{_unitdir}/neutron-linuxbridge-cleanup.service %attr(-, root, %{service}) %{_datadir}/%{service}/api-paste.ini %dir %{_datadir}/%{service}/l3_agent %dir %{_datadir}/%{service}/server %{_datadir}/%{service}/l3_agent/*.conf %config(noreplace) %attr(0640, root, %{service}) %{_sysconfdir}/%{service}/dhcp_agent.ini %config(noreplace) %attr(0640, root, %{service}) %{_sysconfdir}/%{service}/l3_agent.ini %config(noreplace) %attr(0640, root, %{service}) %{_sysconfdir}/%{service}/metadata_agent.ini %dir %{_sysconfdir}/%{service}/conf.d/%{service}-dhcp-agent %dir %{_sysconfdir}/%{service}/conf.d/%{service}-l3-agent %dir %{_sysconfdir}/%{service}/conf.d/%{service}-metadata-agent %dir %{_sysconfdir}/%{service}/conf.d/%{service}-server %dir %{_sysconfdir}/%{service}/conf.d/%{service}-netns-cleanup %dir %{_sysconfdir}/%{service}/conf.d/%{service}-ovs-cleanup %dir %{_sysconfdir}/%{service}/conf.d/%{service}-linuxbridge-cleanup %dir %{_sysconfdir}/%{service}/kill_scripts %files -n python3-%{service}-tests %license LICENSE %{python3_sitelib}/%{service}/tests %files -n python3-%{service} %license LICENSE %{python3_sitelib}/%{service} %{python3_sitelib}/%{service}-*.egg-info %exclude %{python3_sitelib}/%{service}/tests %files common -f %{service}.lang %license LICENSE %doc README.rst # though this script is not exactly needed on all nodes but for ovs and # linuxbridge agents only, it's probably good enough to put it here %{_bindir}/neutron-enable-bridge-firewall.sh %{_bindir}/neutron-rootwrap %{_bindir}/neutron-rootwrap-daemon %dir %{_sysconfdir}/%{service} %{_sysconfdir}/%{service}/conf.d/README %dir %{_sysconfdir}/%{service}/conf.d %dir %{_sysconfdir}/%{service}/conf.d/common %dir %{_sysconfdir}/%{service}/plugins %attr(-, root, %{service}) %{_datadir}/%{service}/%{service}-dist.conf %config(noreplace) %attr(0640, root, %{service}) %{_sysconfdir}/%{service}/%{service}.conf %config(noreplace) %{_sysconfdir}/%{service}/rootwrap.conf %config(noreplace) %{_sysconfdir}/logrotate.d/* %{_sysconfdir}/sudoers.d/%{service} %dir %attr(0755, %{service}, %{service}) %{_sharedstatedir}/%{service} %dir %attr(0750, %{service}, %{service}) %{_localstatedir}/log/%{service} %dir %{_datarootdir}/%{service} %dir %{_datarootdir}/%{service}/rootwrap %{_datarootdir}/%{service}/rootwrap/debug.filters %{_datarootdir}/%{service}/rootwrap/dhcp.filters %{_datarootdir}/%{service}/rootwrap/dibbler.filters %{_datarootdir}/%{service}/rootwrap/ipset-firewall.filters %{_datarootdir}/%{service}/rootwrap/l3.filters %{_datarootdir}/%{service}/rootwrap/privsep.filters %{_datarootdir}/%{service}/rootwrap/ebtables.filters %{_datarootdir}/%{service}/rootwrap/iptables-firewall.filters %files linuxbridge %license LICENSE %{_bindir}/neutron-linuxbridge-agent %{_unitdir}/neutron-linuxbridge-agent.service %{_datarootdir}/%{service}/rootwrap/linuxbridge-plugin.filters %dir %{_sysconfdir}/%{service}/plugins/ml2 %config(noreplace) %attr(0640, root, %{service}) %{_sysconfdir}/%{service}/plugins/ml2/linuxbridge_agent.ini %dir %{_sysconfdir}/%{service}/conf.d/%{service}-linuxbridge-agent %{_sysctldir}/99-neutron-linuxbridge-agent.conf %{_sysconfdir}/sysconfig/modules/neutron-linuxbridge-agent.modules %files macvtap-agent %license LICENSE %{_bindir}/neutron-macvtap-agent %{_unitdir}/neutron-macvtap-agent.service %dir %{_sysconfdir}/%{service}/conf.d/%{service}-macvtap-agent %files ml2 %license LICENSE %doc %{service}/plugins/ml2/README %dir %{_sysconfdir}/%{service}/plugins/ml2 %config(noreplace) %attr(0640, root, %{service}) %{_sysconfdir}/%{service}/plugins/ml2/*.ini %exclude %{_sysconfdir}/%{service}/plugins/ml2/linuxbridge_agent.ini %exclude %{_sysconfdir}/%{service}/plugins/ml2/openvswitch_agent.ini %files openvswitch %license LICENSE %{_bindir}/neutron-openvswitch-agent %{_unitdir}/neutron-openvswitch-agent.service %{_unitdir}/neutron-destroy-patch-ports.service %{_datarootdir}/%{service}/rootwrap/openvswitch-plugin.filters %dir %{_sysconfdir}/%{service}/plugins/ml2 %config(noreplace) %attr(0640, root, %{service}) %{_sysconfdir}/%{service}/plugins/ml2/openvswitch_agent.ini %dir %{_sysconfdir}/%{service}/conf.d/%{service}-openvswitch-agent %{_sysctldir}/99-neutron-openvswitch-agent.conf %{_sysconfdir}/sysconfig/modules/neutron-openvswitch-agent.modules %files metering-agent %license LICENSE %config(noreplace) %attr(0640, root, %{service}) %{_sysconfdir}/%{service}/metering_agent.ini %{_unitdir}/neutron-metering-agent.service %{_bindir}/neutron-metering-agent %dir %{_sysconfdir}/%{service}/conf.d/%{service}-metering-agent %files rpc-server %license LICENSE %{_bindir}/neutron-rpc-server %{_unitdir}/neutron-rpc-server.service %dir %{_sysconfdir}/%{service}/conf.d/%{service}-rpc-server %files sriov-nic-agent %license LICENSE %{_unitdir}/neutron-sriov-nic-agent.service %{_bindir}/neutron-sriov-nic-agent %config(noreplace) %attr(0640, root, %{service}) %{_sysconfdir}/%{service}/plugins/ml2/sriov_agent.ini %dir %{_sysconfdir}/%{service}/conf.d/%{service}-sriov-nic-agent %files distributed-traffic %{python3_sitelib}/openstack-plugin/neutron/%{basename %{SOURCE37}} %changelog * Tue Oct 17 2023 wangkuntian - 15.3.4-3 - Add distributed traffic feature package * Tue Nov 23 2021 zhangy1317 - 15.3.4-2 - Fix install issue * Fri Nov 05 2021 wangxiyuan 15.3.4-1 - Support OpenStack Train release