/mandos/release

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

« back to all changes in this revision

Viewing changes to Makefile

  • Committer: Teddy Hogeborn
  • Date: 2008-08-16 03:29:08 UTC
  • Revision ID: teddy@fukt.bsnet.se-20080816032908-ihw7c05r2mnyk389
Add feature to specify custom environment variables for plugins.

* plugin-runner.c (plugin): New members "environ" and "envc" to
                            contain possible custom environment.
  (getplugin): Return NULL on failure instead of doing exit(); all
               callers changed.
  (add_to_char_array): New helper function for "add_argument" and
                       "add_environment".
  (addargument): Renamed to "add_argument".  Return bool.  Call
                 "add_to_char_array" to actually do things.
  (add_environment): New; analogous to "add_argument".
  (addcustomargument): Renamed to "add_to_argv" to avoid confusion
                       with "add_argument".
  (main): New options "--global-envs" and "--envs-for" to specify
          custom environment for plugins.  Print environment for
          plugins in debug mode.  Use asprintf instead of strcpy and
          strcat.  Use execve() for plugins with custom environments.
          Free environment for plugin when freeing plugin list.

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