| h3. 3.1.2 radsecproxy
h4. 3.1.2.1 Goals and Prerequisites\\
This section describes how to set up radsecproxy to act as a   federation-level RADIUS+RadSec server. It can then completely replace   other RADIUS server products on the federation level.
More precisely, it will enable a server to:
* Accept requests from connected service providers via RADIUS and   RadSec.
* Forward requests to connected identity providers via RADIUS   and RadSec.
* Forward requests from international visitors to the   European eduroam confederation root servers via RadSec.
* Accept requests from the root servers via RadSec for the own federation's users when they are roaming in another federation.
The prerequisites for this deployment are:
* radsecproxy version 1.2 or higher
* A server certificate and a private key for that certificate to establish the RadSec connection which
designates the server as a federation proxy:
          urn:geant:eduroam:component:proxy:Europe:<FedName>:<id>
h4. 3.1.2.2 Sample configuration
Most of the radsecproxy configuration file is static. Therefore, a template configuration file is provided at [http://www.eduroam.org/downloads/docs/eduroam-cookbook-scripts.zip]. A detailed explanation of this configuration file follows. However, the comments included in the file should make its action almost self\- explanatory. This means you can start and experiment with it right after installation.
h4. 3.1.2.3 Installation
On UNIX-like systems, the installation is very simple:
# Download the code from [http://software.uninett.no/radsecproxy/].
# Unpack the code.
# Navigate into the unpacked directory (the base directory) and type:   
_make_
           The code is ISO C and should compile cleanly. It usually does not require a ./configure.
      4.  After compiling, the executable:radsecproxy is in the base directory.
           Either run this executable here or copy it to a convenient location (e.g. /usr/local/bin) and run it there.
           Execution does not require root rights. It expects its configuration file to be in:
           _/etc/radsecproxy.conf_
      5.  Create the directory _/etc/radsecproxy.d/certs/ca/_. The template configuration file requires this directory
           to contain the accredited CA root certificates and the corresponding Certificate Revocation Lists (CAs)
           in their OpenSSL hash form.
      6.  Currently, two CAs are accredited for eduroam. These two certificates and their CRLs need to be copied
           into this directory. For your convenience, we have prepared a script at
           [http://www.eduroam.org/downloads/docs/eduroam-cookbook-scripts.zip], which you can execute in the
           directory. It will download and hash the appropriate files. In this case you can skip steps 7 and 8.
      7.  If you want to download the files manually, download them from these URLs:
*            [http://sca.edugain.org/cacert/eduGAINCA.pem]
*            [http://sca.edugain.org/cacert/eduGAINSCA.pem]
*            [http://pki.edugain.org/edugainca/crl/cacrl.pem]
*            [https://sca.edugain.org/crl/cacrl.pem]
      8.  After downloading, execute the following command in the /etc/radsecproxy.d/certs/ca/ directory:
           \_c_rehash\_ .
           (including the dot) to generate OpenSSL hashes of the downloaded files.
      9.  Make sure that the CRL files are regularly re-downloaded. This can for example be done by executing the
           download script regularly with cron. CRLs have a limited validity time themselves -- not regularly refreshing
           the CRLs will eventually cause certificate validation to fail\!
     10. Copy the template configuration file into /etc/radsecproxy.conf.
     11. Fill the lines marked with __STUFF_\_.
     12. Start radsecproxy and enjoy (for first-time use, starting it with the \--f option is recommended, it will start
           radsecproxy in the foreground and show some verbose startup messages).
h4. 3.1.2.4 Detailed explanation of configuration
This walk-through goes through the template radsecproxy.conf line by line and explains the meaning of each
stanza.
_ListenUDP                 \*:1812{_}{_}ListenTCP                 \*:2083_
radsecproxy will receive requests from all connected Service Providers via both RADIUS and RadSec. Therefore it has to listen on the appropriate ports on its network interfaces (the * meaning: all interfaces). If you want radsecproxy to listen only on specific interfaces, enter the interface names here. Beware: in this case you may also have to set the more exotic options SourceUDP and/or SourceTCP (see the man page of radsecproxy for details).
_LogLevel                   3_
\_LogDestination          [file:///var/log/radsecproxy.log\_|file:///var/log/radsecproxy.log_]
A logging level of 3 is the default and recommended log level. Radsecproxy will then log successful and failed authentications on one line each. The log destination is a typical POSIX-compliant log location.
_LoopPrevention         On_
This enables a semi-automatic prevention of routing loops for RADIUS connections. If you connect a client {...\] and a server {...} and give them the same descriptive name, the proxy will prevent proxying.
_tls default {_
_    CACertificatePath                       /etc/radsecproxy/certs/ca/_
_    CertificateFile                              /etc/radsecproxy/certs/_{_}CERT_PEM_\_\_
_    CertificateKeyFile                        /etc/radsecproxy/certs/_{_}CERT_KEY_\_\_
_    CertificateKeyPassword              \__CERT_PASS_\_\_
    _CRLCheck                                  On_
_}_
This section defines which TLS certificates should be used by default. This installation of radsecproxy always uses the same certificates, so this is the only TLS section. CACertificatePath contains the eduroam-accredited CA certificates with filenames in the OpenSSL hash form. The parameters below need to be adapted to point to your server certificate in PEM format, the private key for this certificate and the password for this private key if needed, respectively. If no password is needed for the private key, you can comment this line (precede it with a # sign). The option CRLCheck validates certificates against the Certificate Revocation List (CRL) of the CAs. It requires a valid CRL in place, or else the certificate validation will fail. Therefore, it is important to regularly update the CRLs by re-downloading them as described above.
_rewrite defaultclient {_
_     removeAttribute                       64_
_     removeAttribute                       65_
_     removeAttribute                       81_
_}_
This section deletes attributes from RADIUS requests that convey VLAN assignment information. If VLAN information is sent inadvertently, it can cause a degraded or non-existent service for the end user because he might be put into the wrong VLAN. Connected service providers should filter this attribute on their own. Connected Identity Providers should not send this attribute at all. Checking for the existence of these attributes on the federation server is just an optional additional safety layer. If you do have a roaming use for cross\- institution VLAN assignment, you may want to delete this stanza.
_client 127.0.0.1 {_
_               type                               udp_
_               secret                            testing123_
_}_
_client ::1 {_
_               type                                udp_
_               secret                             testing123_
_}_
There is no other RADIUS server running on localhost, which makes these client definitions almost superfluous. They may be of some use however to initiate debugging requests and tests from the server itself, so it is considered good practice to list localhost as a client. If your system is not IPv6-enabled, simply delete the stanza about client ::1.
_client \__SP_IP_ADDR__ {\_
_               type                                UDP_
_               secret                             \__SP_SECRET_\_\_
_}_
Stanzas like this one are used for each connected service provider that is connected via RADIUS. You need to know the IP address of every SP's RADIUS server and negotiate a shared secret with the SP.
_client incoming {_
_               host *_
_               type                              TLS_
_               secret                           mysecret_
_               matchcertificateattribute_
\_SubjectAltName:URI:/\^[https://registry.edugain.org/resolver??urn=urn:geant:eduroam:\_|https://registry.edugain.org/resolver\?urn=urn:geant:eduroam:_]
_component:(sp\|proxy\|confederation-root).*$/_
_}_
All incoming RadSec connections can be handled with this stanza. It does not need to be modified. The eduroam trust model requires that a SP that tries to connect has:
* A X.509 certificate from an eduroam-accredited CA (configured above in block *tls default*).
* A URN proving its eligibility (this is achieved with the matchcertificateattribute option).
The traditional RADIUS *shared secret* has no meaning in RadSec and can be statically set without security implications. In current eduroam deployments, it is set to *mysecret*. This may change in the future.
Please note that the client and server stanza for the Service Activity 5 (SA5) monitoring have the same host address, but different stanza names. This is important: it disables the LoopDetection for this host, and the SA5 monitoring deliberate uses loops to do its tests.
_client SA5-monitoring-incoming {_
_                host                          161.53.2.204_
_                type                          UDP_
_                secret                       \__MONITORING_SECRET_\_\_
_}_
This is the eduroam Service Activity's monitoring client. Negotiate a shared secret for monitoring with the operators in SA5 and enter it here.
_server \__DESCRIPTIVE_NAME__ {\_
_                host                         \__IP_ADDR_\_\_
_                type                        UDP_
_                secret                     \__SERVER_SECRET_\_\_
_}_
To deliver requests to your connected IdPs, their servers need to be configured. This stanza is for IdP servers using RADIUS.
_server \__RADSEC_PEER_DNS_NAME__ {\_
_                type                       TLS_
_                secret                    mysecret_
_                statusserver          on_
_               matchcertificateattribute_
\_SubjectAltName:URI:/\^[https://registry.edugain.org/resolver?urn=urn:geant:eduroam:\_|https://registry.edugain.org/resolver\?urn=urn:geant:eduroam:_]
_component:(idp\|proxy\|confederation-root):.*$/i_
_}_
This is the equivalent stanza for IdP servers using RadSec.
_server etlr1.eduroam.org {_
_                type                       TLS_
_                secret                    mysecret_
_                statusserver          on_
\_                matchcertificateattribute _
\_SubjectAltName:URI:/\^[https://registry.edugain.org/resolver??urn=urn:geant:eduroam:component:confederation-root:Europe:ETLR:.*$/i\_|https://registry.edugain.org/resolver\?urn=urn:geant:eduroam:component:confederation-root:Europe:ETLR:.*$/i_]
_}_
_server etlr2.eduroam.org {_
_                 type                      TLS_
_                 secret                   mysecret _
_                 statusserver         on_
\_                 matchcertificateattribute _
\_SubjectAltName:URI:/\^[https://registry.edugain.org/resolver??urn=urn:geant:eduroam:component:confederation-root:Europe:ETLR:.*$/i\_|https://registry.edugain.org/resolver\?urn=urn:geant:eduroam:component:confederation-root:Europe:ETLR:.*$/i_]
_}_
These are the European eduroam Confederation root servers. This entry can be kept as it stands and doesn't need any further configuration.
_server SA5-monitoring-outgoing {_
_                   host                   161.53.2.204_
_                   type                   UDP_
_                   secret                \__MONITORING_SECRET_\_\_
_}_
_server TODO:add SRCE RadSec server here {_
_                  type                    TLS_
_                  secret                 mysecret_
_                  statusserver       on_
\_                 matchcertificateattribute _
_SubjectAltName:URI:/^urn:geant:eduroam:component:confederation-root:Europe:Monitoring:.*/i_
_}_
SA5 monitoring works both ways. The client entry near the beginning of the configuration file was needed for incoming requests from the monitoring servers. The two entries here specify the outgoing connections to the monitoring servers. Outgoing connections can use either RADIUS (first entry) or RadSec (second entry) at your discretion. You can configure both, and select the preferred way later in the special monitoring realm *eduroam.TLD*.
Finally, the IdP realms need to be defined. This is done in the remainder of the configuration file:
_realm /myabc\.com$ {_
_                   replymessage "Misconfigured client: default realm of Intel PRO/Wireless supplicant\! Rejected by <TLD>."_
_}_
\_realm /^\[^@\]*$ { replymessage "Misconfigured client: empty realm\! Rejected by <TLD>."_
_}_
There are some known client-side misconfigurations. If they were not already caught by the SP local RADIUS server, it does not make sense for the proxy to send these requests up to the eduroam infrastructure. These requests are immediately rejected.
*Note:* if you need to blacklist an existing realm for some reason, you can follow the myabc.com example, copying and replacing it with the realm to be blacklisted.
_realm /_{_}IDP_REALM{_}_$ {_
_                               server         \__FROM_SERVER_STANZAS_ABOVE_\_\_
_                               server         \__BACKUP_NAME_\_\_
_}_
Requests that are coming in from upstream and are supposed to be handled by an identity provider are listed in stanzas like this. __IDP_REALM__ contains the realm of the connected IdP. Create one such stanza for each IdP realm. If an IdP has multiple servers for a failover configuration, you can list all servers in a row, as in the example above.
_realm /eduroam\._{_}YOUR_TLD__ {\_
_                               server         SA5-monitoring-outgoing_
_                               server         TODO:SRCE RadSec server_
_}_
The configuration stanza above is for outgoing SA5 monitoring connections. You can select your preference for RADIUS or RadSec for the outgoing connections by changing the order of the server stanzas.
_realm /\._{_}YOUR_TLD{_}_$ {_
_                                replymessage "Misconfigured supplicant or downstream server: uses known\- bad realm in <TLD> federation\!"_
_}_
All the valid realms were listed earlier in the configuration file, and this server is authoritative for the own TLD. If a supplicant or downstream servers sends a realm with the own TLD, but also with a realm name that is not registered, this request is unauthorised and bound to fail. It will be rejected immediately to prevent routing loops.
_realm    \* {_
_                              server           etlr1.eduroam.org_
_                              server           etlr2.eduroam.org_
_}_
Finally, all realms that do not belong to the own federation are forwarded to the European eduroam Confederation root servers.
h3. 3.1.3    Obtaining certificates for RadSec for federation-level servers
To be able to use RadSec in eduroam, you need certificates from a trusted CA with the correct URN values. The procedure below describes how to become a Registration Authority (RA) for the eduGAIN-SCA (eduGAIN Subordinated Certification Authority) with the permission to issue eduroam RadSec certificates. Please note that in the course of RadSec deployment, other CAs may also become accredited to issue such certificates, and that these other CAs have their own operational procedures. When in doubt, ask on the SA5 mailing list whether there is a more specialised CA in your own NREN.
First, you as an NRO operator need to register the three eduroam URN branches on the URN registry at[https://registry.edugain.org/eduroam/]
Click on "Browser" on the top navigation bar and browse to
_urn:geant:eduroam:component:proxy:Europe_
You need to register your own NRO's name directly beneath this URN node. You can do this by clicking on the "+" sign to the right-hand side of that node. If you are going to operate your own sub-registry for your own branch, choose "Request a delegation" in the form which appears. If you do not want to do that, choose "Register a URN" instead (this is recommended for small initial deployments). Fill out the form and send it by clicking "Accept".
If you plan to also issue certificates to IdP and SP servers within your federation, repeat the same registration process also for the URN branches
_urn:geant:eduroam:component:idp:Europe_
_urn:geant:eduroam:component:sp:Europe_
For a more detailed explanation of the URN values, please refer to chapter 3 of deliverable DS5.4.1: Report on RadSec Integration.
After completing all the registry branch registrations, please wait until you get an e-mail notification that the URN branches have indeed been registered. This may take a few days since it is a manual verification process involving both the registry operators and the eduroam Operations Team.
The next step is to add the newly acquired URNs to your Registration Authority. If your NREN already is an RA, a simple e-mail to the eduGAIN-SCA operators to add the new URNs to the existing RA is enough. If your NREN is not an RA yet, you need to fill out the RA application form first. Please get in touch with the SA5 mailing list if you need to do this step.
You can find out whether your NREN is already an accredited RA by visiting [http://sca.edugain.org] and looking for your NREN in the list of accredited RAs.
After your RA is accredited for issuing certificates in the eduroam branch, requesting a new certificate is simple: visit [http://sca.edugain.org], click on your RA and select "Certificate request" in the navigation bar on the left\- hand side. |