blob: 59a2229f7396afda96b084cb571e5f39c016547a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
|
# Copyright 1999-2021 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=7
inherit savedconfig pam
DESCRIPTION="small SSH 2 client/server designed for small memory environments"
HOMEPAGE="https://matt.ucc.asn.au/dropbear/dropbear.html"
SRC_URI="https://matt.ucc.asn.au/dropbear/releases/${P}.tar.bz2
https://matt.ucc.asn.au/dropbear/testing/${P}.tar.bz2"
LICENSE="MIT GPL-2" # (init script is GPL-2 #426056)
SLOT="0"
KEYWORDS="~alpha ~amd64 arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 ~sparc ~x86 ~amd64-linux ~x86-linux ~x64-macos"
IUSE="bsdpty minimal multicall pam +shadow static +syslog zlib"
LIB_DEPEND="
zlib? ( sys-libs/zlib[static-libs(+)] )
"
RDEPEND="
acct-group/sshd
acct-user/sshd
!static? (
>=dev-libs/libtomcrypt-1.18.2-r2
>=dev-libs/libtommath-1.2.0
${LIB_DEPEND//\[static-libs(+)]}
)
pam? ( sys-libs/pam )
"
DEPEND="
${RDEPEND}
static? ( ${LIB_DEPEND} )
"
RDEPEND+=" pam? ( >=sys-auth/pambase-20080219.1 )"
REQUIRED_USE="pam? ( !static )"
PATCHES=(
"${FILESDIR}"/${PN}-0.46-dbscp.patch
)
set_options() {
progs=(
dropbear dbclient dropbearkey
$(usex minimal "" "dropbearconvert scp")
)
makeopts=(
MULTI=$(usex multicall 1 0)
)
}
pkg_setup() {
if use static ; then
ewarn "Using bundled copies of libtommath and libtomcrypt"
fi
}
src_prepare() {
default
sed \
-e '/SFTPSERVER_PATH/s:".*":"/usr/lib/misc/sftp-server":' \
default_options.h > localoptions.h || die
sed \
-e '/pam_start/s:sshd:dropbear:' \
-i svr-authpam.c || die
restore_config localoptions.h
}
src_configure() {
# Notes:
# 1) We use bundled libtom* when static build is enabled because
# libtomcrypt lacks it and we don't particularly want to add it.
# 2) We disable the hardening flags as our compiler already enables them
# by default as is appropriate for the target.
local myeconfargs=(
--disable-harden
$(use_enable static bundled-libtom)
$(use_enable zlib)
$(use_enable pam)
$(use_enable !bsdpty openpty)
$(use_enable shadow)
$(use_enable static)
$(use_enable syslog)
)
econf "${myeconfargs[@]}"
}
src_compile() {
set_options
emake "${makeopts[@]}" PROGRAMS="${progs[*]}"
}
src_install() {
set_options
emake "${makeopts[@]}" PROGRAMS="${progs[*]}" DESTDIR="${D}" install
doman *.8
newinitd "${FILESDIR}"/dropbear.init.d dropbear
newconfd "${FILESDIR}"/dropbear.conf.d dropbear
dodoc CHANGES README SMALL MULTI
# The multi install target does not install the links right.
if use multicall ; then
cd "${ED}"/usr/bin || die
local x
for x in "${progs[@]}" ; do
ln -sf dropbearmulti ${x} || die "ln -s dropbearmulti to ${x} failed"
done
rm -f dropbear
dodir /usr/sbin
dosym ../bin/dropbearmulti /usr/sbin/dropbear
cd "${S}" || die
fi
save_config localoptions.h
if ! use minimal ; then
mv "${ED}"/usr/bin/{,db}scp || die
fi
if use pam; then
pamd_mimic system-remote-login dropbear auth account password session
fi
}
|