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