/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-12-10 01:26:02 UTC
  • mfrom: (237.1.2 mandos)
  • Revision ID: teddy@fukt.bsnet.se-20081210012602-vhz3h75xkj24t340
First version of a somewhat complete D-Bus server interface.  Also
change user/group name to "_mandos".

* debian/mandos.postinst: Rename old "mandos" user and group to
                          "_mandos"; create "_mandos" user and group
                          if none exist.
* debian/mandos-client.postinst: - '' -

* initramfs-tools-hook: Try "_mandos" before "mandos" as user and
                        group name.

* mandos (_datetime_to_dbus_struct): New; was previously local.
  (Client.started): Renamed to "last_started".  All users changed.
  (Client.started): New; boolean.
  (Client.dbus_object_path): New.
  (Client.check_command): Renamed to "checker_command".  All users
                          changed.
  (Client.__init__): Set and use "self.dbus_object_path".  Set
                     "self.started".
  (Client.start): Update "self.started".  Emit "self.PropertyChanged"
                  signals for both "started" and "last_started".
  (Client.stop): Update "self.started".  Emit "self.PropertyChanged"
                 signal for "started".
  (Client.checker_callback): Take additional "command" argument.  All
                             callers changed. Emit
                             "self.PropertyChanged" signal.
  (Client.bump_timeout): Emit "self.PropertyChanged" signal for
                         "last_checked_ok".
  (Client.start_checker): Emit "self.PropertyChanged" signal for
                          "checker_running".
  (Client.stop_checker): Emit "self.PropertyChanged" signal for
                         "checker_running".
  (Client.still_valid): Bug fix: use "getattr(self, started, False)"
                        instead of "self.started" in case this client
                        object is so new that the "started" attribute
                        has not been created yet.
  (Client.IntervalChanged, Client.CheckerIsRunning, Client.GetChecker,
  Client.GetCreated, Client.GetFingerprint, Client.GetHost,
  Client.GetInterval, Client.GetName, Client.GetStarted,
  Client.GetTimeout, Client.StateChanged, Client.TimeoutChanged):
  Removed; all callers changed.
  (Client.CheckerCompleted): Add "condition" and "command" arguments.
                             All callers changed.
  (Client.GetAllProperties, Client.PropertyChanged): New.
  (Client.StillValid): Renamed to "IsStillValid".
  (Client.StartChecker): Changed to its own function to avoid the
                         return value from "Client.start_checker()".
  (Client.Stop): Changed to its own function to avoid the return value
                 from "Client.stop()".
  (main): Try "_mandos" before "mandos" as user and group name.
          Removed inner function "remove_from_clients".  New inner
          class "MandosServer".

Show diffs side-by-side

added added

removed removed

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