/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

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