]> git.proxmox.com Git - mirror_lxc.git/blame - lxc.spec.in
caps: fix illegal access to array bound
[mirror_lxc.git] / lxc.spec.in
CommitLineData
5e97c3fc 1#
2# lxc: linux Container library
3#
4# (C) Copyright IBM Corp. 2007, 2008
5#
6# Authors:
9afe19d6 7# Daniel Lezcano <daniel.lezcano at free.fr>
5e97c3fc 8#
9# This library is free software; you can redistribute it and/or
10# modify it under the terms of the GNU Lesser General Public
11# License as published by the Free Software Foundation; either
12# version 2.1 of the License, or (at your option) any later version.
13#
14# This library is distributed in the hope that it will be useful,
15# but WITHOUT ANY WARRANTY; without even the implied warranty of
16# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17# Lesser General Public License for more details.
18#
19# You should have received a copy of the GNU Lesser General Public
20# License along with this library; if not, write to the Free Software
250b1eec 21# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
5e97c3fc 22
420dfb59
DE
23# Set with_systemd on distros that use it, so we can install the service
24# file, otherwise the sysvinit script will be installed
25%if 0%{?fedora} >= 14 || 0%{?rhel} >= 7 || 0%{?suse_version} >= 1210
26%global with_systemd 1
27%define init_script systemd
0af99319
MW
28#
29# BuildRequires systemd-units on fedora and rhel
30%if 0%{?fedora} >= 14 || 0%{?rhel} >= 7
420dfb59 31BuildRequires: systemd-units
723e380b 32%endif
0af99319
MW
33#
34# BuildRequires systemd on openSUSE and SUSE
0af99319
MW
35%if 0%{?suse_version} >= 1210
36BuildRequires: systemd
37%endif
420dfb59
DE
38%else
39%global with_systemd 0
dc068290 40%define init_script sysvinit
420dfb59
DE
41%endif
42
fce070c8
DE
43# Must use /var/run for runtime_path on older releases or dnsmasq in the
44# lxc-net script will not be able to write its pid in /run (selinux denial)
45%if 0%{?fedora} < 15 || 0%{?rhel} < 7
46%define _with_runtime_path --with-runtime-path=/var/run
47%endif
48
9588a6ce
SH
49# RPM needs alpha/beta/rc in Release: not Version: to ensure smooth
50# package upgrades from alpha->beta->rc->release. For more info see:
51# http://fedoraproject.org/wiki/Packaging%3aNamingGuidelines#NonNumericRelease
52%if "x@LXC_VERSION_BETA@" != "x"
53%global beta_rel @LXC_VERSION_BETA@
54%global beta_dot .%{beta_rel}
55%else
56%global norm_rel 1
57%endif
58
5e97c3fc 59Name: @PACKAGE@
9588a6ce
SH
60Version: @LXC_VERSION_BASE@
61Release: %{?beta_rel:0.1.%{beta_rel}}%{?!beta_rel:%{norm_rel}}%{?dist}
07520b2a 62URL: http://linuxcontainers.org
9588a6ce 63Source: http://linuxcontainers.org/downloads/%{name}-%{version}%{?beta_dot}.tar.gz
0adde0f8 64Summary: Linux Containers userspace tools
5e97c3fc 65Group: Applications/System
0adde0f8 66License: LGPLv2+
cef07149 67BuildRoot: %{_tmppath}/%{name}-%{version}-build
fce070c8 68Requires: openssl rsync dnsmasq bridge-utils
1f3fc0d7 69Requires: %{name}-libs = %{version}-%{release}
fce070c8
DE
70Requires(pre): /usr/sbin/useradd
71Requires(postun): /usr/sbin/userdel
72%if 0%{?fedora} < 15 || 0%{?rhel} < 7
73Requires: libcgroup
74%endif
0af99319
MW
75# Note for Suse. The "docbook2X" BuildRequires does properly
76# match docbook2x on Suse in a case insensitive manner
77BuildRequires: libcap libcap-devel docbook2X graphviz libxslt pkgconfig
78
79#
80# Additional packages for openSUSE and SUSE
81#
82%if 0%{?suse_version} >= 1210
83PreReq: permissions
84BuildRequires: libapparmor-devel linux-glibc-devel lsb-release docbook-utils
85
86#
87# libseccomp-devel only needed on i386/i586/i686 and X86_64
88#
89%ifarch %ix86 x86_64
90BuildRequires: libseccomp-devel
91%endif
92%endif
5e97c3fc 93
94%description
0adde0f8 95Containers are insulated areas inside a system, which have their own namespace
f7f1ba77
SG
96for filesystem, network, PID, IPC, CPU and memory allocation and which can be
97created using the Control Group and Namespace features included in the Linux
0adde0f8
DE
98kernel.
99
100This package provides the lxc-* tools, which can be used to start a single
101daemon in a container, or to boot an entire "containerized" system, and to
102manage and debug your containers.
103
104%package libs
105Summary: Shared library files for %{name}
106Group: System Environment/Libraries
107%description libs
1c41ddcb
GK
108The %{name}-libs package contains libraries for running %{name} applications.
109
0adde0f8
DE
110%package devel
111Summary: Development library for %{name}
112Group: Development/Libraries
113Requires: %{name} = %{version}-%{release}, pkgconfig
114%description devel
805415fc 115The %{name}-devel package contains header files and library needed for
0adde0f8
DE
116development of the Linux containers.
117
5e97c3fc 118%prep
9588a6ce 119%setup -q -n %{name}-%{version}%{?beta_dot}
5e97c3fc 120%build
ce951132 121PATH=$PATH:/usr/sbin:/sbin %configure $args \
0af99319
MW
122%if "x%{_unitdir}" != "x"
123 --with-systemdsystemunitdir=%{_unitdir} \
ce951132 124%endif
fce070c8 125 %{?_with_runtime_path} \
420dfb59
DE
126 --disable-rpath \
127 --with-init-script=%{init_script}
cef07149 128make %{?_smp_mflags}
5e97c3fc 129
130%install
b9cb4325
DE
131rm -rf %{buildroot}
132make install DESTDIR=%{buildroot}
133find %{buildroot} -type f -name '*.la' -exec rm -f {} ';'
805415fc 134
5e97c3fc 135%clean
136rm -rf %{buildroot}
137
0af99319 138%pre
fce070c8 139# Ensure that lxc-dnsmasq uid & gid gets correctly allocated
0af99319
MW
140if getent passwd lxc-dnsmasq >/dev/null 2>&1 ; then : ; else \
141 /usr/sbin/useradd -M -r -s /sbin/nologin \
142 -c "LXC Networking Service" -d %_localstatedir/%name lxc-dnsmasq 2> /dev/null \
143 || exit 1
144fi
145
cef07149 146%post
0af99319 147# This test should trigger a network configure on a new install.
cd27b6c8 148if [ ! -f @LXC_DISTRO_SYSCONF@/lxc-net ] || ! grep -q 'USE_LXC_BRIDGE=' @LXC_DISTRO_SYSCONF@/lxc-net
0af99319
MW
149then
150 # Grab a random 10net subnet. Need to add test logic...
151 while [ true ]
152 do
153 SUBNET=10.$(($RANDOM % 256)).$(($RANDOM % 256))
154 if ! ip -4 route ls | grep -q "^$SUBNET"
155 then
156 break
157 fi
158 done
159
cd27b6c8 160 cat > @LXC_DISTRO_SYSCONF@/lxc-net <<EOF
0af99319
MW
161# Leave USE_LXC_BRIDGE as "true" if you want to use lxcbr0 for your
162# containers. Set to "false" if you'll use virbr0 or another existing
e8202121 163# bridge, or macvlan to your host's NIC.
0af99319
MW
164USE_LXC_BRIDGE="true"
165
166# If you change the LXC_BRIDGE to something other than lxcbr0, then
167# you will also need to update your /etc/lxc/default.conf as well as the
168# configuration (/var/lib/lxc/<container>/config) for any containers
169# already created using the default config to reflect the new bridge
170# name.
171# If you have the dnsmasq daemon installed, you'll also have to update
172# /etc/dnsmasq.d/lxc and restart the system wide dnsmasq daemon.
173LXC_BRIDGE="lxcbr0"
84432621 174LXC_BRIDGE_MAC="00:16:3e:00:00:00"
0af99319
MW
175LXC_ADDR="$SUBNET.1"
176LXC_NETMASK="255.255.255.0"
177LXC_NETWORK="$SUBNET.0/24"
178LXC_DHCP_RANGE="$SUBNET.2,$SUBNET.254"
179LXC_DHCP_MAX="253"
180# Uncomment the next line if you'd like to use a conf-file for the lxcbr0
181# dnsmasq. For instance, you can use 'dhcp-host=mail1,10.0.3.100' to have
182# container 'mail1' always get ip address 10.0.3.100.
183#LXC_DHCP_CONFILE=/etc/lxc/dnsmasq.conf
184
185# Uncomment the next line if you want lxcbr0's dnsmasq to resolve the .lxc
186# domain. You can then add "server=/lxc/10.0.3.1' (or your actual $LXC_ADDR)
187# to /etc/dnsmasq.conf, after which 'container1.lxc' will resolve on your
188# host.
189#LXC_DOMAIN="lxc"
190EOF
191fi
192
fce070c8
DE
193%postun
194/usr/sbin/userdel lxc-dnsmasq > /dev/null 2>&1 || :
195
0adde0f8
DE
196%post libs -p /sbin/ldconfig
197%postun libs -p /sbin/ldconfig
805415fc 198
5e97c3fc 199%files
200%defattr(-,root,root)
5e97c3fc 201%{_bindir}/*
0af99319
MW
202# openSUSE/SUSE
203%if 0%{?suse_version} >= 1210
204%dir %{_sysconfdir}/apparmor.d
205%dir %{_sysconfdir}/apparmor.d/abstractions
206%dir %{_sysconfdir}/apparmor.d/abstractions/%{name}
207%config %{_sysconfdir}/apparmor.d/abstractions/%{name}/container-base
208%config %{_sysconfdir}/apparmor.d/abstractions/%{name}/start-container
209%config %{_sysconfdir}/apparmor.d/%{name}-containers
210%dir %{_sysconfdir}/apparmor.d/%{name}
211%config %{_sysconfdir}/apparmor.d/%{name}/%{name}-default
212%config %{_sysconfdir}/apparmor.d/%{name}/%{name}-default-with-mounting
213%config %{_sysconfdir}/apparmor.d/%{name}/%{name}-default-with-nesting
214%config %{_sysconfdir}/apparmor.d/usr.bin.%{name}-start
215%endif
0adde0f8
DE
216%{_mandir}/man1/lxc*
217%{_mandir}/man5/lxc*
218%{_mandir}/man7/lxc*
0af99319
MW
219# not openSUSE/SUSE
220%if %{undefined suse_version}
0adde0f8
DE
221%{_mandir}/ja/man1/lxc*
222%{_mandir}/ja/man5/lxc*
223%{_mandir}/ja/man7/lxc*
2b371b26
SY
224%{_mandir}/ko/man1/lxc*
225%{_mandir}/ko/man5/lxc*
226%{_mandir}/ko/man7/lxc*
0af99319 227%endif
411c76ce 228%{_datadir}/doc/*
b9cb4325 229%{_datadir}/lxc/*
e0f2f5c7 230%{_sysconfdir}/bash_completion.d
0adde0f8 231%config(noreplace) %{_sysconfdir}/lxc/*
0af99319 232%config(noreplace) %{_sysconfdir}/sysconfig/*
5e97c3fc 233
420dfb59 234%if %{with_systemd}
0af99319 235%{_unitdir}/lxc-net.service
420dfb59 236%{_unitdir}/lxc.service
bc395756 237%{_unitdir}/lxc@.service
420dfb59
DE
238%else
239%{_sysconfdir}/rc.d/init.d/lxc
0af99319 240%{_sysconfdir}/rc.d/init.d/lxc-net
420dfb59 241%endif
87ff951e 242
1c41ddcb
GK
243%files libs
244%defattr(-,root,root)
ba5783a5 245%{_sbindir}/*
1c41ddcb
GK
246%{_libdir}/*.so.*
247%{_libdir}/%{name}
7323456e 248%{_localstatedir}/*
bc395756
EG
249%{_libexecdir}/%{name}/hooks/unmount-namespace
250%{_libexecdir}/%{name}/lxc-apparmor-load
251%{_libexecdir}/%{name}/lxc-monitord
45e854dc 252%attr(4111,root,root) %{_libexecdir}/%{name}/lxc-user-nic
420dfb59 253%if %{with_systemd}
0af99319
MW
254%attr(555,root,root) %{_libexecdir}/%{name}/lxc-net
255%attr(555,root,root) %{_libexecdir}/%{name}/lxc-containers
420dfb59 256%endif
1c41ddcb 257
5e97c3fc 258%files devel
259%defattr(-,root,root)
260%{_includedir}/%{name}/*
1c41ddcb 261%{_libdir}/*.so
b9cb4325 262%{_libdir}/pkgconfig/*
5e97c3fc 263
264%changelog
0adde0f8
DE
265* Tue Oct 22 2013 Dwight Engen <dwight.engen@oracle.com> - 1.0.0-0.1.alpha2
266- fix some rpmlint warnings/errors
ec64264d 267- split lua bits into separate package
0adde0f8
DE
268
269* Mon Sep 10 2012 Dwight Engen <dwight.engen@oracle.com> - 0.8.0
b9cb4325
DE
270- fix lxc-init moved to libexec
271- .pc moved to _libdir
272- package template files /usr/share/lxc/templates
273
0adde0f8 274* Thu Sep 8 2011 Greg Kurz <gkurz@fr.ibm.com> - 0.7.5.1
1c41ddcb
GK
275- fix installed files for rpmbuild
276- introduce lxc-libs package
b4915399 277
0adde0f8 278* Fri Jul 23 2010 Daniel Lezcano <dlezcano@fr.ibm.com> - 0.7.2
7ef6e440
DL
279- set attribute for installed files
280- fix libraries installation
7ef6e440 281
7920b1b4 282* Tue Mar 24 2009 Daniel Lezcano <daniel.lezcano@free.fr> - 0.6.1
237315ff
DL
283- Removed capability setting, let the user to do that through "lxc-setcap"
284
0adde0f8 285* Mon Feb 16 2009 Daniel Lezcano <daniel.lezcano@free.fr> - 0.6.0
44931bc7 286- Added more capabilities to the executables
287
0adde0f8 288* Sun Jan 25 2009 Daniel Lezcano <daniel.lezcano@free.fr> - 0.6.0
cef07149 289- Reduced spec file
290
0adde0f8 291* Sun Aug 3 2008 Daniel Lezcano <dlezcano@fr.ibm.com> - 0.1.0
5e97c3fc 292- Initial RPM release.
293
294# Local variables:
295# mode: shell-script
296# sh-shell: rpm
297# end: