/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: Björn Påhlsson
  • Date: 2008-07-20 02:52:20 UTC
  • Revision ID: belorn@braxen-20080720025220-r5u0388uy9iu23h6
Added following support:
Pluginbased client handler
rewritten Mandos client
       Avahi instead of udp server discovery
       openpgp encrypted key support
Passprompt stand alone application for direct console input
Added logging for Mandos server

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
WARN=-O -Wall -Wformat=2 -Winit-self -Wmissing-include-dirs \
2
 
        -Wswitch-default -Wswitch-enum -Wunused-parameter \
3
 
        -Wstrict-aliasing=2 -Wextra -Wfloat-equal -Wundef -Wshadow \
4
 
        -Wunsafe-loop-optimizations -Wpointer-arith \
5
 
        -Wbad-function-cast -Wcast-qual -Wcast-align -Wwrite-strings \
6
 
        -Wconversion -Wstrict-prototypes -Wold-style-definition \
7
 
        -Wpacked -Wnested-externs -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
13
 
#COVERAGE=--coverage
14
 
OPTIMIZE=-Os
15
 
LANGUAGE=-std=gnu99
16
 
# PREFIX=/usr/local
17
 
PREFIX=$(DESTDIR)/usr
18
 
# CONFDIR=/usr/local/lib/mandos
19
 
CONFDIR=$(DESTDIR)/etc/mandos
20
 
# KEYDIR=/usr/local/lib/mandos/keys
21
 
KEYDIR=$(DESTDIR)/etc/keys/mandos
22
 
# MANDIR=/usr/local/man
23
 
MANDIR=$(DESTDIR)/usr/share/man
24
 
PIDDIR=/var/run/mandos
25
 
USER=nobody
26
 
GROUP=nogroup
27
 
 
28
 
GNUTLS_CFLAGS=$(shell libgnutls-config --cflags)
29
 
GNUTLS_LIBS=$(shell libgnutls-config --libs)
30
 
AVAHI_CFLAGS=$(shell pkg-config --cflags-only-I avahi-core)
31
 
AVAHI_LIBS=$(shell pkg-config --libs avahi-core)
32
 
GPGME_CFLAGS=$(shell gpgme-config --cflags)
33
 
GPGME_LIBS=$(shell gpgme-config --libs)
34
 
 
35
 
# Do not change these two
36
 
CFLAGS=$(WARN) $(DEBUG) $(FORTIFY) $(COVERAGE) $(OPTIMIZE) \
37
 
        $(LANGUAGE) $(GNUTLS_CFLAGS) $(AVAHI_CFLAGS) $(GPGME_CFLAGS)
38
 
LDFLAGS=$(COVERAGE)
39
 
 
40
 
# Commands to format a DocBook refentry document into a manual page
41
 
DOCBOOKTOMAN=cd $(dir $<); xsltproc --nonet --xinclude \
42
 
        --param man.charmap.use.subset          0 \
43
 
        --param make.year.ranges                1 \
44
 
        --param make.single.year.ranges         1 \
45
 
        --param man.output.quietly              1 \
46
 
        --param man.authors.section.enabled     0 \
47
 
         /usr/share/xml/docbook/stylesheet/nwalsh/manpages/docbook.xsl \
48
 
        $(notdir $<); \
49
 
        $(MANPOST) $(notdir $@)
50
 
# DocBook-to-man post-processing to fix a \n escape bug
51
 
MANPOST=sed --in-place --expression='s,\\\\en,\\en,g;s,\\n,\\en,g'
52
 
 
53
 
PLUGINS=plugins.d/password-prompt plugins.d/password-request
54
 
PROGS=plugin-runner $(PLUGINS)
55
 
DOCS=mandos.8 plugin-runner.8mandos mandos-keygen.8 \
56
 
        plugins.d/password-request.8mandos \
57
 
        plugins.d/password-prompt.8mandos mandos.conf.5 \
58
 
        mandos-clients.conf.5
59
 
 
60
 
objects=$(addsuffix .o,$(PROGS))
61
 
 
62
 
all: $(PROGS)
63
 
 
64
 
doc: $(DOCS)
65
 
 
66
 
%.5: %.xml legalnotice.xml
67
 
        $(DOCBOOKTOMAN)
68
 
 
69
 
%.8: %.xml legalnotice.xml
70
 
        $(DOCBOOKTOMAN)
71
 
 
72
 
%.8mandos: %.xml legalnotice.xml
73
 
        $(DOCBOOKTOMAN)
74
 
 
75
 
mandos.8: mandos.xml mandos-options.xml overview.xml legalnotice.xml
76
 
        $(DOCBOOKTOMAN)
77
 
 
78
 
mandos-keygen.8: mandos-keygen.xml overview.xml legalnotice.xml
79
 
        $(DOCBOOKTOMAN)
80
 
 
81
 
mandos.conf.5: mandos.conf.xml mandos-options.xml legalnotice.xml
82
 
        $(DOCBOOKTOMAN)
83
 
 
84
 
plugin-runner.8mandos: plugin-runner.xml overview.xml legalnotice.xml
85
 
        $(DOCBOOKTOMAN)
86
 
 
87
 
plugins.d/password-request.8mandos: plugins.d/password-request.xml \
88
 
                                        mandos-options.xml \
89
 
                                        overview.xml legalnotice.xml
90
 
        $(DOCBOOKTOMAN)
91
 
 
92
 
plugins.d/password-request: plugins.d/password-request.o
93
 
        $(LINK.o) $(GNUTLS_LIBS) $(AVAHI_LIBS) $(GPGME_LIBS) \
94
 
                $(COMMON) $^ $(LOADLIBES) $(LDLIBS) -o $@
95
 
 
96
 
.PHONY : all doc clean distclean run-client run-server install \
97
 
        install-server install-client uninstall uninstall-server \
98
 
        uninstall-client purge purge-server purge-client
 
1
CFLAGS="-Wall -std=gnu99"
 
2
LDFLAGS=-lgnutls
 
3
 
 
4
all: plugbasedclient
99
5
 
100
6
clean:
101
 
        -rm --force $(PROGS) $(objects) $(DOCS) core
102
 
 
103
 
distclean: clean
104
 
mostlyclean: clean
105
 
maintainer-clean: clean
106
 
        -rm --force --recursive keydir confdir
107
 
 
108
 
check:
109
 
        ./mandos --check
110
 
 
111
 
# Run the client with a local config and key
112
 
run-client: all keydir/seckey.txt keydir/pubkey.txt
113
 
        ./plugin-runner --plugin-dir=plugins.d \
114
 
                --config-file=plugin-runner.conf \
115
 
                --options-for=password-request:--seckey=keydir/seckey.txt,--pubkey=keydir/pubkey.txt
116
 
 
117
 
# Used by run-client
118
 
keydir/seckey.txt keydir/pubkey.txt: mandos-keygen
119
 
        install --directory keydir
120
 
        ./mandos-keygen --dir keydir --force
121
 
 
122
 
# Run the server with a local config
123
 
run-server: confdir/mandos.conf confdir/clients.conf
124
 
        ./mandos --debug --configdir=confdir
125
 
 
126
 
# Used by run-server
127
 
confdir/mandos.conf: mandos.conf
128
 
        install --directory confdir
129
 
        install --mode=u=rw,go=r $^ $@
130
 
confdir/clients.conf: clients.conf keydir/seckey.txt
131
 
        install --directory confdir
132
 
        install --mode=u=rw,g=r $< $@
133
 
# Add a client password
134
 
        ./mandos-keygen --dir keydir --password >> $@
135
 
 
136
 
install: install-server install-client
137
 
 
138
 
install-server: doc
139
 
        install --directory $(CONFDIR) $(MANDIR)/man5 \
140
 
                $(MANDIR)/man8
141
 
        install --mode=u=rwx,go=rx --owner=$(USER) --group=$(GROUP) \
142
 
                --directory $(PIDDIR)
143
 
        install --mode=u=rwx,go=rx mandos $(PREFIX)/sbin/mandos
144
 
        install --mode=u=rw,go=r --target-directory=$(CONFDIR) \
145
 
                mandos.conf
146
 
        install --mode=u=rw,g=r --target-directory=$(CONFDIR) \
147
 
                clients.conf
148
 
        install --mode=u=rwx,go=rx init.d-mandos /etc/init.d/mandos
149
 
        install --mode=u=rw,go=r default-mandos /etc/default/mandos
150
 
        update-rc.d mandos defaults
151
 
        gzip --best --to-stdout mandos.8 \
152
 
                > $(MANDIR)/man8/mandos.8.gz
153
 
        gzip --best --to-stdout mandos.conf.5 \
154
 
                > $(MANDIR)/man5/mandos.conf.5.gz
155
 
        gzip --best --to-stdout mandos-clients.conf.5 \
156
 
                > $(MANDIR)/man5/mandos-clients.conf.5.gz
157
 
 
158
 
install-client: all doc /usr/share/initramfs-tools/hooks/.
159
 
        install --directory $(PREFIX)/lib/mandos $(CONFDIR) \
160
 
                $(MANDIR)/man8
161
 
        install --directory --mode=u=rwx $(KEYDIR)
162
 
        install --directory --mode=u=rwx \
163
 
                $(PREFIX)/lib/mandos/plugins.d
164
 
        if [ "$(CONFDIR)/plugins.d" \
165
 
                        != "$(PREFIX)/lib/mandos/plugins.d" ]; then \
166
 
                        install --directory "$(CONFDIR)/plugins.d"; \
167
 
                fi
168
 
        install --mode=u=rwx,go=rx \
169
 
                --target-directory=$(PREFIX)/lib/mandos plugin-runner
170
 
        install --mode=u=rwx,go=rx --target-directory=$(PREFIX)/sbin \
171
 
                mandos-keygen
172
 
        install --mode=u=rwx,go=rx \
173
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
174
 
                plugins.d/password-prompt
175
 
        install --mode=u=rwxs,go=rx \
176
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
177
 
                plugins.d/password-request
178
 
        install --mode=u=rwx,go=rx \
179
 
                --target-directory=$(PREFIX)/lib/mandos/plugins.d \
180
 
                plugins.d/usplash
181
 
        install initramfs-tools-hook \
182
 
                /usr/share/initramfs-tools/hooks/mandos
183
 
        install initramfs-tools-hook-conf \
184
 
                /usr/share/initramfs-tools/conf-hooks.d/mandos
185
 
        install initramfs-tools-script \
186
 
                /usr/share/initramfs-tools/scripts/local-top/mandos
187
 
        install --mode=u=rw,go=r plugin-runner.conf $(CONFDIR)
188
 
        gzip --best --to-stdout mandos-keygen.8 \
189
 
                > $(MANDIR)/man8/mandos-keygen.8.gz
190
 
        gzip --best --to-stdout plugin-runner.8mandos \
191
 
                > $(MANDIR)/man8/plugin-runner.8mandos.gz
192
 
        gzip --best --to-stdout plugins.d/password-prompt.8mandos \
193
 
                > $(MANDIR)/man8/password-prompt.8mandos.gz
194
 
        gzip --best --to-stdout plugins.d/password-request.8mandos \
195
 
                > $(MANDIR)/man8/password-request.8mandos.gz
196
 
        -$(PREFIX)/sbin/mandos-keygen --dir "$(KEYDIR)"
197
 
        update-initramfs -k all -u
198
 
        echo "Now run mandos-keygen --password --dir $(KEYDIR)"
199
 
 
200
 
uninstall: uninstall-server uninstall-client
201
 
 
202
 
uninstall-server:
203
 
        -rm --force $(PREFIX)/sbin/mandos \
204
 
                $(MANDIR)/man8/mandos.8.gz \
205
 
                $(MANDIR)/man5/mandos.conf.5.gz \
206
 
                $(MANDIR)/man5/mandos-clients.conf.5.gz
207
 
        update-rc.d -f mandos remove
208
 
        -rmdir $(CONFDIR) $(PIDDIR)
209
 
 
210
 
uninstall-client:
211
 
# Refuse to uninstall client if /etc/crypttab is explicitly configured
212
 
# to use it.
213
 
        ! grep --regexp='^ *[^ #].*keyscript=[^,=]*/mandos/' \
214
 
                /etc/crypttab
215
 
        -rm --force $(PREFIX)/sbin/mandos-keygen \
216
 
                $(PREFIX)/lib/mandos/plugin-runner \
217
 
                $(PREFIX)/lib/mandos/plugins.d/password-prompt \
218
 
                $(PREFIX)/lib/mandos/plugins.d/password-request \
219
 
                /usr/share/initramfs-tools/hooks/mandos \
220
 
                /usr/share/initramfs-tools/conf-hooks.d/mandos \
221
 
                $(MANDIR)/man8/plugin-runner.8mandos.gz \
222
 
                $(MANDIR)/man8/mandos-keygen.8.gz \
223
 
                $(MANDIR)/man8/password-prompt.8mandos.gz \
224
 
                $(MANDIR)/man8/password-request.8mandos.gz
225
 
        -rmdir $(PREFIX)/lib/mandos/plugins.d $(CONFDIR)/plugins.d \
226
 
                 $(PREFIX)/lib/mandos $(CONFDIR)
227
 
        update-initramfs -k all -u
228
 
 
229
 
purge: purge-server purge-client
230
 
 
231
 
purge-server: uninstall-server
232
 
        -rm --force $(CONFDIR)/mandos.conf $(CONFDIR)/clients.conf \
233
 
                /etc/default/mandos /etc/init.d/mandos
234
 
        -rmdir $(CONFDIR)
235
 
 
236
 
purge-client: uninstall-client
237
 
        -shred --remove $(KEYDIR)/seckey.txt
238
 
        -rm --force $(CONFDIR)/plugin-runner.conf \
239
 
                $(KEYDIR)/pubkey.txt $(KEYDIR)/seckey.txt
240
 
        -rmdir $(KEYDIR) $(CONFDIR)/plugins.d $(CONFDIR)
 
7
        rm -f plugbasedclient
 
8
 
 
9
client_debug: client
 
10
        mv -f client client.tmp
 
11
        $(MAKE) client CXXFLAGS="$(CXXFLAGS) -DDEBUG -DCERT_ROOT=\\\"./\\\""
 
12
        mv client client_debug
 
13
        mv client.tmp client