/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 debian/rules

  • Committer: Teddy Hogeborn
  • Date: 2024-11-24 00:44:25 UTC
  • Revision ID: teddy@recompile.se-20241124004425-6k3y0ir1ksyjq3c4
mandos-keygen: Show warning about old OpenSSH versions

When generating a config file snippet on the Mandos client system
using mandos-keygen, and the default ssh-keyscan checker is used, and
if the OpenSSH version is 9.8 or later, the "checker" command
generated for the config file on the Mandos server will include the
"-q" option for ssh-keyscan.  This option did not exist on ssh-keyscan
from OpenSSH older than version 9.8.  Therefore, if the Mandos
*server* is running an older version of OpenSSH, where ssh-keyscan
does not support the "-q" option, this option must be removed from the
generated "checker" setting.  Since we cannot know if this is the case
when running mandos-keygen on the Mandos client system, we print this
information as a comment above the generated "checker" setting.

* mandos-keygen: Show warning if the new "-q" options was used with
  ssh-keyscan in the generated "checker" setting.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
#!/usr/bin/make -f
2
 
# Sample debian/rules that uses debhelper.
3
 
#
4
 
# This file was originally written by Joey Hess and Craig Small.
5
 
# As a special exception, when this file is copied by dh-make into a
6
 
# dh-make output file, you may use that output file without restriction.
7
 
# This special exception was added by Craig Small in version 0.37 of dh-make.
8
 
#
9
 
# Modified to make a template file for a multi-binary package with separated
10
 
# build-arch and build-indep targets  by Bill Allombert 2001
11
 
 
12
 
# Uncomment this to turn on verbose mode.
13
 
#export DH_VERBOSE=1
14
 
 
15
 
# This has to be exported to make some magic below work.
16
 
export DH_OPTIONS
17
 
 
18
 
# -pie is broken on the mips and mipsel architectures, see
19
 
# <http://bugs.debian.org/526961>
20
 
ifneq (,$(findstring :$(DEB_HOST_ARCH):,:mips:mipsel:))
21
 
  BROKEN_PIE := yes
22
 
  export BROKEN_PIE
23
 
endif
24
 
ifneq (,$(findstring :$(DEB_BUILD_ARCH):,:mips:mipsel:))
25
 
  BROKEN_PIE := yes
26
 
  export BROKEN_PIE
27
 
endif
28
 
 
29
 
configure: configure-stamp
30
 
configure-stamp:
31
 
        dh_testdir
32
 
        touch configure-stamp
33
 
 
34
 
build: build-arch build-indep
35
 
 
36
 
build-arch: build-arch-stamp
37
 
build-arch-stamp: configure-stamp
38
 
        dh_auto_build -- all doc
39
 
        touch $@
40
 
 
41
 
build-indep: build-indep-stamp
42
 
build-indep-stamp: configure-stamp
43
 
        dh_auto_build -- doc
44
 
        touch $@
45
 
 
46
 
clean:
47
 
        dh_testdir
48
 
        dh_testroot
49
 
        rm -f build-arch-stamp build-indep-stamp configure-stamp
50
 
        dh_auto_clean
51
 
        dh_clean
52
 
 
53
 
install: install-indep install-arch
54
 
install-indep:
55
 
        dh_testdir
56
 
        dh_testroot
57
 
        dh_prep
58
 
        dh_installdirs --indep
59
 
        $(MAKE) DESTDIR=$(CURDIR)/debian/mandos install-server
60
 
        dh_lintian
 
2
 
 
3
ifeq (,$(filter noopt,$(DEB_BUILD_OPTIONS)))
 
4
    MAKEFLAGS += OPTIMIZE=-O0
 
5
endif
 
6
 
 
7
ifneq (,$(filter parallel=%,$(DEB_BUILD_OPTIONS)))
 
8
    NUMJOBS = $(patsubst parallel=%,%,$(filter parallel=%,$(DEB_BUILD_OPTIONS)))
 
9
    MAKEFLAGS += -j$(NUMJOBS)
 
10
endif
 
11
 
 
12
PKG_CONFIG?=pkg-config
 
13
 
 
14
%:
 
15
        dh $@
 
16
 
 
17
override_dh_installdirs-indep:
 
18
        dh_installdirs
 
19
        dh_installdirs $(patsubst /%,%,$(shell $(PKG_CONFIG) \
 
20
                systemd --variable=systemdsystemunitdir)) \
 
21
                $(patsubst /%,%,$(shell $(PKG_CONFIG) \
 
22
                systemd --variable=tmpfilesdir)) \
 
23
                $(patsubst /%,%,$(shell $(PKG_CONFIG) \
 
24
                systemd --variable=sysusersdir))
 
25
 
 
26
override_dh_installdirs-arch:
 
27
        dh_installdirs
 
28
        dh_installdirs $(patsubst /%,%,$(shell $(PKG_CONFIG) \
 
29
                systemd --variable=sysusersdir))
 
30
 
 
31
override_dh_auto_build-arch:
 
32
        LC_ALL=en_US.utf8 dh_auto_build -- all doc
 
33
 
 
34
override_dh_auto_build-indep:
 
35
        LC_ALL=en_US.utf8 dh_auto_build -- doc
 
36
 
 
37
override_dh_installinit-indep:
61
38
        dh_installinit --onlyscripts \
62
39
                --update-rcd-params="defaults 25 15"
63
 
        dh_install --indep
64
 
 
65
 
install-arch:
66
 
        dh_testdir
67
 
        dh_testroot
68
 
        dh_prep
69
 
        dh_installdirs --same-arch
70
 
        $(MAKE) DESTDIR=$(CURDIR)/debian/mandos-client install-client-nokey
71
 
        dh_lintian
72
 
        dh_install --same-arch
73
 
 
74
 
binary-common:
75
 
        dh_testdir
76
 
        dh_testroot
77
 
        dh_installchangelogs
78
 
        dh_installdocs
79
 
        dh_link
80
 
        dh_strip
81
 
        dh_compress
 
40
 
 
41
override_dh_auto_install-indep:
 
42
        $(MAKE) DESTDIR=$(CURDIR)/debian/mandos install-server
 
43
 
 
44
override_dh_auto_install-arch:
 
45
        $(MAKE) DESTDIR=$(CURDIR)/debian/mandos-client \
 
46
                install-client-nokey
 
47
 
 
48
override_dh_fixperms-arch:
82
49
        dh_fixperms --exclude etc/keys/mandos \
83
 
                --exclude etc/mandos/clients.conf \
84
50
                --exclude etc/mandos/plugins.d \
85
 
                --exclude usr/lib/mandos/plugins.d
86
 
        dh_installdeb
87
 
        dh_shlibdeps
88
 
        dh_gencontrol
89
 
        dh_md5sums
90
 
        dh_builddeb
91
 
 
92
 
# Build architecture independant packages using the common target.
93
 
binary-indep: build-indep install-indep
94
 
        $(MAKE) -f debian/rules DH_OPTIONS=--indep binary-common
95
 
 
96
 
# Build architecture dependant packages using the common target.
97
 
binary-arch: build-arch install-arch
98
 
        $(MAKE) -f debian/rules DH_OPTIONS=--same-arch binary-common
99
 
 
100
 
binary: binary-arch binary-indep
101
 
 
102
 
.PHONY: build clean binary-indep binary-arch binary install \
103
 
                install-indep install-arch configure
 
51
                --exclude etc/mandos/plugin-helpers \
 
52
                --exclude usr/lib/$(DEB_HOST_MULTIARCH)/mandos/plugins.d \
 
53
                --exclude usr/lib/$(DEB_HOST_MULTIARCH)/mandos/plugin-helpers \
 
54
                --exclude usr/share/doc/mandos-client/examples/network-hooks.d/
 
55
        chmod --recursive g-w -- \
 
56
        "$(CURDIR)/debian/mandos-client/usr/share/doc/mandos-client/examples/network-hooks.d"
 
57
 
 
58
override_dh_fixperms-indep:
 
59
        dh_fixperms --exclude etc/mandos/clients.conf
 
60
 
 
61
override_dh_auto_test-arch: ;
 
62
 
 
63
#bpo## dpkg-shlibdeps sees the "libgnutls28-dev (>= 3.6.6) |
 
64
#bpo## libgnutls28-dev (<< 3.6.0)," in the build-dependencies not as two
 
65
#bpo## alternatives, but as an absolute dependency on libgnutls30 >= 3.6.6.
 
66
#bpo## So we have to do this ugly hack to hide this build dependency if we
 
67
#bpo## compiled with libgnutls30 << 3.6.0.
 
68
#bpo#override_dh_shlibdeps-arch:
 
69
#bpo#   -gnutls_version=$$(dpkg-query --showformat='$${Version}' \
 
70
#bpo#           --show libgnutls30); \
 
71
#bpo#   dpkg --compare-versions $$gnutls_version lt 3.6.0 \
 
72
#bpo#           && { cp --archive debian/control debian/control.orig; sed --in-place --expression='s/libgnutls28-dev (>= 3\.6\.6) |//' debian/control; }
 
73
#bpo#   dh_shlibdeps
 
74
#bpo#   -gnutls_version=$$(dpkg-query --showformat='$${Version}' \
 
75
#bpo#           --show libgnutls30); \
 
76
#bpo#   dpkg --compare-versions $$gnutls_version lt 3.6.0 \
 
77
#bpo#           && mv debian/control.orig debian/control