blob: 0f50674653e733b1d21aa6e6f6d69c2322dc9ce0 [file] [log] [blame]
Patrick Williamsc124f4f2015-09-15 14:41:29 -05001SUMMARY = "Security tool that is a wrapper for TCP daemons"
Brad Bishopd7bf8c12018-02-25 22:55:05 -05002HOMEPAGE = "http://www.softpanorama.org/Net/Network_security/TCP_wrappers/"
Patrick Williamsc124f4f2015-09-15 14:41:29 -05003DESCRIPTION = "Tools for monitoring and filtering incoming requests for tcp \
4 services."
5SECTION = "console/network"
6
7LICENSE = "BSD"
8LIC_FILES_CHKSUM = "file://DISCLAIMER;md5=071bd69cb78b18888ea5e3da5c3127fa"
9PR ="r10"
10
Brad Bishop1a4b7ee2018-12-16 17:11:34 -080011DEPENDS += "libnsl2"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050012
13PACKAGES = "${PN}-dbg libwrap libwrap-doc libwrap-dev libwrap-staticdev ${PN} ${PN}-doc"
14FILES_libwrap = "${base_libdir}/lib*${SOLIBS}"
15FILES_libwrap-doc = "${mandir}/man3 ${mandir}/man5"
16FILES_libwrap-dev = "${libdir}/lib*${SOLIBSDEV} ${includedir}"
17FILES_libwrap-staticdev = "${libdir}/lib*.a"
18FILES_${PN} = "${sbindir}"
19FILES_${PN}-doc = "${mandir}/man8"
20
21SRC_URI = "ftp://ftp.porcupine.org/pub/security/tcp_wrappers_${PV}.tar.gz \
22 file://00_man_quoting.diff \
23 file://01_man_portability.patch \
24 file://05_wildcard_matching.patch \
25 file://06_fix_gethostbyname.patch \
26 file://10_usagi-ipv6.patch \
27 file://11_tcpd_blacklist.patch \
28 file://11_usagi_fix.patch \
29 file://12_makefile_config.patch \
30 file://13_shlib_weaksym.patch \
31 file://14_cidr_support.patch \
32 file://15_match_clarify.patch \
33 file://expand_remote_port.patch \
34 file://have_strerror.patch \
35 file://man_fromhost.patch \
36 file://restore_sigalarm.patch \
37 file://rfc931.diff \
38 file://safe_finger.patch \
39 file://sig_fix.patch \
40 file://siglongjmp.patch \
41 file://socklen_t.patch \
42 file://tcpdchk_libwrapped.patch \
43 file://ldflags.patch \
44 file://rename_strings_variable.patch \
45 file://try-from.8 \
46 file://safe_finger.8 \
47 file://makefile-fix-parallel.patch \
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050048 file://musl-decls.patch \
Brad Bishop316dfdd2018-06-25 12:45:53 -040049 file://0001-Fix-build-with-clang.patch \
Patrick Williamsc124f4f2015-09-15 14:41:29 -050050 "
51
52SRC_URI[md5sum] = "e6fa25f71226d090f34de3f6b122fb5a"
53SRC_URI[sha256sum] = "9543d7adedf78a6de0b221ccbbd1952e08b5138717f4ade814039bb489a4315d"
54
55S = "${WORKDIR}/tcp_wrappers_${PV}"
56
57EXTRA_OEMAKE = "'CC=${CC}' \
58 'AR=${AR}' \
59 'RANLIB=${RANLIB}' \
60 'REAL_DAEMON_DIR=${sbindir}' \
61 'STYLE=-DPROCESS_OPTIONS' \
62 'FACILITY=LOG_DAEMON' \
63 'SEVERITY=LOG_INFO' \
64 'BUGS=' \
65 'VSYSLOG=' \
66 'RFC931_TIMEOUT=10' \
67 'ACCESS=-DHOSTS_ACCESS' \
68 'KILL_OPT=-DKILL_IP_OPTIONS' \
69 'UMASK=-DDAEMON_UMASK=022' \
70 'NETGROUP=${EXTRA_OEMAKE_NETGROUP}' \
Patrick Williamsc124f4f2015-09-15 14:41:29 -050071 'ARFLAGS=rv' \
72 'AUX_OBJ=weak_symbols.o' \
73 'TLI=' \
74 'COPTS=' \
75 'EXTRA_CFLAGS=${CFLAGS} -DSYS_ERRLIST_DEFINED -DHAVE_STRERROR -DHAVE_WEAKSYMS -D_REENTRANT -DINET6=1 -Dss_family=__ss_family -Dss_len=__ss_len'"
76
77EXTRA_OEMAKE_NETGROUP = "-DNETGROUP -DUSE_GETDOMAIN"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050078EXTRA_OEMAKE_NETGROUP_libc-musl = "-DUSE_GETDOMAIN"
79
80EXTRA_OEMAKE_append_libc-musl = " 'LIBS='"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050081
82do_compile () {
83 oe_runmake 'TABLES=-DHOSTS_DENY=\"${sysconfdir}/hosts.deny\" -DHOSTS_ALLOW=\"${sysconfdir}/hosts.allow\"' \
84 all
85}
86
87BINS = "safe_finger tcpd tcpdchk try-from tcpdmatch"
88MANS3 = "hosts_access"
89MANS5 = "hosts_options"
90MANS8 = "tcpd tcpdchk tcpdmatch"
91do_install () {
92 oe_libinstall -a libwrap ${D}${libdir}
93 oe_libinstall -C shared -so libwrap ${D}${base_libdir}
94
95 if [ "${libdir}" != "${base_libdir}" ] ; then
96 rel_lib_prefix=`echo ${libdir} | sed 's,\(^/\|\)[^/][^/]*,..,g'`
97 libname=`readlink ${D}${base_libdir}/libwrap.so | xargs basename`
98 ln -s ${rel_lib_prefix}${base_libdir}/${libname} ${D}${libdir}/libwrap.so
99 rm -f ${D}${base_libdir}/libwrap.so
100 fi
101
102 install -d ${D}${sbindir}
103 for b in ${BINS}; do
104 install -m 0755 $b ${D}${sbindir}/ || exit 1
105 done
106
107 install -d ${D}${mandir}/man3
108 for m in ${MANS3}; do
109 install -m 0644 $m.3 ${D}${mandir}/man3/ || exit 1
110 done
111
112 install -d ${D}${mandir}/man5
113 for m in ${MANS5}; do
114 install -m 0644 $m.5 ${D}${mandir}/man5/ || exit 1
115 done
116
117 install -d ${D}${mandir}/man8
118 for m in ${MANS8}; do
119 install -m 0644 $m.8 ${D}${mandir}/man8/ || exit 1
120 done
121
122 install -m 0644 ${WORKDIR}/try-from.8 ${D}${mandir}/man8/
123 install -m 0644 ${WORKDIR}/safe_finger.8 ${D}${mandir}/man8/
124
125 install -d ${D}${includedir}
126 install -m 0644 tcpd.h ${D}${includedir}/
127
128 install -d ${D}${sysconfdir}
129 touch ${D}${sysconfdir}/hosts.allow
130 touch ${D}${sysconfdir}/hosts.deny
131}
132
133FILES_${PN} += "${sysconfdir}/hosts.allow ${sysconfdir}/hosts.deny"