1*4882a593SmuzhiyunDESCRIPTION = "FreeRADIUS is an Internet authentication daemon, which implements the RADIUS \
2*4882a593Smuzhiyunprotocol, as defined in RFC 2865 (and others). It allows Network Access \
3*4882a593SmuzhiyunServers (NAS boxes) to perform authentication for dial-up users. There are \
4*4882a593Smuzhiyunalso RADIUS clients available for Web servers, firewalls, Unix logins, and \
5*4882a593Smuzhiyunmore.  Using RADIUS allows authentication and authorization for a network to \
6*4882a593Smuzhiyunbe centralized, and minimizes the amount of re-configuration which has to be \
7*4882a593Smuzhiyundone when adding or deleting new users."
8*4882a593Smuzhiyun
9*4882a593SmuzhiyunSUMMARY = "High-performance and highly configurable RADIUS server"
10*4882a593SmuzhiyunHOMEPAGE = "http://www.freeradius.org/"
11*4882a593SmuzhiyunSECTION = "System/Servers"
12*4882a593SmuzhiyunLICENSE = "GPL-2.0-only & LGPL-2.0-or-later"
13*4882a593SmuzhiyunLIC_FILES_CHKSUM = "file://LICENSE;md5=eb723b61539feef013de476e68b5c50a"
14*4882a593SmuzhiyunDEPENDS = "openssl-native openssl libidn libtool libpcap libtalloc"
15*4882a593Smuzhiyun
16*4882a593SmuzhiyunSRC_URI = "git://github.com/FreeRADIUS/freeradius-server.git;branch=v3.0.x;lfs=0;;protocol=https \
17*4882a593Smuzhiyun    file://freeradius \
18*4882a593Smuzhiyun    file://volatiles.58_radiusd \
19*4882a593Smuzhiyun    file://freeradius-enble-user-in-conf.patch \
20*4882a593Smuzhiyun    file://freeradius-configure.ac-allow-cross-compilation.patch \
21*4882a593Smuzhiyun    file://freeradius-libtool-detection.patch \
22*4882a593Smuzhiyun    file://freeradius-configure.ac-add-option-for-libcap.patch \
23*4882a593Smuzhiyun    file://freeradius-avoid-searching-host-dirs.patch \
24*4882a593Smuzhiyun    file://freeradius-rlm_python-add-PY_INC_DIR.patch \
25*4882a593Smuzhiyun    file://freeradius-libtool-do-not-use-jlibtool.patch \
26*4882a593Smuzhiyun    file://freeradius-fix-quoting-for-BUILT_WITH.patch \
27*4882a593Smuzhiyun    file://freeradius-fix-error-for-expansion-of-macro.patch \
28*4882a593Smuzhiyun    file://0001-rlm_mschap-Use-includedir-instead-of-hardcoding-usr-.patch \
29*4882a593Smuzhiyun    file://0001-raddb-certs-Makefile-fix-the-existed-certificate-err.patch \
30*4882a593Smuzhiyun    file://0001-raddb-certs-Makefile-fix-the-occasional-verification.patch \
31*4882a593Smuzhiyun    file://0001-workaround-error-with-autoconf-2.7.patch \
32*4882a593Smuzhiyun    file://radiusd.service \
33*4882a593Smuzhiyun    file://radiusd-volatiles.conf \
34*4882a593Smuzhiyun    file://check-openssl-cmds-in-script-bootstrap.patch \
35*4882a593Smuzhiyun    file://0001-version.c-don-t-print-build-flags.patch \
36*4882a593Smuzhiyun    file://CVE-2022-41860.patch \
37*4882a593Smuzhiyun    file://CVE-2022-41861.patch \
38*4882a593Smuzhiyun"
39*4882a593Smuzhiyun
40*4882a593Smuzhiyunraddbdir="${sysconfdir}/${MLPREFIX}raddb"
41*4882a593Smuzhiyun
42*4882a593SmuzhiyunSRCREV = "af428abda249b2279ba0582180985a9f6f4a144a"
43*4882a593Smuzhiyun
44*4882a593SmuzhiyunCVE_CHECK_IGNORE = "\
45*4882a593Smuzhiyun    CVE-2002-0318 \
46*4882a593Smuzhiyun    CVE-2011-4966 \
47*4882a593Smuzhiyun"
48*4882a593Smuzhiyun
49*4882a593SmuzhiyunPARALLEL_MAKE = ""
50*4882a593Smuzhiyun
51*4882a593SmuzhiyunS = "${WORKDIR}/git"
52*4882a593Smuzhiyun
53*4882a593SmuzhiyunLDFLAGS:append:powerpc = " -latomic"
54*4882a593SmuzhiyunLDFLAGS:append:mipsarch = " -latomic"
55*4882a593SmuzhiyunLDFLAGS:append:armv5 = " -latomic"
56*4882a593Smuzhiyun
57*4882a593SmuzhiyunEXTRA_OECONF = " --enable-strict-dependencies \
58*4882a593Smuzhiyun        --with-docdir=${docdir}/freeradius-${PV} \
59*4882a593Smuzhiyun        --with-openssl-includes=${STAGING_INCDIR} \
60*4882a593Smuzhiyun        --with-openssl-libraries=${STAGING_LIBDIR} \
61*4882a593Smuzhiyun        --with-raddbdir=${raddbdir} \
62*4882a593Smuzhiyun        --without-rlm_ippool \
63*4882a593Smuzhiyun        --without-rlm_cache_memcached \
64*4882a593Smuzhiyun        --without-rlm_counter \
65*4882a593Smuzhiyun        --without-rlm_couchbase \
66*4882a593Smuzhiyun        --without-rlm_dbm \
67*4882a593Smuzhiyun        --without-rlm_eap_tnc \
68*4882a593Smuzhiyun        --without-rlm_eap_ikev2 \
69*4882a593Smuzhiyun        --without-rlm_opendirectory \
70*4882a593Smuzhiyun        --without-rlm_redis \
71*4882a593Smuzhiyun        --without-rlm_rediswho \
72*4882a593Smuzhiyun        --without-rlm_sql_db2 \
73*4882a593Smuzhiyun        --without-rlm_sql_firebird \
74*4882a593Smuzhiyun        --without-rlm_sql_freetds \
75*4882a593Smuzhiyun        --without-rlm_sql_iodbc \
76*4882a593Smuzhiyun        --without-rlm_sql_oracle \
77*4882a593Smuzhiyun        --without-rlm_sql_sybase \
78*4882a593Smuzhiyun        --without-rlm_sql_mongo \
79*4882a593Smuzhiyun        --without-rlm_sqlhpwippool \
80*4882a593Smuzhiyun        --without-rlm_securid \
81*4882a593Smuzhiyun        --without-rlm_unbound \
82*4882a593Smuzhiyun        --without-rlm_python \
83*4882a593Smuzhiyun        ac_cv_path_PERL=${bindir}/perl \
84*4882a593Smuzhiyun        ax_cv_cc_builtin_choose_expr=no \
85*4882a593Smuzhiyun        ax_cv_cc_builtin_types_compatible_p=no \
86*4882a593Smuzhiyun        ax_cv_cc_builtin_bswap64=no \
87*4882a593Smuzhiyun        ax_cv_cc_bounded_attribute=no \
88*4882a593Smuzhiyun"
89*4882a593Smuzhiyun
90*4882a593SmuzhiyunPACKAGECONFIG ??= "${@bb.utils.contains('DISTRO_FEATURES', 'pam', 'pam', '', d)} \
91*4882a593Smuzhiyun                   pcre libcap \
92*4882a593Smuzhiyun                   openssl rlm-eap-fast rlm-eap-pwd \
93*4882a593Smuzhiyun"
94*4882a593Smuzhiyun
95*4882a593SmuzhiyunPACKAGECONFIG[krb5] = "--with-rlm_krb5,--without-rlm_krb5,krb5"
96*4882a593SmuzhiyunPACKAGECONFIG[pam] = "--with-rlm_pam,--without-rlm_pam,libpam"
97*4882a593SmuzhiyunPACKAGECONFIG[libcap] = "--with-libcap,--without-libcap,libcap"
98*4882a593SmuzhiyunPACKAGECONFIG[ldap] = "--with-rlm_ldap,--without-rlm_ldap,openldap"
99*4882a593SmuzhiyunPACKAGECONFIG[mysql] = "--with-rlm_sql_mysql,--without-rlm_sql_mysql,mysql5"
100*4882a593SmuzhiyunPACKAGECONFIG[sqlite] = "--with-rlm_sql_sqlite,--without-rlm_sql_sqlite,sqlite3"
101*4882a593SmuzhiyunPACKAGECONFIG[unixodbc] = "--with-rlm_sql_unixodbc,--without-rlm_sql_unixodbc,unixodbc"
102*4882a593SmuzhiyunPACKAGECONFIG[postgresql] = "--with-rlm_sql_postgresql,--without-rlm_sql_postgresql,postgresql"
103*4882a593SmuzhiyunPACKAGECONFIG[pcre] = "--with-pcre,--without-pcre,libpcre"
104*4882a593SmuzhiyunPACKAGECONFIG[perl] = "--with-perl=${STAGING_BINDIR_NATIVE}/perl-native/perl --with-rlm_perl,--without-rlm_perl,perl-native perl,perl"
105*4882a593SmuzhiyunPACKAGECONFIG[python3] = "--with-rlm_python3 --with-rlm-python3-bin=${STAGING_BINDIR_NATIVE}/python3-native/python3 --with-rlm-python3-include-dir=${STAGING_INCDIR}/${PYTHON_DIR},--without-rlm_python3,python3-native python3"
106*4882a593SmuzhiyunPACKAGECONFIG[rest] = "--with-rlm_rest,--without-rlm_rest,curl json-c"
107*4882a593SmuzhiyunPACKAGECONFIG[ruby] = "--with-rlm_ruby,--without-rlm_ruby,ruby"
108*4882a593SmuzhiyunPACKAGECONFIG[openssl] = "--with-openssl, --without-openssl"
109*4882a593SmuzhiyunPACKAGECONFIG[rlm-eap-fast] = "--with-rlm_eap_fast, --without-rlm_eap_fast"
110*4882a593SmuzhiyunPACKAGECONFIG[rlm-eap-pwd] = "--with-rlm_eap_pwd, --without-rlm_eap_pwd"
111*4882a593Smuzhiyun
112*4882a593Smuzhiyuninherit useradd autotools-brokensep update-rc.d systemd multilib_script multilib_header
113*4882a593Smuzhiyun
114*4882a593SmuzhiyunMULTILIB_SCRIPTS = "${PN}:${sbindir}/checkrad"
115*4882a593Smuzhiyun
116*4882a593Smuzhiyun# This is not a cpan or python based package, but it needs some definitions
117*4882a593Smuzhiyun# from cpan-base and python3-dir bbclasses for building rlm_perl and rlm_python
118*4882a593Smuzhiyun# correctly.
119*4882a593Smuzhiyuninherit cpan-base python3-dir
120*4882a593Smuzhiyun
121*4882a593Smuzhiyun# The modules subdirs also need to be processed by autoreconf. Use autogen.sh
122*4882a593Smuzhiyun# in order to handle the subdirs correctly.
123*4882a593Smuzhiyundo_configure () {
124*4882a593Smuzhiyun    ./autogen.sh
125*4882a593Smuzhiyun
126*4882a593Smuzhiyun    # the configure of rlm_perl needs this to get correct
127*4882a593Smuzhiyun    # mod_cflags and mod_ldflags
128*4882a593Smuzhiyun    if ${@bb.utils.contains('PACKAGECONFIG', 'perl', 'true', 'false', d)}; then
129*4882a593Smuzhiyun        export PERL5LIB="${STAGING_LIBDIR}${PERL_OWN_DIR}/perl/${@get_perl_version(d)}"
130*4882a593Smuzhiyun    fi
131*4882a593Smuzhiyun
132*4882a593Smuzhiyun    oe_runconf
133*4882a593Smuzhiyun
134*4882a593Smuzhiyun    # we don't need dhcpclient
135*4882a593Smuzhiyun    sed -i -e 's/dhcpclient.mk//' ${S}/src/modules/proto_dhcp/all.mk
136*4882a593Smuzhiyun}
137*4882a593Smuzhiyun
138*4882a593SmuzhiyunINITSCRIPT_NAME = "radiusd"
139*4882a593Smuzhiyun
140*4882a593SmuzhiyunSYSTEMD_SERVICE:${PN} = "radiusd.service"
141*4882a593Smuzhiyun
142*4882a593SmuzhiyunUSERADD_PACKAGES = "${PN}"
143*4882a593SmuzhiyunUSERADD_PARAM:${PN} = "--system --no-create-home --shell /bin/false --user-group radiusd"
144*4882a593Smuzhiyun
145*4882a593Smuzhiyundo_install() {
146*4882a593Smuzhiyun    rm -rf ${D}
147*4882a593Smuzhiyun    mkdir -p ${D}/${sysconfdir}/logrotate.d
148*4882a593Smuzhiyun    mkdir -p ${D}/${sysconfdir}/pam.d
149*4882a593Smuzhiyun    mkdir -p ${D}/${sysconfdir}/init.d
150*4882a593Smuzhiyun    mkdir -p ${D}/${localstatedir}/lib/radiusd
151*4882a593Smuzhiyun    mkdir -p ${D}${sysconfdir}/default/volatiles
152*4882a593Smuzhiyun
153*4882a593Smuzhiyun    export LD_LIBRARY_PATH=${D}/${libdir}
154*4882a593Smuzhiyun    oe_runmake install R=${D} INSTALLSTRIP=""
155*4882a593Smuzhiyun
156*4882a593Smuzhiyun    # remove unsupported config files
157*4882a593Smuzhiyun    rm -f ${D}/${raddbdir}/experimental.conf
158*4882a593Smuzhiyun
159*4882a593Smuzhiyun    # remove scripts that required Perl(DBI)
160*4882a593Smuzhiyun    rm -rf ${D}/${bindir}/radsqlrelay
161*4882a593Smuzhiyun
162*4882a593Smuzhiyun    cp -f ${WORKDIR}/freeradius ${D}/etc/init.d/radiusd
163*4882a593Smuzhiyun    rm -f ${D}/${sbindir}/rc.radiusd
164*4882a593Smuzhiyun    chmod +x ${D}/${sysconfdir}/init.d/radiusd
165*4882a593Smuzhiyun    rm -rf ${D}/${localstatedir}/run/
166*4882a593Smuzhiyun    rm -rf ${D}/${localstatedir}/log/
167*4882a593Smuzhiyun    install -m 0644 ${WORKDIR}/volatiles.58_radiusd  ${D}${sysconfdir}/default/volatiles/58_radiusd
168*4882a593Smuzhiyun
169*4882a593Smuzhiyun    chown -R radiusd:radiusd ${D}/${raddbdir}
170*4882a593Smuzhiyun    chown -R radiusd:radiusd ${D}/${localstatedir}/lib/radiusd
171*4882a593Smuzhiyun
172*4882a593Smuzhiyun    # For systemd
173*4882a593Smuzhiyun    if ${@bb.utils.contains('DISTRO_FEATURES', 'systemd', 'true', 'false', d)}; then
174*4882a593Smuzhiyun        install -d ${D}${systemd_unitdir}/system
175*4882a593Smuzhiyun        install -m 0644 ${WORKDIR}/radiusd.service ${D}${systemd_unitdir}/system
176*4882a593Smuzhiyun        sed -i -e 's,@BASE_BINDIR@,${base_bindir},g' \
177*4882a593Smuzhiyun            -e 's,@SBINDIR@,${sbindir},g' \
178*4882a593Smuzhiyun            -e 's,@STATEDIR@,${localstatedir},g' \
179*4882a593Smuzhiyun            -e 's,@SYSCONFDIR@,${sysconfdir},g' \
180*4882a593Smuzhiyun            ${D}${systemd_unitdir}/system/radiusd.service
181*4882a593Smuzhiyun
182*4882a593Smuzhiyun        install -d ${D}${sysconfdir}/tmpfiles.d/
183*4882a593Smuzhiyun        install -m 0644 ${WORKDIR}/radiusd-volatiles.conf ${D}${sysconfdir}/tmpfiles.d/radiusd.conf
184*4882a593Smuzhiyun    fi
185*4882a593Smuzhiyun    oe_multilib_header freeradius/autoconf.h
186*4882a593Smuzhiyun    oe_multilib_header freeradius/missing.h
187*4882a593Smuzhiyun    oe_multilib_header freeradius/radpaths.h
188*4882a593Smuzhiyun}
189*4882a593Smuzhiyun
190*4882a593Smuzhiyun# This is only needed when we install/update on a running target.
191*4882a593Smuzhiyun#
192*4882a593Smuzhiyunpkg_postinst:${PN} () {
193*4882a593Smuzhiyun    if [ -z "$D" ]; then
194*4882a593Smuzhiyun        if command -v systemd-tmpfiles >/dev/null; then
195*4882a593Smuzhiyun            # create /var/log/radius, /var/run/radiusd
196*4882a593Smuzhiyun            systemd-tmpfiles --create ${sysconfdir}/tmpfiles.d/radiusd.conf
197*4882a593Smuzhiyun        elif [ -e ${sysconfdir}/init.d/populate-volatile.sh ]; then
198*4882a593Smuzhiyun            ${sysconfdir}/init.d/populate-volatile.sh update
199*4882a593Smuzhiyun        fi
200*4882a593Smuzhiyun
201*4882a593Smuzhiyun        # Fix ownership for /etc/raddb/*, /var/lib/radiusd
202*4882a593Smuzhiyun        chown -R radiusd:radiusd ${raddbdir}
203*4882a593Smuzhiyun        chown -R radiusd:radiusd ${localstatedir}/lib/radiusd
204*4882a593Smuzhiyun    fi
205*4882a593Smuzhiyun}
206*4882a593Smuzhiyun
207*4882a593Smuzhiyun# We really need the symlink :(
208*4882a593SmuzhiyunINSANE_SKIP:${PN} = "dev-so"
209*4882a593SmuzhiyunINSANE_SKIP:${PN}-krb5 = "dev-so"
210*4882a593SmuzhiyunINSANE_SKIP:${PN}-ldap = "dev-so"
211*4882a593SmuzhiyunINSANE_SKIP:${PN}-mysql = "dev-so"
212*4882a593SmuzhiyunINSANE_SKIP:${PN}-perl = "dev-so"
213*4882a593SmuzhiyunINSANE_SKIP:${PN}-postgresql = "dev-so"
214*4882a593SmuzhiyunINSANE_SKIP:${PN}-python = "dev-so"
215*4882a593SmuzhiyunINSANE_SKIP:${PN}-unixodbc = "dev-so"
216*4882a593Smuzhiyun
217*4882a593SmuzhiyunPACKAGES =+ "${PN}-utils ${PN}-ldap ${PN}-krb5 ${PN}-perl \
218*4882a593Smuzhiyun    ${PN}-python ${PN}-mysql ${PN}-postgresql ${PN}-unixodbc"
219*4882a593Smuzhiyun
220*4882a593SmuzhiyunFILES:${PN}-utils = "${bindir}/*"
221*4882a593Smuzhiyun
222*4882a593SmuzhiyunFILES:${PN}-ldap = "${libdir}/rlm_ldap.so* \
223*4882a593Smuzhiyun    ${raddbdir}/mods-available/ldap \
224*4882a593Smuzhiyun"
225*4882a593Smuzhiyun
226*4882a593SmuzhiyunFILES:${PN}-krb5 = "${libdir}/rlm_krb5.so* \
227*4882a593Smuzhiyun    ${raddbdir}/mods-available/krb5 \
228*4882a593Smuzhiyun"
229*4882a593Smuzhiyun
230*4882a593SmuzhiyunFILES:${PN}-perl = "${libdir}/rlm_perl.so* \
231*4882a593Smuzhiyun    ${raddbdir}/mods-config/perl \
232*4882a593Smuzhiyun    ${raddbdir}/mods-available/perl \
233*4882a593Smuzhiyun"
234*4882a593Smuzhiyun
235*4882a593SmuzhiyunFILES:${PN}-python = "${libdir}/rlm_python3.so* \
236*4882a593Smuzhiyun    ${raddbdir}/mods-config/python3 \
237*4882a593Smuzhiyun    ${raddbdir}/mods-available/python3 \
238*4882a593Smuzhiyun"
239*4882a593Smuzhiyun
240*4882a593SmuzhiyunFILES:${PN}-mysql = "${libdir}/rlm_sql_mysql.so* \
241*4882a593Smuzhiyun    ${raddbdir}/mods-config/sql/*/mysql \
242*4882a593Smuzhiyun    ${raddbdir}/mods-available/sql \
243*4882a593Smuzhiyun"
244*4882a593Smuzhiyun
245*4882a593SmuzhiyunFILES:${PN}-postgresql = "${libdir}/rlm_sql_postgresql.so* \
246*4882a593Smuzhiyun    ${raddbdir}/mods-config/sql/*/postgresql \
247*4882a593Smuzhiyun"
248*4882a593Smuzhiyun
249*4882a593SmuzhiyunFILES:${PN}-unixodbc = "${libdir}/rlm_sql_unixodbc.so*"
250*4882a593Smuzhiyun
251*4882a593SmuzhiyunFILES:${PN} =+ "${libdir}/rlm_*.so* ${libdir}/proto_*so*"
252*4882a593Smuzhiyun
253*4882a593SmuzhiyunRDEPENDS:${PN} += "perl"
254*4882a593SmuzhiyunRDEPENDS:${PN}-utils = "${PN} perl"
255*4882a593Smuzhiyun
256*4882a593SmuzhiyunCLEANBROKEN = "1"
257