/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: 2008-07-20 06:33:48 UTC
  • Revision ID: teddy@fukt.bsnet.se-20080720063348-jscgy5p0itrgvlo8
* mandos-clients.conf ([foo]): Uncommented.
  ([foo]/secret): New.
  ([foo]/secfile): Commented out.
  ([foo]/checker): Changed to "fping -q -- %%(fqdn)s".
  ([foo]/timeout): New.

* server.py: New modeline for Python and Emacs.  Set a logging format.
  (Client.__init__): Bug fix: Choose either the value from the options
                     object or pass the argument through string_to_delta
                     for both "timeout" and "interval".
  (Client.checker_callback): Bug fix: Do not log spurious "Checker for
                             <foo> failed" messages.
  (Client.start_checker): Moved "Starting checker" log message down to
                          just before actually starting the subprocess.
                          Do not redirect the subprocesses' stdout to a
                          pipe.
  (peer_certificate, fingerprint): Added docstrings.
  (entry_group_state_changed): Call "killme()" instead of
                               "main_loop.quit()".
  (daemon, killme): New functions.
  (exitstatus, main_loop_started): New global variables.
  (__main__): Removed the "--cert", "--key", "--ca", and "--crl"
              options.  Removed the sleep command from the default
              checker.  Add a console logger in debug mode.  Call
              "killme()" instead of "main_loop.quit()" when there are no
              more clients.  Call "daemon()" if not in debug mode.
              Register "cleanup()" to run at exit.  Ignore some
              signals.  Catch DBusException to detect another running
              server and exit cleanly.  Exit with "exitstatus".
  (cleanup): New function.

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 \
4
 
        -Wunsafe-loop-optimizations -Wpointer-arith \
5
 
        -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
14
 
LINK_FORTIFY_LD=-z relro -z now
15
 
LINK_FORTIFY=
16
 
 
17
 
# If BROKEN_PIE is set, do not build with -pie
18
 
ifndef BROKEN_PIE
19
 
FORTIFY += -fPIE
20
 
LINK_FORTIFY += -pie
21
 
endif
22
 
#COVERAGE=--coverage
23
 
OPTIMIZE=-Os
24
 
LANGUAGE=-std=gnu99
25
 
htmldir=man
26
 
version=1.4.1
27
 
SED=sed
28
 
 
29
 
USER=$(firstword $(subst :, ,$(shell getent passwd _mandos || getent passwd nobody || echo 65534)))
30
 
GROUP=$(firstword $(subst :, ,$(shell getent group _mandos || getent group nobody || echo 65534)))
31
 
 
32
 
## Use these settings for a traditional /usr/local install
33
 
# PREFIX=$(DESTDIR)/usr/local
34
 
# CONFDIR=$(DESTDIR)/etc/mandos
35
 
# KEYDIR=$(DESTDIR)/etc/mandos/keys
36
 
# MANDIR=$(PREFIX)/man
37
 
# INITRAMFSTOOLS=$(DESTDIR)/etc/initramfs-tools
38
 
# STATEDIR=$(DESTDIR)/var/lib/mandos
39
 
##
40
 
 
41
 
## These settings are for a package-type install
42
 
PREFIX=$(DESTDIR)/usr
43
 
CONFDIR=$(DESTDIR)/etc/mandos
44
 
KEYDIR=$(DESTDIR)/etc/keys/mandos
45
 
MANDIR=$(PREFIX)/share/man
46
 
INITRAMFSTOOLS=$(DESTDIR)/usr/share/initramfs-tools
47
 
STATEDIR=$(DESTDIR)/var/lib/mandos
48
 
##
49
 
 
50
 
GNUTLS_CFLAGS=$(shell pkg-config --cflags-only-I gnutls)
51
 
GNUTLS_LIBS=$(shell pkg-config --libs gnutls)
52
 
AVAHI_CFLAGS=$(shell pkg-config --cflags-only-I avahi-core)
53
 
AVAHI_LIBS=$(shell pkg-config --libs avahi-core)
54
 
GPGME_CFLAGS=$(shell gpgme-config --cflags; getconf LFS_CFLAGS)
55
 
GPGME_LIBS=$(shell gpgme-config --libs; getconf LFS_LIBS; \
56
 
        getconf LFS_LDFLAGS)
57
 
 
58
 
# Do not change these two
59
 
CFLAGS=$(WARN) $(DEBUG) $(FORTIFY) $(COVERAGE) $(OPTIMIZE) \
60
 
        $(LANGUAGE) $(GNUTLS_CFLAGS) $(AVAHI_CFLAGS) $(GPGME_CFLAGS) \
61
 
        -DVERSION='"$(version)"'
62
 
LDFLAGS=-Xlinker --as-needed $(COVERAGE) $(LINK_FORTIFY) $(foreach flag,$(LINK_FORTIFY_LD),-Xlinker $(flag))
63
 
 
64
 
# Commands to format a DocBook <refentry> document into a manual page
65
 
DOCBOOKTOMAN=$(strip cd $(dir $<); xsltproc --nonet --xinclude \
66
 
        --param man.charmap.use.subset          0 \
67
 
        --param make.year.ranges                1 \
68
 
        --param make.single.year.ranges         1 \
69
 
        --param man.output.quietly              1 \
70
 
        --param man.authors.section.enabled     0 \
71
 
         /usr/share/xml/docbook/stylesheet/nwalsh/manpages/docbook.xsl \
72
 
        $(notdir $<); \
73
 
        $(MANPOST) $(notdir $@);\
74
 
        LANG=en_US.UTF-8 MANWIDTH=80 man --warnings --encoding=UTF-8 \
75
 
        --local-file $(notdir $@) >/dev/null)
76
 
# DocBook-to-man post-processing to fix a '\n' escape bug
77
 
MANPOST=$(SED) --in-place --expression='s,\\\\en,\\en,g;s,\\n,\\en,g'
78
 
 
79
 
DOCBOOKTOHTML=$(strip xsltproc --nonet --xinclude \
80
 
        --param make.year.ranges                1 \
81
 
        --param make.single.year.ranges         1 \
82
 
        --param man.output.quietly              1 \
83
 
        --param man.authors.section.enabled     0 \
84
 
        --param citerefentry.link               1 \
85
 
        --output $@ \
86
 
        /usr/share/xml/docbook/stylesheet/nwalsh/xhtml/docbook.xsl \
87
 
        $<; $(HTMLPOST) $@)
88
 
# Fix citerefentry links
89
 
HTMLPOST=$(SED) --in-place \
90
 
        --expression='s/\(<a class="citerefentry" href="\)\("><span class="citerefentry"><span class="refentrytitle">\)\([^<]*\)\(<\/span>(\)\([^)]*\)\()<\/span><\/a>\)/\1\3.\5\2\3\4\5\6/g'
91
 
 
92
 
PLUGINS=plugins.d/password-prompt plugins.d/mandos-client \
93
 
        plugins.d/usplash plugins.d/splashy plugins.d/askpass-fifo \
94
 
        plugins.d/plymouth
95
 
CPROGS=plugin-runner $(PLUGINS)
96
 
PROGS=mandos mandos-keygen mandos-ctl mandos-monitor $(CPROGS)
97
 
DOCS=mandos.8 mandos-keygen.8 mandos-monitor.8 mandos-ctl.8 \
98
 
        mandos.conf.5 mandos-clients.conf.5 plugin-runner.8mandos \
99
 
        plugins.d/mandos-client.8mandos \
100
 
        plugins.d/password-prompt.8mandos plugins.d/usplash.8mandos \
101
 
        plugins.d/splashy.8mandos plugins.d/askpass-fifo.8mandos \
102
 
        plugins.d/plymouth.8mandos intro.8mandos
103
 
 
104
 
htmldocs=$(addsuffix .xhtml,$(DOCS))
105
 
 
106
 
objects=$(addsuffix .o,$(CPROGS))
107
 
 
108
 
all: $(PROGS) mandos.lsm
109
 
 
110
 
doc: $(DOCS)
111
 
 
112
 
html: $(htmldocs)
113
 
 
114
 
%.5: %.xml common.ent legalnotice.xml
115
 
        $(DOCBOOKTOMAN)
116
 
%.5.xhtml: %.xml common.ent legalnotice.xml
117
 
        $(DOCBOOKTOHTML)
118
 
 
119
 
%.8: %.xml common.ent legalnotice.xml
120
 
        $(DOCBOOKTOMAN)
121
 
%.8.xhtml: %.xml common.ent legalnotice.xml
122
 
        $(DOCBOOKTOHTML)
123
 
 
124
 
%.8mandos: %.xml common.ent legalnotice.xml
125
 
        $(DOCBOOKTOMAN)
126
 
%.8mandos.xhtml: %.xml common.ent legalnotice.xml
127
 
        $(DOCBOOKTOHTML)
128
 
 
129
 
intro.8mandos: intro.xml common.ent legalnotice.xml
130
 
        $(DOCBOOKTOMAN)
131
 
intro.8mandos.xhtml: intro.xml common.ent legalnotice.xml
132
 
        $(DOCBOOKTOHTML)
133
 
 
134
 
mandos.8: mandos.xml common.ent mandos-options.xml overview.xml \
135
 
                legalnotice.xml
136
 
        $(DOCBOOKTOMAN)
137
 
mandos.8.xhtml: mandos.xml common.ent mandos-options.xml \
138
 
                overview.xml legalnotice.xml
139
 
        $(DOCBOOKTOHTML)
140
 
 
141
 
mandos-keygen.8: mandos-keygen.xml common.ent overview.xml \
142
 
                legalnotice.xml
143
 
        $(DOCBOOKTOMAN)
144
 
mandos-keygen.8.xhtml: mandos-keygen.xml common.ent overview.xml \
145
 
                 legalnotice.xml
146
 
        $(DOCBOOKTOHTML)
147
 
 
148
 
mandos-monitor.8: mandos-monitor.xml common.ent overview.xml \
149
 
                legalnotice.xml
150
 
        $(DOCBOOKTOMAN)
151
 
mandos-monitor.8.xhtml: mandos-monitor.xml common.ent overview.xml \
152
 
                 legalnotice.xml
153
 
        $(DOCBOOKTOHTML)
154
 
 
155
 
mandos-ctl.8: mandos-ctl.xml common.ent overview.xml \
156
 
                legalnotice.xml
157
 
        $(DOCBOOKTOMAN)
158
 
mandos-ctl.8.xhtml: mandos-ctl.xml common.ent overview.xml \
159
 
                 legalnotice.xml
160
 
        $(DOCBOOKTOHTML)
161
 
 
162
 
mandos.conf.5: mandos.conf.xml common.ent mandos-options.xml \
163
 
                legalnotice.xml
164
 
        $(DOCBOOKTOMAN)
165
 
mandos.conf.5.xhtml: mandos.conf.xml common.ent mandos-options.xml \
166
 
                legalnotice.xml
167
 
        $(DOCBOOKTOHTML)
168
 
 
169
 
plugin-runner.8mandos: plugin-runner.xml common.ent overview.xml \
170
 
                legalnotice.xml
171
 
        $(DOCBOOKTOMAN)
172
 
plugin-runner.8mandos.xhtml: plugin-runner.xml common.ent \
173
 
                overview.xml legalnotice.xml
174
 
        $(DOCBOOKTOHTML)
175
 
 
176
 
plugins.d/mandos-client.8mandos: plugins.d/mandos-client.xml \
177
 
                                        common.ent \
178
 
                                        mandos-options.xml \
179
 
                                        overview.xml legalnotice.xml
180
 
        $(DOCBOOKTOMAN)
181
 
plugins.d/mandos-client.8mandos.xhtml: plugins.d/mandos-client.xml \
182
 
                                        common.ent \
183
 
                                        mandos-options.xml \
184
 
                                        overview.xml legalnotice.xml
185
 
        $(DOCBOOKTOHTML)
186
 
 
187
 
# Update all these files with version number $(version)
188
 
common.ent: Makefile
189
 
        $(strip $(SED) --in-place \
190
 
                --expression='s/^\(<!ENTITY version "\)[^"]*">$$/\1$(version)">/' \
191
 
                $@)
192
 
 
193
 
mandos: Makefile
194
 
        $(strip $(SED) --in-place \
195
 
                --expression='s/^\(version = "\)[^"]*"$$/\1$(version)"/' \
196
 
                $@)
197
 
 
198
 
mandos-keygen: Makefile
199
 
        $(strip $(SED) --in-place \
200
 
                --expression='s/^\(VERSION="\)[^"]*"$$/\1$(version)"/' \
201
 
                $@)
202
 
 
203
 
mandos-ctl: Makefile
204
 
        $(strip $(SED) --in-place \
205
 
                --expression='s/^\(version = "\)[^"]*"$$/\1$(version)"/' \
206
 
                $@)
207
 
 
208
 
mandos-monitor: Makefile
209
 
        $(strip $(SED) --in-place \
210
 
                --expression='s/^\(version = "\)[^"]*"$$/\1$(version)"/' \
211
 
                $@)
212
 
 
213
 
mandos.lsm: Makefile
214
 
        $(strip $(SED) --in-place \
215
 
                --expression='s/^\(Version:\).*/\1\t$(version)/' \
216
 
                $@)
217
 
        $(strip $(SED) --in-place \
218
 
                --expression='s/^\(Entered-date:\).*/\1\t$(shell date --rfc-3339=date --reference=Makefile)/' \
219
 
                $@)
220
 
        $(strip $(SED) --in-place \
221
 
                --expression='s/\(mandos_\)[0-9.]\+\(\.orig\.tar\.gz\)/\1$(version)\2/' \
222
 
                $@)
223
 
 
224
 
plugins.d/mandos-client: plugins.d/mandos-client.c
225
 
        $(LINK.c) $^ -lrt $(GNUTLS_LIBS) $(AVAHI_LIBS) $(strip\
226
 
                ) $(GPGME_LIBS) $(LOADLIBES) $(LDLIBS) -o $@
227
 
 
228
 
.PHONY : all doc html clean distclean run-client run-server install \
229
 
        install-server install-client uninstall uninstall-server \
230
 
        uninstall-client purge purge-server purge-client
 
1
CFLAGS=-Wall -g -std=gnu99
 
2
LDFLAGS=-lgnutls
 
3
 
 
4
all: plugbasedclient
231
5
 
232
6
clean:
233
 
        -rm --force $(CPROGS) $(objects) $(htmldocs) $(DOCS) core
234
 
 
235
 
distclean: clean
236
 
mostlyclean: clean
237
 
maintainer-clean: clean
238
 
        -rm --force --recursive keydir confdir statedir
239
 
 
240
 
check:  all
241
 
        ./mandos --check
242
 
 
243
 
# Run the client with a local config and key
244
 
run-client: all keydir/seckey.txt keydir/pubkey.txt
245
 
        @echo "###################################################################"
246
 
        @echo "# The following error messages are harmless and can be safely     #"
247
 
        @echo "# ignored.  The messages are caused by not running as root, but   #"
248
 
        @echo "# you should NOT run \"make run-client\" as root unless you also    #"
249
 
        @echo "# unpacked and compiled Mandos as root, which is NOT recommended. #"
250
 
        @echo "# From plugin-runner: setuid: Operation not permitted             #"
251
 
        @echo "# From askpass-fifo:  mkfifo: Permission denied                   #"
252
 
        @echo "# From mandos-client: setuid: Operation not permitted             #"
253
 
        @echo "#                     seteuid: Operation not permitted            #"
254
 
        @echo "#                     klogctl: Operation not permitted            #"
255
 
        @echo "###################################################################"
256
 
        ./plugin-runner --plugin-dir=plugins.d \
257
 
                --config-file=plugin-runner.conf \
258
 
                --options-for=mandos-client:--seckey=keydir/seckey.txt,--pubkey=keydir/pubkey.txt \
259
 
                $(CLIENTARGS)
260
 
 
261
 
# Used by run-client
262
 
keydir/seckey.txt keydir/pubkey.txt: mandos-keygen
263
 
        install --directory keydir
264
 
        ./mandos-keygen --dir keydir --force
265
 
 
266
 
# Run the server with a local config
267
 
run-server: confdir/mandos.conf confdir/clients.conf
268
 
        ./mandos --debug --no-dbus --configdir=confdir \
269
 
                --statedir=statedir $(SERVERARGS)
270
 
 
271
 
# Used by run-server
272
 
confdir/mandos.conf: mandos.conf
273
 
        install --directory confdir
274
 
        install --mode=u=rw,go=r $^ $@
275
 
confdir/clients.conf: clients.conf keydir/seckey.txt
276
 
        install --directory confdir
277
 
        install --mode=u=rw $< $@
278
 
# Add a client password
279
 
        ./mandos-keygen --dir keydir --password >> $@
280
 
statedir:
281
 
        install --directory statedir
282
 
 
283
 
install: install-server install-client-nokey
284
 
 
285
 
install-html: html
286
 
        install --directory $(htmldir)
287
 
        install --mode=u=rw,go=r --target-directory=$(htmldir) \
288
 
                $(htmldocs)
289
 
 
290
 
install-server: doc
291
 
        install --directory $(CONFDIR)
292
 
        install --directory --mode=u=rwx --owner=$(USER) \
293
 
                --group=$(GROUP) $(STATEDIR)
294
 
        install --mode=u=rwx,go=rx mandos $(PREFIX)/sbin/mandos
295
 
        install --mode=u=rwx,go=rx --target-directory=$(PREFIX)/sbin \
296
 
                mandos-ctl
297
 
        install --mode=u=rwx,go=rx --target-directory=$(PREFIX)/sbin \
298
 
                mandos-monitor
299
 
        install --mode=u=rw,go=r --target-directory=$(CONFDIR) \
300
 
                mandos.conf
301
 
        install --mode=u=rw --target-directory=$(CONFDIR) \
302
 
                clients.conf
303
 
        install --mode=u=rw,go=r dbus-mandos.conf \
304
 
                $(DESTDIR)/etc/dbus-1/system.d/mandos.conf
305
 
        install --mode=u=rwx,go=rx init.d-mandos \
306
 
                $(DESTDIR)/etc/init.d/mandos
307
 
        install --mode=u=rw,go=r default-mandos \
308
 
                $(DESTDIR)/etc/default/mandos
309
 
        if [ -z $(DESTDIR) ]; then \
310
 
                update-rc.d mandos defaults 25 15;\
311
 
        fi
312
 
        gzip --best --to-stdout mandos.8 \
313
 
                > $(MANDIR)/man8/mandos.8.gz
314
 
        gzip --best --to-stdout mandos-monitor.8 \
315
 
                > $(MANDIR)/man8/mandos-monitor.8.gz
316
 
        gzip --best --to-stdout mandos-ctl.8 \
317
 
                > $(MANDIR)/man8/mandos-ctl.8.gz
318
 
        gzip --best --to-stdout mandos.conf.5 \
319
 
                > $(MANDIR)/man5/mandos.conf.5.gz
320
 
        gzip --best --to-stdout mandos-clients.conf.5 \
321
 
                > $(MANDIR)/man5/mandos-clients.conf.5.gz
322
 
 
323
 
install-client-nokey: all doc
324
 
        install --directory $(PREFIX)/lib/mandos $(CONFDIR)
325
 
        install --directory --mode=u=rwx $(KEYDIR) \
326
 
                $(PREFIX)/lib/mandos/plugins.d
327
 
        if [ "$(CONFDIR)" != "$(PREFIX)/lib/mandos" ]; then \
328
 
                install --mode=u=rwx \
329
 
                        --directory "$(CONFDIR)/plugins.d"; \
330
 
        fi
331
 
        install --mode=u=rwx,go=rx \
332
 
                --target-directory=$(PREFIX)/lib/mandos plugin-runner
333
 
        install --mode=u=rwx,go=rx --target-directory=$(PREFIX)/sbin \
334
 
                mandos-keygen
335
 
        install --mode=u=rwx,go=rx \
336
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
337
 
                plugins.d/password-prompt
338
 
        install --mode=u=rwxs,go=rx \
339
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
340
 
                plugins.d/mandos-client
341
 
        install --mode=u=rwxs,go=rx \
342
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
343
 
                plugins.d/usplash
344
 
        install --mode=u=rwxs,go=rx \
345
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
346
 
                plugins.d/splashy
347
 
        install --mode=u=rwxs,go=rx \
348
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
349
 
                plugins.d/askpass-fifo
350
 
        install --mode=u=rwxs,go=rx \
351
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
352
 
                plugins.d/plymouth
353
 
        install initramfs-tools-hook \
354
 
                $(INITRAMFSTOOLS)/hooks/mandos
355
 
        install --mode=u=rw,go=r initramfs-tools-hook-conf \
356
 
                $(INITRAMFSTOOLS)/conf-hooks.d/mandos
357
 
        install initramfs-tools-script \
358
 
                $(INITRAMFSTOOLS)/scripts/init-premount/mandos
359
 
        install --mode=u=rw,go=r plugin-runner.conf $(CONFDIR)
360
 
        gzip --best --to-stdout mandos-keygen.8 \
361
 
                > $(MANDIR)/man8/mandos-keygen.8.gz
362
 
        gzip --best --to-stdout plugin-runner.8mandos \
363
 
                > $(MANDIR)/man8/plugin-runner.8mandos.gz
364
 
        gzip --best --to-stdout plugins.d/mandos-client.8mandos \
365
 
                > $(MANDIR)/man8/mandos-client.8mandos.gz
366
 
        gzip --best --to-stdout plugins.d/password-prompt.8mandos \
367
 
                > $(MANDIR)/man8/password-prompt.8mandos.gz
368
 
        gzip --best --to-stdout plugins.d/usplash.8mandos \
369
 
                > $(MANDIR)/man8/usplash.8mandos.gz
370
 
        gzip --best --to-stdout plugins.d/splashy.8mandos \
371
 
                > $(MANDIR)/man8/splashy.8mandos.gz
372
 
        gzip --best --to-stdout plugins.d/askpass-fifo.8mandos \
373
 
                > $(MANDIR)/man8/askpass-fifo.8mandos.gz
374
 
        gzip --best --to-stdout plugins.d/plymouth.8mandos \
375
 
                > $(MANDIR)/man8/plymouth.8mandos.gz
376
 
 
377
 
install-client: install-client-nokey
378
 
# Post-installation stuff
379
 
        -$(PREFIX)/sbin/mandos-keygen --dir "$(KEYDIR)"
380
 
        update-initramfs -k all -u
381
 
        echo "Now run mandos-keygen --password --dir $(KEYDIR)"
382
 
 
383
 
uninstall: uninstall-server uninstall-client
384
 
 
385
 
uninstall-server:
386
 
        -rm --force $(PREFIX)/sbin/mandos \
387
 
                $(PREFIX)/sbin/mandos-ctl \
388
 
                $(PREFIX)/sbin/mandos-monitor \
389
 
                $(MANDIR)/man8/mandos.8.gz \
390
 
                $(MANDIR)/man8/mandos-monitor.8.gz \
391
 
                $(MANDIR)/man8/mandos-ctl.8.gz \
392
 
                $(MANDIR)/man5/mandos.conf.5.gz \
393
 
                $(MANDIR)/man5/mandos-clients.conf.5.gz
394
 
        update-rc.d -f mandos remove
395
 
        -rmdir $(CONFDIR)
396
 
 
397
 
uninstall-client:
398
 
# Refuse to uninstall client if /etc/crypttab is explicitly configured
399
 
# to use it.
400
 
        ! grep --regexp='^ *[^ #].*keyscript=[^,=]*/mandos/' \
401
 
                $(DESTDIR)/etc/crypttab
402
 
        -rm --force $(PREFIX)/sbin/mandos-keygen \
403
 
                $(PREFIX)/lib/mandos/plugin-runner \
404
 
                $(PREFIX)/lib/mandos/plugins.d/password-prompt \
405
 
                $(PREFIX)/lib/mandos/plugins.d/mandos-client \
406
 
                $(PREFIX)/lib/mandos/plugins.d/usplash \
407
 
                $(PREFIX)/lib/mandos/plugins.d/splashy \
408
 
                $(PREFIX)/lib/mandos/plugins.d/askpass-fifo \
409
 
                $(PREFIX)/lib/mandos/plugins.d/plymouth \
410
 
                $(INITRAMFSTOOLS)/hooks/mandos \
411
 
                $(INITRAMFSTOOLS)/conf-hooks.d/mandos \
412
 
                $(INITRAMFSTOOLS)/scripts/init-premount/mandos \
413
 
                $(MANDIR)/man8/mandos-keygen.8.gz \
414
 
                $(MANDIR)/man8/plugin-runner.8mandos.gz \
415
 
                $(MANDIR)/man8/mandos-client.8mandos.gz
416
 
                $(MANDIR)/man8/password-prompt.8mandos.gz \
417
 
                $(MANDIR)/man8/usplash.8mandos.gz \
418
 
                $(MANDIR)/man8/splashy.8mandos.gz \
419
 
                $(MANDIR)/man8/askpass-fifo.8mandos.gz \
420
 
                $(MANDIR)/man8/plymouth.8mandos.gz \
421
 
        -rmdir $(PREFIX)/lib/mandos/plugins.d $(CONFDIR)/plugins.d \
422
 
                 $(PREFIX)/lib/mandos $(CONFDIR) $(KEYDIR)
423
 
        update-initramfs -k all -u
424
 
 
425
 
purge: purge-server purge-client
426
 
 
427
 
purge-server: uninstall-server
428
 
        -rm --force $(CONFDIR)/mandos.conf $(CONFDIR)/clients.conf \
429
 
                $(DESTDIR)/etc/dbus-1/system.d/mandos.conf
430
 
                $(DESTDIR)/etc/default/mandos \
431
 
                $(DESTDIR)/etc/init.d/mandos \
432
 
                $(DESTDIR)/var/run/mandos.pid
433
 
        -rmdir $(CONFDIR)
434
 
 
435
 
purge-client: uninstall-client
436
 
        -shred --remove $(KEYDIR)/seckey.txt
437
 
        -rm --force $(CONFDIR)/plugin-runner.conf \
438
 
                $(KEYDIR)/pubkey.txt $(KEYDIR)/seckey.txt
439
 
        -rmdir $(KEYDIR) $(CONFDIR)/plugins.d $(CONFDIR)
 
7
        rm -f plugbasedclient