blob: 051af43d6b57994547ac40a301ff0f6619219214 (
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
|
# Copyright 1999-2016 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Id$
EAPI=6
inherit eutils systemd
DESCRIPTION="A lightweight secured SOCKS5 proxy for embedded devices and low end boxes"
HOMEPAGE="https://github.com/shadowsocks/shadowsocks-libev"
MY_PV="v${PV}"
SRC_URI="https://github.com/shadowsocks/${PN}/archive/${MY_PV}.tar.gz -> ${P}.tar.gz"
LICENSE="GPL-3+"
SLOT="0"
KEYWORDS="~amd64 ~x86"
IUSE="debug doc +openssl mbedtls +system-libs"
RDEPEND="openssl? ( dev-libs/openssl:= )
mbedtls? ( net-libs/mbedtls )
system-libs? (
dev-libs/libsodium
dev-libs/libev
net-libs/udns
)
"
DEPEND="${RDEPEND}
sys-kernel/linux-headers
doc? (
app-text/asciidoc
app-text/xmlto
)
"
REQUIRED_USE=" ^^ ( openssl mbedtls )"
src_configure() {
econf \
$(use_enable debug assert) \
$(use_enable doc documentation) \
$(use_enable system-libs system-shared-lib) \
--with-crypto-library=$(usex openssl openssl mbedtls)
}
src_install() {
default
prune_libtool_files --all
dodir "/etc/${PN}"
insinto "/etc/${PN}"
newins "${FILESDIR}/shadowsocks.json" shadowsocks.json
newinitd "${FILESDIR}/shadowsocks.initd" shadowsocks
dosym /etc/init.d/shadowsocks /etc/init.d/shadowsocks.server
dosym /etc/init.d/shadowsocks /etc/init.d/shadowsocks.client
dosym /etc/init.d/shadowsocks /etc/init.d/shadowsocks.redir
dosym /etc/init.d/shadowsocks /etc/init.d/shadowsocks.tunnel
systemd_newunit "${FILESDIR}/${PN}-local_at.service" "${PN}-local@.service"
systemd_newunit "${FILESDIR}/${PN}-server_at.service" "${PN}-server@.service"
systemd_newunit "${FILESDIR}/${PN}-redir_at.service" "${PN}-redir@.service"
systemd_newunit "${FILESDIR}/${PN}-tunnel_at.service" "${PN}-tunnel@.service"
}
pkg_setup() {
elog "You need to choose the mode"
elog " server: rc-update add shadowsocks.server default"
elog " client: rc-update add shadowsocks.client default"
elog " redir: rc-update add shadowsocks.redir default"
elog " tunnel: rc-update add shadowsocks.tunnel default"
}
|