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