~ttx/apparmor/fix-357581

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
#!/usr/bin/make -f
# -*- makefile -*-
# Sample debian/rules that uses debhelper.
# This file was originally written by Joey Hess and Craig Small.
# As a special exception, when this file is copied by dh-make into a
# dh-make output file, you may use that output file without restriction.
# This special exception was added by Craig Small in version 0.37 of dh-make.

# Uncomment this to turn on verbose mode.
#export DH_VERBOSE=1

# libapparmor uses autotools
export DEB_HOST_GNU_TYPE  ?= $(shell dpkg-architecture -qDEB_HOST_GNU_TYPE)
export DEB_BUILD_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_BUILD_GNU_TYPE)

# FOR AUTOCONF 2.52 AND NEWER ONLY
CONFFLAGS =
ifeq ($(DEB_BUILD_GNU_TYPE), $(DEB_HOST_GNU_TYPE))
  CONFFLAGS += --build $(DEB_HOST_GNU_TYPE)
else
  CONFFLAGS += --build $(DEB_BUILD_GNU_TYPE) --host $(DEB_HOST_GNU_TYPE)
endif

CFLAGS = -Wall -g
CXXFLAGS = -Wall -g

ifneq (,$(findstring noopt,$(DEB_BUILD_OPTIONS)))
	CFLAGS += -O0
	CXXFLAGS += -O0
else
	CFLAGS += -O2
	CXXFLAGS += -O2
endif


configure: configure-stamp
configure-stamp:
	dh_testdir
	# Add here commands to configure the package.
	# Regenerate all files. This should be done by the maintainer 
	# before building the source package and not at build time.
	cd libraries/libapparmor && \
		sh autogen.sh && \
		sh configure $(CONFFLAGS) --prefix=/usr --with-perl
	touch configure-stamp


build: build-stamp

build-stamp: configure-stamp 
	dh_testdir

	# Add here commands to compile the package.
	cd utils; $(MAKE)
	cd parser; $(MAKE)
	cd profiles; $(MAKE)
	cd libraries/libapparmor; $(MAKE)

	touch $@

clean: clean-patched
clean-patched:
	dh_testdir
	dh_testroot
	rm -f build-stamp configure-stamp

	# Add here commands to clean up after the build process.
	cd utils; [ ! -f Makefile ] || $(MAKE) clean; rm -f common
	cd parser; [ ! -f Makefile ] || $(MAKE) clean; rm -f common \
		libapparmor_re/regexp.o libapparmor_re/regexp.cc \
		techdoc.aux techdoc.log techdoc.pdf techdoc.toc
	cd profiles; [ ! -f Makefile ] || $(MAKE) clean; rm -f common
	cd changehat/mod_apparmor && [ ! -f Makefile ] || $(MAKE) clean; rm -f common
	cd changehat/pam_apparmor && [ ! -f Makefile ] || $(MAKE) clean; rm -f common

	# Try to clean up from an autogen'd build
	cd libraries/libapparmor && [ ! -f Makefile ] || $(MAKE) distclean
	if [ -r debian/libapparmor.cleanup ] ; then \
		xargs -t -r rm -f < debian/libapparmor.cleanup ;\
	fi
	
	dh_clean	

install: build
	dh_testdir
	dh_testroot
	dh_clean -k 
	dh_installdirs

	# Utils
	cd utils; $(MAKE) \
	    DESTDIR=$(CURDIR)/debian/apparmor-utils \
	    PERLDIR=$(CURDIR)/debian/apparmor-utils/usr/share/perl5/Immunix \
	    install

	# Parser
	cd parser; $(MAKE) \
	    DESTDIR=$(CURDIR)/debian/apparmor \
	    install
	mv $(CURDIR)/debian/apparmor/lib/apparmor/rc.* $(CURDIR)/debian/apparmor/etc/apparmor/
	mkdir -p $(CURDIR)/debian/apparmor/etc/apparmor.d/disable
	mkdir -p $(CURDIR)/debian/apparmor/etc/apparmor.d/force-complain
	rm -rf $(CURDIR)/debian/apparmor/lib

	# Changehat via libapparmor
	cd libraries/libapparmor; $(MAKE) \
	    RELEASE=$(shell dpkg-parsechangelog | grep ^Version | cut -d+ -f2 | cut -d. -f1) \
	    DESTDIR=$(CURDIR)/debian/libapparmor1 \
	    install
	# don't include deprecated library and headers
	rm -f $(CURDIR)/debian/libapparmor1/usr/lib/*immunix*
	rm -f $(CURDIR)/debian/libapparmor1/usr/include/sys/immunix.h
	# libapparmor-dev
	mkdir -p $(CURDIR)/debian/libapparmor-dev/usr/lib
	mv $(CURDIR)/debian/libapparmor1/usr/lib/libapparmor.a $(CURDIR)/debian/libapparmor-dev/usr/lib/
	mv $(CURDIR)/debian/libapparmor1/usr/lib/libapparmor.la $(CURDIR)/debian/libapparmor-dev/usr/lib/
	cp -P $(CURDIR)/debian/libapparmor1/usr/lib/libapparmor.so $(CURDIR)/debian/libapparmor-dev/usr/lib/
	mv $(CURDIR)/debian/libapparmor1/usr/include $(CURDIR)/debian/libapparmor-dev/usr
	# libapparmor-perl
	mkdir -p $(CURDIR)/debian/libapparmor-perl/usr/lib
	mv $(CURDIR)/debian/libapparmor1/usr/lib/perl5 $(CURDIR)/debian/libapparmor-perl/usr/lib/

	# Changehat via mod_apparmor
	cd changehat/mod_apparmor; $(MAKE) \
	    DESTDIR=$(CURDIR)/debian/libapache2-mod-apparmor \
	    LIBAPPARMOR_FLAGS="-I$(CURDIR)/debian/libapparmor-dev/usr/include -L$(CURDIR)/debian/libapparmor1/usr/lib -lapparmor" \
	    install
	mkdir -p $(CURDIR)/debian/libapache2-mod-apparmor/etc/apache2/mods-available
	echo "LoadModule apparmor_module /usr/lib/apache2/modules/mod_apparmor.so" > $(CURDIR)/debian/libapache2-mod-apparmor/etc/apache2/mods-available/apparmor.load
	# Fix rpath in mod_apparmor.so
	chrpath -d $(CURDIR)/debian/libapache2-mod-apparmor/usr/lib/apache2/modules/mod_apparmor.so

	# Changehat via libpam-apparmor
	cd changehat/pam_apparmor; $(MAKE) \
	    DESTDIR=$(CURDIR)/debian/libpam-apparmor \
	    CFLAGS="$(CFLAGS) -I$(CURDIR)/debian/libapparmor-dev/usr/include" \
	    LIBS="-L$(CURDIR)/debian/libapparmor1/usr/lib -lapparmor -lpam" \
	    install

	# Fix rpath in pam_apparmor.so
	chrpath -d $(CURDIR)/debian/libpam-apparmor/lib/security/pam_apparmor.so

	# Remove libapparmor.so now that mod_apparmor and libpam-apparmor have 
	# been built.
	rm $(CURDIR)/debian/libapparmor1/usr/lib/libapparmor.so

	# Profiles
	cd profiles; $(MAKE) \
	    DESTDIR=$(CURDIR)/debian/apparmor-profiles \
	    EXTRAS_DEST=$(CURDIR)/debian/apparmor-profiles/usr/share/doc/apparmor-profiles/extras \
	    install

        # Delete aa-eventd and Reports.pm
	rm -f $(CURDIR)/debian/apparmor-utils/usr/sbin/aa-eventd
	rm -f $(CURDIR)/debian/apparmor-utils/usr/share/perl5/Immunix/Reports.pm

	# Delete existing enabled profiles that also appear in extras
	rm -f $(CURDIR)/debian/apparmor-profiles/usr/share/doc/apparmor-profiles/extras/usr.sbin.mysqld

	# Move tunable/ and abstractions/ in apparmor
	# as long as apparmor-profiles is in universe.
	mv $(CURDIR)/debian/apparmor-profiles/etc/apparmor.d/tunables/ $(CURDIR)/debian/apparmor/etc/apparmor.d/
	mv $(CURDIR)/debian/apparmor-profiles/etc/apparmor.d/abstractions/ $(CURDIR)/debian/apparmor/etc/apparmor.d/

	# Apparmor-doc
	install -d $(CURDIR)/debian/apparmor-docs/usr/share/doc/apparmor-docs/
	cp parser/techdoc.pdf $(CURDIR)/debian/apparmor-docs/usr/share/doc/apparmor-docs/

	dh_install

# Build architecture-independent files here.
binary-indep: build install
# We have nothing to do by default.

# Build architecture-dependent files here.
binary-arch: build install
	dh_testdir
	dh_testroot
	dh_installchangelogs 
	dh_installdocs
	dh_installexamples
#	dh_install
#	dh_installmenu
#	dh_installdebconf	
#	dh_installlogrotate
#	dh_installemacsen
#	dh_installpam
#	dh_installmime
#	dh_python
	dh_installinit --update-rcd-params='start 37 S .' --no-restart-on-upgrade --error-handler=true
#	dh_installcron
#	dh_installinfo
	dh_installman
	dh_link
	dh_strip
	dh_compress -Xextras
	dh_fixperms
	dh_perl
	dh_makeshlibs
	dh_installdeb
	dh_shlibdeps
	dh_gencontrol
	dh_md5sums
	dh_builddeb

binary: binary-indep binary-arch
.PHONY: build clean binary-indep binary-arch binary install configure

VERSION=$(shell  dpkg-parsechangelog | grep ^Version | cut -d+ -f1 | cut -d\  -f2)
SVN_RELEASE=$(shell dpkg-parsechangelog | grep ^Version | cut -d+ -f2 | cut -d. -f1 | cut -d- -f1)
ORIG_FILE=$(CURDIR)/../apparmor_$(VERSION)+$(SVN_RELEASE).orig.tar.gz
SVN_CO_DIR=$(CURDIR)/apparmor
get-orig-source:
	test ! -e $(ORIG_FILE)
	test ! -e $(SVN_CO_DIR)
	svn co -r $(SVN_RELEASE) https://forgesvn1.novell.com/svn/apparmor/trunk $(SVN_CO_DIR)
	tar czf $(ORIG_FILE) -C `dirname $(SVN_CO_DIR)` --exclude .svn `basename $(SVN_CO_DIR)`
	rm -rf $(SVN_CO_DIR)