/mandos/trunk

To get this branch, use:
bzr branch http://bzr.recompile.se/loggerhead/mandos/trunk

« back to all changes in this revision

Viewing changes to Makefile

  • Committer: Teddy Hogeborn
  • Date: 2019-08-05 21:14:05 UTC
  • Revision ID: teddy@recompile.se-20190805211405-9m6hecekaihpttz9
Override lintian warnings about upgrading from old versions

There are some really things which are imperative that we fix in case
someone were to upgrade from a really old version.  We want to keep
these fixes in the postinst maintainer scripts, even though lintian
complains about such old upgrades not being supported by Debian in
general.  We prefer the code being there, for the sake of the users.

* debian/mandos-client.lintian-overrides
  (maintainer-script-supports-ancient-package-version): New.
  debian/mandos.lintian-overrides
  (maintainer-script-supports-ancient-package-version): - '' -

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
WARN=-O -Wall -Wformat=2 -Winit-self -Wmissing-include-dirs \
2
 
        -Wswitch-default -Wswitch-enum -Wunused-parameter \
3
 
        -Wstrict-aliasing=1 -Wextra -Wfloat-equal -Wundef -Wshadow \
 
1
WARN:=-O -Wall -Wextra -Wdouble-promotion -Wformat=2 -Winit-self \
 
2
        -Wmissing-include-dirs -Wswitch-default -Wswitch-enum \
 
3
        -Wunused -Wuninitialized -Wstrict-overflow=5 \
 
4
        -Wsuggest-attribute=pure -Wsuggest-attribute=const \
 
5
        -Wsuggest-attribute=noreturn -Wfloat-equal -Wundef -Wshadow \
4
6
        -Wunsafe-loop-optimizations -Wpointer-arith \
5
7
        -Wbad-function-cast -Wcast-qual -Wcast-align -Wwrite-strings \
6
 
        -Wconversion -Wstrict-prototypes -Wold-style-definition \
7
 
        -Wpacked -Wnested-externs -Winline -Wvolatile-register-var
8
 
#       -Wunreachable-code 
9
 
#DEBUG=-ggdb3
10
 
# For info about _FORTIFY_SOURCE, see
11
 
# <http://www.kernel.org/doc/man-pages/online/pages/man7/feature_test_macros.7.html>
12
 
# and <http://gcc.gnu.org/ml/gcc-patches/2004-09/msg02055.html>.
13
 
FORTIFY=-D_FORTIFY_SOURCE=2 -fstack-protector-all -fPIC -fPIE
14
 
LINK_FORTIFY_LD=-z relro -fPIE
15
 
LINK_FORTIFY=-pie
 
8
        -Wconversion -Wlogical-op -Waggregate-return \
 
9
        -Wstrict-prototypes -Wold-style-definition \
 
10
        -Wmissing-format-attribute -Wnormalized=nfc -Wpacked \
 
11
        -Wredundant-decls -Wnested-externs -Winline -Wvla \
 
12
        -Wvolatile-register-var -Woverlength-strings
 
13
 
 
14
#DEBUG:=-ggdb3 -fsanitize=address $(SANITIZE)
 
15
## Check which sanitizing options can be used
 
16
#SANITIZE:=$(foreach option,$(ALL_SANITIZE_OPTIONS),$(shell \
 
17
#       echo 'int main(){}' | $(CC) --language=c $(option) \
 
18
#       /dev/stdin -o /dev/null >/dev/null 2>&1 && echo $(option)))
 
19
# <https://developerblog.redhat.com/2014/10/16/gcc-undefined-behavior-sanitizer-ubsan/>
 
20
ALL_SANITIZE_OPTIONS:=-fsanitize=leak -fsanitize=undefined \
 
21
        -fsanitize=shift -fsanitize=integer-divide-by-zero \
 
22
        -fsanitize=unreachable -fsanitize=vla-bound -fsanitize=null \
 
23
        -fsanitize=return -fsanitize=signed-integer-overflow \
 
24
        -fsanitize=bounds -fsanitize=alignment \
 
25
        -fsanitize=object-size -fsanitize=float-divide-by-zero \
 
26
        -fsanitize=float-cast-overflow -fsanitize=nonnull-attribute \
 
27
        -fsanitize=returns-nonnull-attribute -fsanitize=bool \
 
28
        -fsanitize=enum -fsanitize-address-use-after-scope
 
29
 
 
30
# For info about _FORTIFY_SOURCE, see feature_test_macros(7)
 
31
# and <https://gcc.gnu.org/ml/gcc-patches/2004-09/msg02055.html>.
 
32
FORTIFY:=-D_FORTIFY_SOURCE=2 -fstack-protector-all -fPIC
 
33
LINK_FORTIFY_LD:=-z relro -z now
 
34
LINK_FORTIFY:=
 
35
 
 
36
# If BROKEN_PIE is set, do not build with -pie
 
37
ifndef BROKEN_PIE
 
38
FORTIFY += -fPIE
 
39
LINK_FORTIFY += -pie
 
40
endif
16
41
#COVERAGE=--coverage
17
 
OPTIMIZE=-Os
18
 
LANGUAGE=-std=gnu99
19
 
htmldir=man
20
 
version=1.0.13
21
 
SED=sed
 
42
OPTIMIZE:=-Os -fno-strict-aliasing
 
43
LANGUAGE:=-std=gnu11
 
44
FEATURES:=-D_FILE_OFFSET_BITS=64
 
45
htmldir:=man
 
46
version:=1.8.6
 
47
SED:=sed
 
48
PKG_CONFIG?=pkg-config
 
49
 
 
50
USER:=$(firstword $(subst :, ,$(shell getent passwd _mandos \
 
51
        || getent passwd nobody || echo 65534)))
 
52
GROUP:=$(firstword $(subst :, ,$(shell getent group _mandos \
 
53
        || getent group nogroup || echo 65534)))
 
54
 
 
55
LINUXVERSION:=$(shell uname --kernel-release)
22
56
 
23
57
## Use these settings for a traditional /usr/local install
24
 
# PREFIX=$(DESTDIR)/usr/local
25
 
# CONFDIR=$(DESTDIR)/etc/mandos
26
 
# KEYDIR=$(DESTDIR)/etc/mandos/keys
27
 
# MANDIR=$(PREFIX)/man
28
 
# INITRAMFSTOOLS=$(DESTDIR)/etc/initramfs-tools
 
58
# PREFIX:=$(DESTDIR)/usr/local
 
59
# CONFDIR:=$(DESTDIR)/etc/mandos
 
60
# KEYDIR:=$(DESTDIR)/etc/mandos/keys
 
61
# MANDIR:=$(PREFIX)/man
 
62
# INITRAMFSTOOLS:=$(DESTDIR)/etc/initramfs-tools
 
63
# DRACUTMODULE:=$(DESTDIR)/usr/lib/dracut/modules.d/90mandos
 
64
# STATEDIR:=$(DESTDIR)/var/lib/mandos
 
65
# LIBDIR:=$(PREFIX)/lib
29
66
##
30
67
 
31
68
## These settings are for a package-type install
32
 
PREFIX=$(DESTDIR)/usr
33
 
CONFDIR=$(DESTDIR)/etc/mandos
34
 
KEYDIR=$(DESTDIR)/etc/keys/mandos
35
 
MANDIR=$(PREFIX)/share/man
36
 
INITRAMFSTOOLS=$(DESTDIR)/usr/share/initramfs-tools
 
69
PREFIX:=$(DESTDIR)/usr
 
70
CONFDIR:=$(DESTDIR)/etc/mandos
 
71
KEYDIR:=$(DESTDIR)/etc/keys/mandos
 
72
MANDIR:=$(PREFIX)/share/man
 
73
INITRAMFSTOOLS:=$(DESTDIR)/usr/share/initramfs-tools
 
74
DRACUTMODULE:=$(DESTDIR)/usr/lib/dracut/modules.d/90mandos
 
75
STATEDIR:=$(DESTDIR)/var/lib/mandos
 
76
LIBDIR:=$(shell \
 
77
        for d in \
 
78
        "/usr/lib/`dpkg-architecture \
 
79
                        -qDEB_HOST_MULTIARCH 2>/dev/null`" \
 
80
        "`rpm --eval='%{_libdir}' 2>/dev/null`" /usr/lib; do \
 
81
                if [ -d "$$d" -a "$$d" = "$${d%/}" ]; then \
 
82
                        echo "$(DESTDIR)$$d"; \
 
83
                        break; \
 
84
                fi; \
 
85
        done)
37
86
##
38
87
 
39
 
GNUTLS_CFLAGS=$(shell pkg-config --cflags-only-I gnutls)
40
 
GNUTLS_LIBS=$(shell pkg-config --libs gnutls)
41
 
AVAHI_CFLAGS=$(shell pkg-config --cflags-only-I avahi-core)
42
 
AVAHI_LIBS=$(shell pkg-config --libs avahi-core)
43
 
GPGME_CFLAGS=$(shell gpgme-config --cflags; getconf LFS_CFLAGS)
44
 
GPGME_LIBS=$(shell gpgme-config --libs; getconf LFS_LIBS; \
 
88
SYSTEMD:=$(DESTDIR)$(shell $(PKG_CONFIG) systemd \
 
89
                        --variable=systemdsystemunitdir)
 
90
TMPFILES:=$(DESTDIR)$(shell $(PKG_CONFIG) systemd \
 
91
                        --variable=tmpfilesdir)
 
92
 
 
93
GNUTLS_CFLAGS:=$(shell $(PKG_CONFIG) --cflags-only-I gnutls)
 
94
GNUTLS_LIBS:=$(shell $(PKG_CONFIG) --libs gnutls)
 
95
AVAHI_CFLAGS:=$(shell $(PKG_CONFIG) --cflags-only-I avahi-core)
 
96
AVAHI_LIBS:=$(shell $(PKG_CONFIG) --libs avahi-core)
 
97
GPGME_CFLAGS:=$(shell gpgme-config --cflags; getconf LFS_CFLAGS)
 
98
GPGME_LIBS:=$(shell gpgme-config --libs; getconf LFS_LIBS; \
45
99
        getconf LFS_LDFLAGS)
 
100
LIBNL3_CFLAGS:=$(shell $(PKG_CONFIG) --cflags-only-I libnl-route-3.0)
 
101
LIBNL3_LIBS:=$(shell $(PKG_CONFIG) --libs libnl-route-3.0)
 
102
GLIB_CFLAGS:=$(shell $(PKG_CONFIG) --cflags glib-2.0)
 
103
GLIB_LIBS:=$(shell $(PKG_CONFIG) --libs glib-2.0)
46
104
 
47
105
# Do not change these two
48
 
CFLAGS=$(WARN) $(DEBUG) $(FORTIFY) $(COVERAGE) $(OPTIMIZE) \
49
 
        $(LANGUAGE) $(GNUTLS_CFLAGS) $(AVAHI_CFLAGS) $(GPGME_CFLAGS) \
50
 
        -DVERSION='"$(version)"'
51
 
LDFLAGS=$(COVERAGE) $(LINK_FORTIFY) $(foreach flag,$(LINK_FORTIFY_LD),-Xlinker $(flag))
 
106
CFLAGS+=$(WARN) $(DEBUG) $(FORTIFY) $(COVERAGE) $(OPTIMIZE) \
 
107
        $(LANGUAGE) $(FEATURES) -DVERSION='"$(version)"'
 
108
LDFLAGS+=-Xlinker --as-needed $(COVERAGE) $(LINK_FORTIFY) $(strip \
 
109
        ) $(foreach flag,$(LINK_FORTIFY_LD),-Xlinker $(flag))
52
110
 
53
111
# Commands to format a DocBook <refentry> document into a manual page
54
 
DOCBOOKTOMAN=cd $(dir $<); xsltproc --nonet --xinclude \
 
112
DOCBOOKTOMAN=$(strip cd $(dir $<); xsltproc --nonet --xinclude \
55
113
        --param man.charmap.use.subset          0 \
56
114
        --param make.year.ranges                1 \
57
115
        --param make.single.year.ranges         1 \
58
116
        --param man.output.quietly              1 \
59
117
        --param man.authors.section.enabled     0 \
60
 
         /usr/share/xml/docbook/stylesheet/nwalsh/manpages/docbook.xsl \
 
118
        /usr/share/xml/docbook/stylesheet/nwalsh/manpages/docbook.xsl \
61
119
        $(notdir $<); \
62
 
        $(MANPOST) $(notdir $@)
63
 
# DocBook-to-man post-processing to fix a '\n' escape bug
64
 
MANPOST=$(SED) --in-place --expression='s,\\\\en,\\en,g;s,\\n,\\en,g'
 
120
        if locale --all 2>/dev/null | grep --regexp='^en_US\.utf8$$' \
 
121
        && command -v man >/dev/null; then LANG=en_US.UTF-8 \
 
122
        MANWIDTH=80 man --warnings --encoding=UTF-8 --local-file \
 
123
        $(notdir $@); fi >/dev/null)
65
124
 
66
 
DOCBOOKTOHTML=xsltproc --nonet --xinclude \
 
125
DOCBOOKTOHTML=$(strip xsltproc --nonet --xinclude \
67
126
        --param make.year.ranges                1 \
68
127
        --param make.single.year.ranges         1 \
69
128
        --param man.output.quietly              1 \
71
130
        --param citerefentry.link               1 \
72
131
        --output $@ \
73
132
        /usr/share/xml/docbook/stylesheet/nwalsh/xhtml/docbook.xsl \
74
 
        $<; $(HTMLPOST) $@
 
133
        $<; $(HTMLPOST) $@)
75
134
# Fix citerefentry links
76
 
HTMLPOST=$(SED) --in-place \
 
135
HTMLPOST:=$(SED) --in-place \
77
136
        --expression='s/\(<a class="citerefentry" href="\)\("><span class="citerefentry"><span class="refentrytitle">\)\([^<]*\)\(<\/span>(\)\([^)]*\)\()<\/span><\/a>\)/\1\3.\5\2\3\4\5\6/g'
78
137
 
79
 
PLUGINS=plugins.d/password-prompt plugins.d/mandos-client \
80
 
        plugins.d/usplash plugins.d/splashy plugins.d/askpass-fifo
81
 
CPROGS=plugin-runner $(PLUGINS)
82
 
PROGS=mandos mandos-keygen mandos-ctl $(CPROGS)
83
 
DOCS=mandos.8 plugin-runner.8mandos mandos-keygen.8 \
 
138
PLUGINS:=plugins.d/password-prompt plugins.d/mandos-client \
 
139
        plugins.d/usplash plugins.d/splashy plugins.d/askpass-fifo \
 
140
        plugins.d/plymouth
 
141
PLUGIN_HELPERS:=plugin-helpers/mandos-client-iprouteadddel
 
142
CPROGS:=plugin-runner dracut-module/password-agent $(PLUGINS) \
 
143
        $(PLUGIN_HELPERS)
 
144
PROGS:=mandos mandos-keygen mandos-ctl mandos-monitor $(CPROGS)
 
145
DOCS:=mandos.8 mandos-keygen.8 mandos-monitor.8 mandos-ctl.8 \
 
146
        mandos.conf.5 mandos-clients.conf.5 plugin-runner.8mandos \
 
147
        dracut-module/password-agent.8mandos \
84
148
        plugins.d/mandos-client.8mandos \
85
 
        plugins.d/password-prompt.8mandos mandos.conf.5 \
86
 
        plugins.d/usplash.8mandos plugins.d/splashy.8mandos \
87
 
        plugins.d/askpass-fifo.8mandos mandos-clients.conf.5
88
 
 
89
 
htmldocs=$(addsuffix .xhtml,$(DOCS))
90
 
 
91
 
objects=$(addsuffix .o,$(CPROGS))
 
149
        plugins.d/password-prompt.8mandos plugins.d/usplash.8mandos \
 
150
        plugins.d/splashy.8mandos plugins.d/askpass-fifo.8mandos \
 
151
        plugins.d/plymouth.8mandos intro.8mandos
 
152
 
 
153
htmldocs:=$(addsuffix .xhtml,$(DOCS))
 
154
 
 
155
objects:=$(addsuffix .o,$(CPROGS))
92
156
 
93
157
all: $(PROGS) mandos.lsm
94
158
 
111
175
%.8mandos.xhtml: %.xml common.ent legalnotice.xml
112
176
        $(DOCBOOKTOHTML)
113
177
 
 
178
intro.8mandos: intro.xml common.ent legalnotice.xml
 
179
        $(DOCBOOKTOMAN)
 
180
intro.8mandos.xhtml: intro.xml common.ent legalnotice.xml
 
181
        $(DOCBOOKTOHTML)
 
182
 
114
183
mandos.8: mandos.xml common.ent mandos-options.xml overview.xml \
115
184
                legalnotice.xml
116
185
        $(DOCBOOKTOMAN)
125
194
                 legalnotice.xml
126
195
        $(DOCBOOKTOHTML)
127
196
 
 
197
mandos-monitor.8: mandos-monitor.xml common.ent overview.xml \
 
198
                legalnotice.xml
 
199
        $(DOCBOOKTOMAN)
 
200
mandos-monitor.8.xhtml: mandos-monitor.xml common.ent overview.xml \
 
201
                 legalnotice.xml
 
202
        $(DOCBOOKTOHTML)
 
203
 
 
204
mandos-ctl.8: mandos-ctl.xml common.ent overview.xml \
 
205
                legalnotice.xml
 
206
        $(DOCBOOKTOMAN)
 
207
mandos-ctl.8.xhtml: mandos-ctl.xml common.ent overview.xml \
 
208
                 legalnotice.xml
 
209
        $(DOCBOOKTOHTML)
 
210
 
128
211
mandos.conf.5: mandos.conf.xml common.ent mandos-options.xml \
129
212
                legalnotice.xml
130
213
        $(DOCBOOKTOMAN)
139
222
                overview.xml legalnotice.xml
140
223
        $(DOCBOOKTOHTML)
141
224
 
 
225
dracut-module/password-agent.8mandos: \
 
226
                dracut-module/password-agent.xml common.ent \
 
227
                overview.xml legalnotice.xml
 
228
        $(DOCBOOKTOMAN)
 
229
dracut-module/password-agent.8mandos.xhtml: \
 
230
                dracut-module/password-agent.xml common.ent \
 
231
                overview.xml legalnotice.xml
 
232
        $(DOCBOOKTOHTML)
 
233
 
142
234
plugins.d/mandos-client.8mandos: plugins.d/mandos-client.xml \
143
235
                                        common.ent \
144
236
                                        mandos-options.xml \
152
244
 
153
245
# Update all these files with version number $(version)
154
246
common.ent: Makefile
155
 
        $(SED) --in-place \
 
247
        $(strip $(SED) --in-place \
156
248
                --expression='s/^\(<!ENTITY version "\)[^"]*">$$/\1$(version)">/' \
157
 
                $@
 
249
                $@)
158
250
 
159
251
mandos: Makefile
160
 
        $(SED) --in-place \
 
252
        $(strip $(SED) --in-place \
161
253
                --expression='s/^\(version = "\)[^"]*"$$/\1$(version)"/' \
162
 
                $@
 
254
                $@)
163
255
 
164
256
mandos-keygen: Makefile
165
 
        $(SED) --in-place \
 
257
        $(strip $(SED) --in-place \
166
258
                --expression='s/^\(VERSION="\)[^"]*"$$/\1$(version)"/' \
167
 
                $@
 
259
                $@)
168
260
 
169
261
mandos-ctl: Makefile
170
 
        $(SED) --in-place \
171
 
                --expression='s/^\(version = "\)[^"]*"$$/\1$(version)"/' \
172
 
                $@
 
262
        $(strip $(SED) --in-place \
 
263
                --expression='s/^\(version = "\)[^"]*"$$/\1$(version)"/' \
 
264
                $@)
 
265
 
 
266
mandos-monitor: Makefile
 
267
        $(strip $(SED) --in-place \
 
268
                --expression='s/^\(version = "\)[^"]*"$$/\1$(version)"/' \
 
269
                $@)
173
270
 
174
271
mandos.lsm: Makefile
175
 
        $(SED) --in-place \
 
272
        $(strip $(SED) --in-place \
176
273
                --expression='s/^\(Version:\).*/\1\t$(version)/' \
177
 
                $@
178
 
        $(SED) --in-place \
 
274
                $@)
 
275
        $(strip $(SED) --in-place \
179
276
                --expression='s/^\(Entered-date:\).*/\1\t$(shell date --rfc-3339=date --reference=Makefile)/' \
180
 
                $@
181
 
        $(SED) --in-place \
 
277
                $@)
 
278
        $(strip $(SED) --in-place \
182
279
                --expression='s/\(mandos_\)[0-9.]\+\(\.orig\.tar\.gz\)/\1$(version)\2/' \
183
 
                $@
184
 
 
185
 
plugins.d/mandos-client: plugins.d/mandos-client.o
186
 
        $(LINK.o) $(GNUTLS_LIBS) $(AVAHI_LIBS) $(GPGME_LIBS) \
187
 
                $(COMMON) $^ $(LOADLIBES) $(LDLIBS) -o $@
188
 
 
189
 
.PHONY : all doc html clean distclean run-client run-server install \
190
 
        install-server install-client uninstall uninstall-server \
191
 
        uninstall-client purge purge-server purge-client
 
280
                $@)
 
281
 
 
282
# Need to add the GnuTLS, Avahi and GPGME libraries
 
283
plugins.d/mandos-client: plugins.d/mandos-client.c
 
284
        $(LINK.c) $^ $(GNUTLS_CFLAGS) $(AVAHI_CFLAGS) $(strip\
 
285
                ) $(GPGME_CFLAGS) $(GNUTLS_LIBS) $(strip\
 
286
                ) $(AVAHI_LIBS) $(GPGME_LIBS) $(LOADLIBES) $(strip\
 
287
                ) $(LDLIBS) -o $@
 
288
 
 
289
# Need to add the libnl-route library
 
290
plugin-helpers/mandos-client-iprouteadddel: plugin-helpers/mandos-client-iprouteadddel.c
 
291
        $(LINK.c) $(LIBNL3_CFLAGS) $^ $(LIBNL3_LIBS) $(strip\
 
292
                ) $(LOADLIBES) $(LDLIBS) -o $@
 
293
 
 
294
# Need to add the GLib and pthread libraries
 
295
dracut-module/password-agent: dracut-module/password-agent.c
 
296
        $(LINK.c) $(GLIB_CFLAGS) $^ $(GLIB_LIBS) -lpthread $(strip\
 
297
                ) $(LOADLIBES) $(LDLIBS) -o $@
 
298
 
 
299
.PHONY : all doc html clean distclean mostlyclean maintainer-clean \
 
300
        check run-client run-server install install-html \
 
301
        install-server install-client-nokey install-client uninstall \
 
302
        uninstall-server uninstall-client purge purge-server \
 
303
        purge-client
192
304
 
193
305
clean:
194
306
        -rm --force $(CPROGS) $(objects) $(htmldocs) $(DOCS) core
196
308
distclean: clean
197
309
mostlyclean: clean
198
310
maintainer-clean: clean
199
 
        -rm --force --recursive keydir confdir
 
311
        -rm --force --recursive keydir confdir statedir
200
312
 
201
 
check:  all
 
313
check: all
202
314
        ./mandos --check
 
315
        ./mandos-ctl --check
 
316
        ./mandos-keygen --version
 
317
        ./plugin-runner --version
 
318
        ./plugin-helpers/mandos-client-iprouteadddel --version
 
319
        ./dracut-module/password-agent --test
203
320
 
204
321
# Run the client with a local config and key
205
 
run-client: all keydir/seckey.txt keydir/pubkey.txt
 
322
run-client: all keydir/seckey.txt keydir/pubkey.txt \
 
323
                        keydir/tls-privkey.pem keydir/tls-pubkey.pem
 
324
        @echo '######################################################'
 
325
        @echo '# The following error messages are harmless and can  #'
 
326
        @echo '#  be safely ignored:                                #'
 
327
        @echo '## From plugin-runner:                               #'
 
328
        @echo '# setgid: Operation not permitted                    #'
 
329
        @echo '# setuid: Operation not permitted                    #'
 
330
        @echo '## From askpass-fifo:                                #'
 
331
        @echo '# mkfifo: Permission denied                          #'
 
332
        @echo '## From mandos-client:                               #'
 
333
        @echo '# Failed to raise privileges: Operation not permi... #'
 
334
        @echo '# Warning: network hook "*" exited with status *     #'
 
335
        @echo '# ioctl SIOCSIFFLAGS +IFF_UP: Operation not permi... #'
 
336
        @echo '# Failed to bring up interface "*": Operation not... #'
 
337
        @echo '#                                                    #'
 
338
        @echo '# (The messages are caused by not running as root,   #'
 
339
        @echo '# but you should NOT run "make run-client" as root   #'
 
340
        @echo '# unless you also unpacked and compiled Mandos as    #'
 
341
        @echo '# root, which is also NOT recommended.)              #'
 
342
        @echo '######################################################'
 
343
# We set GNOME_KEYRING_CONTROL to block pam_gnome_keyring
206
344
        ./plugin-runner --plugin-dir=plugins.d \
 
345
                --plugin-helper-dir=plugin-helpers \
207
346
                --config-file=plugin-runner.conf \
208
 
                --options-for=mandos-client:--seckey=keydir/seckey.txt,--pubkey=keydir/pubkey.txt \
 
347
                --options-for=mandos-client:--seckey=keydir/seckey.txt,--pubkey=keydir/pubkey.txt,--tls-privkey=keydir/tls-privkey.pem,--tls-pubkey=keydir/tls-pubkey.pem,--network-hook-dir=network-hooks.d \
 
348
                --env-for=mandos-client:GNOME_KEYRING_CONTROL= \
209
349
                $(CLIENTARGS)
210
350
 
211
351
# Used by run-client
212
 
keydir/seckey.txt keydir/pubkey.txt: mandos-keygen
 
352
keydir/seckey.txt keydir/pubkey.txt keydir/tls-privkey.pem keydir/tls-pubkey.pem: mandos-keygen
213
353
        install --directory keydir
214
354
        ./mandos-keygen --dir keydir --force
215
355
 
216
356
# Run the server with a local config
217
 
run-server: confdir/mandos.conf confdir/clients.conf
218
 
        ./mandos --debug --no-dbus --configdir=confdir $(SERVERARGS)
 
357
run-server: confdir/mandos.conf confdir/clients.conf statedir
 
358
        ./mandos --debug --no-dbus --configdir=confdir \
 
359
                --statedir=statedir $(SERVERARGS)
219
360
 
220
361
# Used by run-server
221
362
confdir/mandos.conf: mandos.conf
222
363
        install --directory confdir
223
364
        install --mode=u=rw,go=r $^ $@
224
 
confdir/clients.conf: clients.conf keydir/seckey.txt
 
365
confdir/clients.conf: clients.conf keydir/seckey.txt keydir/tls-pubkey.pem
225
366
        install --directory confdir
226
367
        install --mode=u=rw $< $@
227
368
# Add a client password
228
 
        ./mandos-keygen --dir keydir --password >> $@
 
369
        ./mandos-keygen --dir keydir --password --no-ssh >> $@
 
370
statedir:
 
371
        install --directory statedir
229
372
 
230
373
install: install-server install-client-nokey
231
374
 
236
379
 
237
380
install-server: doc
238
381
        install --directory $(CONFDIR)
 
382
        if install --directory --mode=u=rwx --owner=$(USER) \
 
383
                --group=$(GROUP) $(STATEDIR); then \
 
384
                :; \
 
385
        elif install --directory --mode=u=rwx $(STATEDIR); then \
 
386
                chown -- $(USER):$(GROUP) $(STATEDIR) || :; \
 
387
        fi
 
388
        if [ "$(TMPFILES)" != "$(DESTDIR)" \
 
389
                        -a -d "$(TMPFILES)" ]; then \
 
390
                install --mode=u=rw,go=r tmpfiles.d-mandos.conf \
 
391
                        $(TMPFILES)/mandos.conf; \
 
392
        fi
239
393
        install --mode=u=rwx,go=rx mandos $(PREFIX)/sbin/mandos
 
394
        install --mode=u=rwx,go=rx --target-directory=$(PREFIX)/sbin \
 
395
                mandos-ctl
 
396
        install --mode=u=rwx,go=rx --target-directory=$(PREFIX)/sbin \
 
397
                mandos-monitor
240
398
        install --mode=u=rw,go=r --target-directory=$(CONFDIR) \
241
399
                mandos.conf
242
400
        install --mode=u=rw --target-directory=$(CONFDIR) \
243
401
                clients.conf
 
402
        install --mode=u=rw,go=r dbus-mandos.conf \
 
403
                $(DESTDIR)/etc/dbus-1/system.d/mandos.conf
244
404
        install --mode=u=rwx,go=rx init.d-mandos \
245
405
                $(DESTDIR)/etc/init.d/mandos
 
406
        if [ "$(SYSTEMD)" != "$(DESTDIR)" -a -d "$(SYSTEMD)" ]; then \
 
407
                install --mode=u=rw,go=r mandos.service $(SYSTEMD); \
 
408
        fi
246
409
        install --mode=u=rw,go=r default-mandos \
247
410
                $(DESTDIR)/etc/default/mandos
248
411
        if [ -z $(DESTDIR) ]; then \
250
413
        fi
251
414
        gzip --best --to-stdout mandos.8 \
252
415
                > $(MANDIR)/man8/mandos.8.gz
 
416
        gzip --best --to-stdout mandos-monitor.8 \
 
417
                > $(MANDIR)/man8/mandos-monitor.8.gz
 
418
        gzip --best --to-stdout mandos-ctl.8 \
 
419
                > $(MANDIR)/man8/mandos-ctl.8.gz
253
420
        gzip --best --to-stdout mandos.conf.5 \
254
421
                > $(MANDIR)/man5/mandos.conf.5.gz
255
422
        gzip --best --to-stdout mandos-clients.conf.5 \
256
423
                > $(MANDIR)/man5/mandos-clients.conf.5.gz
 
424
        gzip --best --to-stdout intro.8mandos \
 
425
                > $(MANDIR)/man8/intro.8mandos.gz
257
426
 
258
427
install-client-nokey: all doc
259
 
        install --directory $(PREFIX)/lib/mandos $(CONFDIR)
 
428
        install --directory $(LIBDIR)/mandos $(CONFDIR)
260
429
        install --directory --mode=u=rwx $(KEYDIR) \
261
 
                $(PREFIX)/lib/mandos/plugins.d
262
 
        if [ "$(CONFDIR)" != "$(PREFIX)/lib/mandos" ]; then \
 
430
                $(LIBDIR)/mandos/plugins.d \
 
431
                $(LIBDIR)/mandos/plugin-helpers
 
432
        if [ "$(CONFDIR)" != "$(LIBDIR)/mandos" ]; then \
263
433
                install --mode=u=rwx \
264
 
                        --directory "$(CONFDIR)/plugins.d"; \
 
434
                        --directory "$(CONFDIR)/plugins.d" \
 
435
                        "$(CONFDIR)/plugin-helpers"; \
265
436
        fi
266
 
        install --mode=u=rwx,go=rx \
267
 
                --target-directory=$(PREFIX)/lib/mandos plugin-runner
 
437
        install --mode=u=rwx,go=rx --directory \
 
438
                "$(CONFDIR)/network-hooks.d"
 
439
        install --mode=u=rwx,go=rx \
 
440
                --target-directory=$(LIBDIR)/mandos plugin-runner
 
441
        install --mode=u=rwx,go=rx \
 
442
                --target-directory=$(LIBDIR)/mandos \
 
443
                mandos-to-cryptroot-unlock
268
444
        install --mode=u=rwx,go=rx --target-directory=$(PREFIX)/sbin \
269
445
                mandos-keygen
270
446
        install --mode=u=rwx,go=rx \
271
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
 
447
                --target-directory=$(LIBDIR)/mandos/plugins.d \
272
448
                plugins.d/password-prompt
273
449
        install --mode=u=rwxs,go=rx \
274
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
 
450
                --target-directory=$(LIBDIR)/mandos/plugins.d \
275
451
                plugins.d/mandos-client
276
452
        install --mode=u=rwxs,go=rx \
277
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
 
453
                --target-directory=$(LIBDIR)/mandos/plugins.d \
278
454
                plugins.d/usplash
279
455
        install --mode=u=rwxs,go=rx \
280
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
 
456
                --target-directory=$(LIBDIR)/mandos/plugins.d \
281
457
                plugins.d/splashy
282
458
        install --mode=u=rwxs,go=rx \
283
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
 
459
                --target-directory=$(LIBDIR)/mandos/plugins.d \
284
460
                plugins.d/askpass-fifo
 
461
        install --mode=u=rwxs,go=rx \
 
462
                --target-directory=$(LIBDIR)/mandos/plugins.d \
 
463
                plugins.d/plymouth
 
464
        install --mode=u=rwx,go=rx \
 
465
                --target-directory=$(LIBDIR)/mandos/plugin-helpers \
 
466
                plugin-helpers/mandos-client-iprouteadddel
285
467
        install initramfs-tools-hook \
286
468
                $(INITRAMFSTOOLS)/hooks/mandos
287
 
        install --mode=u=rw,go=r initramfs-tools-hook-conf \
288
 
                $(INITRAMFSTOOLS)/conf-hooks.d/mandos
 
469
        install --mode=u=rw,go=r initramfs-tools-conf \
 
470
                $(INITRAMFSTOOLS)/conf.d/mandos-conf
 
471
        install --mode=u=rw,go=r initramfs-tools-conf-hook \
 
472
                $(INITRAMFSTOOLS)/conf-hooks.d/zz-mandos
289
473
        install initramfs-tools-script \
290
474
                $(INITRAMFSTOOLS)/scripts/init-premount/mandos
 
475
        install initramfs-tools-script-stop \
 
476
                $(INITRAMFSTOOLS)/scripts/local-premount/mandos
 
477
        install --directory $(DRACUTMODULE)
 
478
        install --mode=u=rw,go=r --target-directory=$(DRACUTMODULE) \
 
479
                dracut-module/ask-password-mandos.path \
 
480
                dracut-module/ask-password-mandos.service
 
481
        install --mode=u=rwxs,go=rx \
 
482
                --target-directory=$(DRACUTMODULE) \
 
483
                dracut-module/module-setup.sh \
 
484
                dracut-module/cmdline-mandos.sh \
 
485
                dracut-module/password-agent
291
486
        install --mode=u=rw,go=r plugin-runner.conf $(CONFDIR)
292
487
        gzip --best --to-stdout mandos-keygen.8 \
293
488
                > $(MANDIR)/man8/mandos-keygen.8.gz
294
489
        gzip --best --to-stdout plugin-runner.8mandos \
295
490
                > $(MANDIR)/man8/plugin-runner.8mandos.gz
 
491
        gzip --best --to-stdout plugins.d/mandos-client.8mandos \
 
492
                > $(MANDIR)/man8/mandos-client.8mandos.gz
296
493
        gzip --best --to-stdout plugins.d/password-prompt.8mandos \
297
494
                > $(MANDIR)/man8/password-prompt.8mandos.gz
298
 
        gzip --best --to-stdout plugins.d/mandos-client.8mandos \
299
 
                > $(MANDIR)/man8/mandos-client.8mandos.gz
300
495
        gzip --best --to-stdout plugins.d/usplash.8mandos \
301
496
                > $(MANDIR)/man8/usplash.8mandos.gz
302
497
        gzip --best --to-stdout plugins.d/splashy.8mandos \
303
498
                > $(MANDIR)/man8/splashy.8mandos.gz
304
499
        gzip --best --to-stdout plugins.d/askpass-fifo.8mandos \
305
500
                > $(MANDIR)/man8/askpass-fifo.8mandos.gz
 
501
        gzip --best --to-stdout plugins.d/plymouth.8mandos \
 
502
                > $(MANDIR)/man8/plymouth.8mandos.gz
 
503
        gzip --best --to-stdout dracut-module/password-agent.8mandos \
 
504
                > $(MANDIR)/man8/password-agent.8mandos.gz
306
505
 
307
506
install-client: install-client-nokey
308
507
# Post-installation stuff
309
508
        -$(PREFIX)/sbin/mandos-keygen --dir "$(KEYDIR)"
310
 
        update-initramfs -k all -u
 
509
        if command -v update-initramfs >/dev/null; then \
 
510
            update-initramfs -k all -u; \
 
511
        elif command -v dracut >/dev/null; then \
 
512
            for initrd in $(DESTDIR)/boot/initr*-$(LINUXVERSION); do \
 
513
                if [ -w "$$initrd" ]; then \
 
514
                    chmod go-r "$$initrd"; \
 
515
                    dracut --force "$$initrd"; \
 
516
                fi; \
 
517
            done; \
 
518
        fi
311
519
        echo "Now run mandos-keygen --password --dir $(KEYDIR)"
312
520
 
313
521
uninstall: uninstall-server uninstall-client
314
522
 
315
523
uninstall-server:
316
524
        -rm --force $(PREFIX)/sbin/mandos \
 
525
                $(PREFIX)/sbin/mandos-ctl \
 
526
                $(PREFIX)/sbin/mandos-monitor \
317
527
                $(MANDIR)/man8/mandos.8.gz \
 
528
                $(MANDIR)/man8/mandos-monitor.8.gz \
 
529
                $(MANDIR)/man8/mandos-ctl.8.gz \
318
530
                $(MANDIR)/man5/mandos.conf.5.gz \
319
531
                $(MANDIR)/man5/mandos-clients.conf.5.gz
320
532
        update-rc.d -f mandos remove
326
538
        ! grep --regexp='^ *[^ #].*keyscript=[^,=]*/mandos/' \
327
539
                $(DESTDIR)/etc/crypttab
328
540
        -rm --force $(PREFIX)/sbin/mandos-keygen \
329
 
                $(PREFIX)/lib/mandos/plugin-runner \
330
 
                $(PREFIX)/lib/mandos/plugins.d/password-prompt \
331
 
                $(PREFIX)/lib/mandos/plugins.d/mandos-client \
332
 
                $(PREFIX)/lib/mandos/plugins.d/usplash \
333
 
                $(PREFIX)/lib/mandos/plugins.d/splashy \
334
 
                $(PREFIX)/lib/mandos/plugins.d/askpass-fifo \
 
541
                $(LIBDIR)/mandos/plugin-runner \
 
542
                $(LIBDIR)/mandos/plugins.d/password-prompt \
 
543
                $(LIBDIR)/mandos/plugins.d/mandos-client \
 
544
                $(LIBDIR)/mandos/plugins.d/usplash \
 
545
                $(LIBDIR)/mandos/plugins.d/splashy \
 
546
                $(LIBDIR)/mandos/plugins.d/askpass-fifo \
 
547
                $(LIBDIR)/mandos/plugins.d/plymouth \
335
548
                $(INITRAMFSTOOLS)/hooks/mandos \
336
549
                $(INITRAMFSTOOLS)/conf-hooks.d/mandos \
337
550
                $(INITRAMFSTOOLS)/scripts/init-premount/mandos \
 
551
                $(INITRAMFSTOOLS)/scripts/local-premount/mandos \
 
552
                $(DRACUTMODULE)/ask-password-mandos.path \
 
553
                $(DRACUTMODULE)/ask-password-mandos.service \
 
554
                $(DRACUTMODULE)/module-setup.sh \
 
555
                $(DRACUTMODULE)/cmdline-mandos.sh \
 
556
                $(DRACUTMODULE)/password-agent \
 
557
                $(MANDIR)/man8/mandos-keygen.8.gz \
338
558
                $(MANDIR)/man8/plugin-runner.8mandos.gz \
339
 
                $(MANDIR)/man8/mandos-keygen.8.gz \
 
559
                $(MANDIR)/man8/mandos-client.8mandos.gz
340
560
                $(MANDIR)/man8/password-prompt.8mandos.gz \
341
561
                $(MANDIR)/man8/usplash.8mandos.gz \
342
562
                $(MANDIR)/man8/splashy.8mandos.gz \
343
563
                $(MANDIR)/man8/askpass-fifo.8mandos.gz \
344
 
                $(MANDIR)/man8/mandos-client.8mandos.gz
345
 
        -rmdir $(PREFIX)/lib/mandos/plugins.d $(CONFDIR)/plugins.d \
346
 
                 $(PREFIX)/lib/mandos $(CONFDIR) $(KEYDIR)
347
 
        update-initramfs -k all -u
 
564
                $(MANDIR)/man8/plymouth.8mandos.gz \
 
565
                $(MANDIR)/man8/password-agent.8mandos.gz \
 
566
        -rmdir $(LIBDIR)/mandos/plugins.d $(CONFDIR)/plugins.d \
 
567
                 $(LIBDIR)/mandos $(CONFDIR) $(KEYDIR) $(DRACUTMODULE)
 
568
        if command -v update-initramfs >/dev/null; then \
 
569
            update-initramfs -k all -u; \
 
570
        elif command -v dracut >/dev/null; then \
 
571
            for initrd in $(DESTDIR)/boot/initr*-$(LINUXVERSION); do \
 
572
                test -w "$$initrd" && dracut --force "$$initrd"; \
 
573
            done; \
 
574
        fi
348
575
 
349
576
purge: purge-server purge-client
350
577
 
351
578
purge-server: uninstall-server
352
579
        -rm --force $(CONFDIR)/mandos.conf $(CONFDIR)/clients.conf \
 
580
                $(DESTDIR)/etc/dbus-1/system.d/mandos.conf
353
581
                $(DESTDIR)/etc/default/mandos \
354
582
                $(DESTDIR)/etc/init.d/mandos \
 
583
                $(SYSTEMD)/mandos.service \
 
584
                $(DESTDIR)/run/mandos.pid \
355
585
                $(DESTDIR)/var/run/mandos.pid
356
586
        -rmdir $(CONFDIR)
357
587
 
358
588
purge-client: uninstall-client
359
 
        -shred --remove $(KEYDIR)/seckey.txt
 
589
        -shred --remove $(KEYDIR)/seckey.txt $(KEYDIR)/tls-privkey.pem
360
590
        -rm --force $(CONFDIR)/plugin-runner.conf \
361
 
                $(KEYDIR)/pubkey.txt $(KEYDIR)/seckey.txt
 
591
                $(KEYDIR)/pubkey.txt $(KEYDIR)/seckey.txt \
 
592
                $(KEYDIR)/tls-pubkey.txt $(KEYDIR)/tls-privkey.txt
362
593
        -rmdir $(KEYDIR) $(CONFDIR)/plugins.d $(CONFDIR)