Netgate Discussion Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Search
    • Register
    • Login

    NEW Package: freeRADIUS 2.x

    Scheduled Pinned Locked Moved pfSense Packages
    628 Posts 80 Posters 754.1k Views
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • M
      markuhde
      last edited by

      Tried that, didn't do the trick, freeRADIUS 2 still won't start on 2.1 development.

      1 Reply Last reply Reply Quote 0
      • M
        markuhde
        last edited by

        Here's the result of my attempt to start it from SSH in debugging mode. Any help would be great I'd LOVE to get this thing running and I appreciate it a ton!:

        
        [2.1-DEVELOPMENT][admin@glacierfire.glaciercamp]/root(3): radiusd -X
        FreeRADIUS Version 2.1.12, for host i386-portbld-freebsd8.1, built on Jan  3 2012 at 23:44:16
        Copyright (C) 1999-2009 The FreeRADIUS server project and contributors. 
        There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A 
        PARTICULAR PURPOSE. 
        You may redistribute copies of FreeRADIUS under the terms of the 
        GNU General Public License v2\. 
        Starting - reading configuration files ...
        including configuration file /usr/local/etc/raddb/radiusd.conf
        including configuration file /usr/local/etc/raddb/clients.conf
        including files in directory /usr/local/etc/raddb/modules/
        including configuration file /usr/local/etc/raddb/modules/wimax
        including configuration file /usr/local/etc/raddb/modules/always
        including configuration file /usr/local/etc/raddb/modules/attr_filter
        including configuration file /usr/local/etc/raddb/modules/attr_rewrite
        including configuration file /usr/local/etc/raddb/modules/chap
        including configuration file /usr/local/etc/raddb/modules/checkval
        including configuration file /usr/local/etc/raddb/modules/counter
        including configuration file /usr/local/etc/raddb/modules/cui
        including configuration file /usr/local/etc/raddb/modules/detail
        including configuration file /usr/local/etc/raddb/modules/detail.example.com
        including configuration file /usr/local/etc/raddb/modules/detail.log
        including configuration file /usr/local/etc/raddb/modules/digest
        including configuration file /usr/local/etc/raddb/modules/dynamic_clients
        including configuration file /usr/local/etc/raddb/modules/echo
        including configuration file /usr/local/etc/raddb/modules/etc_group
        including configuration file /usr/local/etc/raddb/modules/exec
        including configuration file /usr/local/etc/raddb/modules/expiration
        including configuration file /usr/local/etc/raddb/modules/expr
        including configuration file /usr/local/etc/raddb/modules/files
        including configuration file /usr/local/etc/raddb/modules/inner-eap
        including configuration file /usr/local/etc/raddb/modules/ippool
        including configuration file /usr/local/etc/raddb/modules/krb5
        including configuration file /usr/local/etc/raddb/modules/ldap
        including configuration file /usr/local/etc/raddb/modules/linelog
        including configuration file /usr/local/etc/raddb/modules/logintime
        including configuration file /usr/local/etc/raddb/modules/mac2ip
        including configuration file /usr/local/etc/raddb/modules/mschap
        including configuration file /usr/local/etc/raddb/modules/mac2vlan
        including configuration file /usr/local/etc/raddb/modules/ntlm_auth
        including configuration file /usr/local/etc/raddb/modules/opendirectory
        including configuration file /usr/local/etc/raddb/modules/otp
        including configuration file /usr/local/etc/raddb/modules/pam
        including configuration file /usr/local/etc/raddb/modules/pap
        including configuration file /usr/local/etc/raddb/modules/passwd
        including configuration file /usr/local/etc/raddb/modules/perl
        including configuration file /usr/local/etc/raddb/modules/policy
        including configuration file /usr/local/etc/raddb/modules/preprocess
        including configuration file /usr/local/etc/raddb/modules/radutmp
        including configuration file /usr/local/etc/raddb/modules/realm
        including configuration file /usr/local/etc/raddb/modules/redis
        including configuration file /usr/local/etc/raddb/modules/rediswho
        including configuration file /usr/local/etc/raddb/modules/replicate
        including configuration file /usr/local/etc/raddb/modules/smbpasswd
        including configuration file /usr/local/etc/raddb/modules/smsotp
        including configuration file /usr/local/etc/raddb/modules/soh
        including configuration file /usr/local/etc/raddb/modules/sql_log
        including configuration file /usr/local/etc/raddb/modules/sqlcounter_expire_on_login
        including configuration file /usr/local/etc/raddb/modules/sradutmp
        including configuration file /usr/local/etc/raddb/modules/unix
        including configuration file /usr/local/etc/raddb/modules/acct_unique
        including configuration file /usr/local/etc/raddb/eap.conf
        including configuration file /usr/local/etc/raddb/policy.conf
        including files in directory /usr/local/etc/raddb/sites-enabled/
        including configuration file /usr/local/etc/raddb/sites-enabled/control-socket
        including configuration file /usr/local/etc/raddb/sites-enabled/default
        including configuration file /usr/local/etc/raddb/sites-enabled/inner-tunnel
        main {
        	allow_core_dumps = no
        }
        including dictionary file /usr/local/etc/raddb/dictionary
        main {
        	name = "radiusd"
        	prefix = "/usr/local"
        	localstatedir = "/var"
        	sbindir = "/usr/local/sbin"
        	logdir = "/var/log"
        	run_dir = "/var/run"
        	libdir = "/usr/local/lib/freeradius-2.1.12"
        	radacctdir = "/var/log/radacct"
        	hostname_lookups = no
        	max_request_time = 30
        	cleanup_delay = 5
        	max_requests = 2048
        	pidfile = "/var/run/radiusd.pid"
        	checkrad = "/usr/local/sbin/checkrad"
        	debug_level = 0
        	proxy_requests = yes
         log {
        	stripped_names = no
        	auth = no
        	auth_badpass = no
        	auth_goodpass = no
        	msg_badpass = ""
        	msg_goodpass = ""
         }
         security {
        	max_attributes = 200
        	reject_delay = 1
        	status_server = no
         }
        }
        radiusd: #### Loading Realms and Home Servers ####
        radiusd: #### Loading Clients ####
         client teakettle2 {
        	ipaddr = 192.168.10.2
        	require_message_authenticator = no
        	secret = "mqh6rWnxbTkgQkVn"
        	shortname = "teakettle2"
        	nastype = "other"
         }
         client cafeteria {
        	ipaddr = 192.168.10.3
        	require_message_authenticator = no
        	secret = "8UmEX8Xr6sRz64R4"
        	shortname = "cafeteria"
        	nastype = "other"
         }
         client lodgelobby {
        	ipaddr = 192.168.10.4
        	require_message_authenticator = no
        	secret = "5TEEQULqqTB49bYc"
        	shortname = "lodgelobby"
        	nastype = "other"
         }
         client conferenceroom {
        	ipaddr = 192.168.10.5
        	require_message_authenticator = no
        	secret = "5vQTATZSLBGqKNhx"
        	shortname = "conferenceroom"
        	nastype = "other"
         }
         client sector1 {
        	ipaddr = 192.168.10.6
        	require_message_authenticator = no
        	secret = "LgVKSbJ6eRcwdJzU"
        	shortname = "sector1"
        	nastype = "other"
         }
         client sector2 {
        	ipaddr = 192.168.10.7
        	require_message_authenticator = no
        	secret = "aHfBaTuxytqLKXFG"
        	shortname = "sector2"
        	nastype = "other"
         }
        radiusd: #### Instantiating modules ####
         instantiate {
         Module: Linked to module rlm_exec
         Module: Instantiating module "exec" from file /usr/local/etc/raddb/modules/exec
          exec {
        	wait = no
        	input_pairs = "request"
        	shell_escape = yes
          }
         Module: Linked to module rlm_expr
         Module: Instantiating module "expr" from file /usr/local/etc/raddb/modules/expr
         Module: Linked to module rlm_counter
         Module: Instantiating module "daily" from file /usr/local/etc/raddb/modules/counter
          counter daily {
        	filename = "/usr/local/etc/raddb/db.daily"
        	key = "User-Name"
        	reset = "daily"
        	count-attribute = "Acct-Session-Time"
        	counter-name = "Daily-Session-Time"
        	check-name = "Max-Daily-Session"
        	reply-name = "Session-Timeout"
        	allowed-servicetype = "Framed-User"
        	cache-size = 5000
          }
        rlm_counter: Counter attribute Daily-Session-Time is number 11273
        rlm_counter: Current Time: 1337493979 [2012-05-20 00:06:19], Next reset 1337580000 [2012-05-21 00:00:00]
        ERROR: Cannot find a configuration entry for module "weekly". 
        
        1 Reply Last reply Reply Quote 0
        • M
          markuhde
          last edited by

          **IGNORE ALL OF THIS - it didn't survive a reboot. The package must try to repair itself or something, I'm back to the error above about the module weekly…

          P.P.S. I know I'm mostly talking to myself at this point but the magic final edit was hashtagging out weekly, monthly, and forever in freeradius.inc since it turns out that's where radiusd.conf is loaded from. Now, to figure out if whatever I broke to get FreeRADIUS to start is so severe that it won't work for my needs (which are fairly minimal, authenticate a few users who will stay around all the time, and have the ability to add/remove temporary users as needed).**

          I think I got it running. I dunno what I broke in the process but first thing I tried was adding the "weekly, monthly, and forever" entries from my working 2.0.2-RC1's version of "/usr/local/etc/raddb/modules/counter" since those were missing. That did NO good. Changed nothing. So instead I hashtagged out weekly monthly and forever from radiusd.conf. Then on an error related to MOTP, so I edited the file "default" that contained MOTP references to hashtag that out. Then I halted on more errors about daily (yes, daily too this time), weekly, monthly, and forever so I hashtagged out a all those references in default and it starts!

          I know I broke something in the process. I also know that I have no idea WHAT I BROKE, and I randomly hashtagged things out. The server starts but who knows if it'll work for what I want (WPA2-Enterprise). I'll find out Monday when I'm up there if I can connect to the private network I'm setting up now.

          Anyone got any insight into what I broke? LOL

          1 Reply Last reply Reply Quote 0
          • N
            Nachtfalke
            last edited by

            I did the GUI for that package. What you broke is nothing important for you. So no problem.
            The counter files will be installed on package installation process. If you do not need the counters that will be no problem for you. Uncommenting this in "default" is no problem.

            The same for MOTP. this a is one time password feature - you probably do not need this for your environment. :)

            I posted on the dev mailing list and we will see what is happening for pfsense 2.1 :)
            http://lists.pfsense.org/pipermail/dev/2012-May/000176.html

            PS: If you have the time to do so, you can do the following:
            copy and execute the code on pfsense GUI -> Diagnostics -> Command prompt -> PHP execute
            Just copy the lines below - this will probably create all your missing files.

            
            require_once("freeradius.inc");
            freeradius_dictionary_resync();
            freeradius_modulesmotp_resync();
            freeradius_modulesdatacounter_resync();
            freeradius_datacounter_acct_resync();
            freeradius_datacounter_auth_resync();
            freeradius_modulescounter_resync();
            
            
            1 Reply Last reply Reply Quote 0
            • M
              markuhde
              last edited by

              Thanks, as far as I know it works, but I haven't been up to the campground this is installed at (it's about 30 miles away). I know pfSense works, I haven't got any complaints and I see users connecting. No idea, however, if my WPA2-Enterprise admin network works. I know all my setup and VLAN tagging works (because I had no issues connecting when it was WPA2-PSK).

              Why all the hassle to do WPA2-Enterprise? The admin network is also the network that bypasses the proxy. I want to be able to give group leaders passwords that are removed when their group leaves in case they need to bypass SquidGuard for any reason (it is setup fairly restrictive).

              On my test setup here at home, running pfSense 2.0.2-RC1, it all works great (for my demo network, which is a similar setup).

              Thanks again!

              1 Reply Last reply Reply Quote 0
              • R
                Rampage
                last edited by

                Hello,
                sorry but i'm a bit n00b :)

                i've read through this thread but i couldn't find informations about my issue.

                i've configured freeRADIUS2 to run with MySQL, apparently everything seems fine as in the log i can see that it connects to the db properly without any error.

                My question is, once i'm relying on mysql, i'm left on my own for managing users nas mac etc? in the mean that the pfsense webUI doesn't control them anymore if mySQL is set as abackend?

                I ask this because as i can see, local users (flat file) are still authed properly by freeRADIUS, and if i add new users they are not added to the MySQL database, as it results empty.

                am i missing something or is it working as intended?

                1 Reply Last reply Reply Quote 0
                • N
                  Nachtfalke
                  last edited by

                  Hi,

                  it is working as intended. Adding users on the GUI will only add users in the flat "users" file.
                  If you are using MySQL you will have to add them there in any other way to the database. for example you write a HTML web page or do this with some other tool or script.

                  1 Reply Last reply Reply Quote 0
                  • R
                    Rampage
                    last edited by

                    ok nice, i kinda figured it out, as i'm planning to use some php to add users to the mysql database.

                    the problem is that as of now, by browsing the freeradius wiki, i found it extremely difficult to figure out what goes where in terms of users, limitations etc.

                    for instance i noticed that if i add

                    "testuser", "cleartest-password", ":=", "testpassword" in the radcheck table
                    i can perform a successful login on the captive portal.

                    problem is.. what if i also want to limit the usage to 1 hour per day? or eventually bandwidth? are these values also to be added to radcheck? they go in radreply?

                    an exhaustive list of the usable attributes would be also interesting, ok i know i'm going OT here, so maybe i should ask in the proper section of this board (if any) wiki only reports some of them, and they are not well described/explained on what they are suitable for.

                    1 Reply Last reply Reply Quote 0
                    • N
                      Nachtfalke
                      last edited by

                      Hi again,

                      if you add a user in GUI then this user is placed in the plain "users" file in /usr/local/etc/raddb/users
                      all check and reply attributes you can add from GUI will go int users file. The same is with limitations and restrictions.
                      Most of the features from this package aim to the "users" file.

                      If you are using LDAP or mysql it is up to you to configure this, add users and limitations.
                      This needs to be done vi console/ssh and via config files:
                      You can find them - depending on your database - in this folder:

                      /usr/local/etc/raddb/sql/
                      

                      So there it is up to you to create your "SELECTs" and "QUERY". The very best place too find help - depending on this is probably the freeradius mailing list and their homepage.

                      Limiting bandwidth is a reply attribute - you/freeradius is telling the NAS to limit the bandwidth.
                      a check attribute is for example "simultaneous-use" or "expiration" - the user wnats to login and the NAS needs to check if there are limitations for this user and needs to check this.
                      In the GUI there are many attributes implemented - just add them and take a look at the users file to see if they are check or reply attributes.
                      the check attributes are on the same line as the username.
                      reply attributes are listed below.

                      attributes:
                      There are "unlimited" attributes. It always depends on what you NAS understands. Most NAS do have a dictionary of attributes and freeradius knows and understand these attributes. You can find them here - or you create a new one:

                      /usr/local/share/freeradius/dictionary.*
                      

                      If you have ideas to improve the wiki - please feel free to do so. If you wrote some text - I can add this for you to the wiki. :-)

                      1 Reply Last reply Reply Quote 0
                      • M
                        markuhde
                        last edited by

                        Okay, well, there is now no way apparently to get FreeRadius 2.x installed on the latest builds, so I figured I'd try FreeRADIUS 1.x. I cannot, for the life of me, figure out how to get all the certificates and everything to make WPA2-Enterprise. On FreeRADIUS2, once I finally got it to start, everything "just worked" - am I missing something or is FreeRADIUX 1.x not capable of doing WPA2-Enterprise. Desperately need a solution here to get the staff network up at this campground back up and online in the latest builds.

                        1 Reply Last reply Reply Quote 0
                        • N
                          Nachtfalke
                          last edited by

                          @markuhde:

                          Okay, well, there is now no way apparently to get FreeRadius 2.x installed on the latest builds, so I figured I'd try FreeRADIUS 1.x. I cannot, for the life of me, figure out how to get all the certificates and everything to make WPA2-Enterprise. On FreeRADIUS2, once I finally got it to start, everything "just worked" - am I missing something or is FreeRADIUX 1.x not capable of doing WPA2-Enterprise. Desperately need a solution here to get the staff network up at this campground back up and online in the latest builds.

                          I am not 100% sure how it works in freeradius1 but you have to place your certificates in /usr/local/etc/raddb/certs/ folder. Then you need to edit the "eap.conf" file to point to the correct certificates. Perhaps you have to enable "eap" in radiusd.conf.
                          But you are right - in freeradius1 there is no GUI for that. The certificates need to be in .pem format if I remember correct. So probably best way would be to copy these certificates created on a pfsense 2.0.1 version to pfsense 2.1.

                          I am not sure if freeradius2 package is visible on package manager on pfsese 2.1 but if it is try to install the package - it will install the GUI but breaks because of the missing packages which are not available in .pbi format.
                          The go to console and add the freeradius2 package from freebsd server with:
                          pkg_add -r http://www.bla-bla/freeradius2.tbz

                          Then it "should" work with the basic features.

                          1 Reply Last reply Reply Quote 0
                          • M
                            markuhde
                            last edited by

                            Yeah, I had it working that way before, it worked great, but I updated my snapshot and they removed all the non-PBI packages now. So I have no way to install the GUI since it can't manually be installed. Ugh…

                            1 Reply Last reply Reply Quote 0
                            • N
                              Nachtfalke
                              last edited by

                              This is the install link in the package manager of pfsense 2.0.1
                              Perhaps login on your pfsense and type in this URL. This should work…

                              http://172.17.0.1/pkg_mgr_install.php?id=freeradius2

                              1 Reply Last reply Reply Quote 0
                              • M
                                markuhde
                                last edited by

                                Thanks I'll give that a try tomorrow, I can't honestly see how it would work if the underlying reference to it in the list of available packages is gone, but anything's worth a try :)

                                1 Reply Last reply Reply Quote 0
                                • M
                                  markuhde
                                  last edited by

                                  Working perfectly, I guess the underlying reference to the package isn't gone. Running today's snapshot, where it'll probably stay for quite some time (maybe until release if it proves stable) since everything I need up here is now working well (content filtering, traffic shaping, a VLAN with priority, and WPA2-Enterprise)! Thanks a ton!

                                  1 Reply Last reply Reply Quote 0
                                  • M
                                    markuhde
                                    last edited by

                                    That was quick! I see there's now a PBI for freeRADIUS 2.x… Not gonna give it a shot yet I have everything working on the system and not gonna take it down on a client right now, I'll test next week and make sure the PBI "just works" by doing an update probably next Thursday

                                    1 Reply Last reply Reply Quote 0
                                    • N
                                      Nachtfalke
                                      last edited by

                                      @markuhde:

                                      That was quick! I see there's now a PBI for freeRADIUS 2.x… Not gonna give it a shot yet I have everything working on the system and not gonna take it down on a client right now, I'll test next week and make sure the PBI "just works" by doing an update probably next Thursday

                                      Don't do that!
                                      We are trying to build the correct .PBIs and the correct dependency .PBIs for freeradius. At the moment there are not all .PBIs on the server. Hopefully the .PBI builder is doing its job.
                                      On the Packages or the 2.1 forum there is a thread where peaople post which packages work for pfsense 2.1. You should have a look there and first install / change packages in production if they were tested.

                                      Just remember - pfsense 2.1 is still development and not ready ;-)

                                      1 Reply Last reply Reply Quote 0
                                      • M
                                        markuhde
                                        last edited by

                                        @Nachtfalke:

                                        Just remember - pfsense 2.1 is still development and not ready ;-)

                                        Something I know all too well, but at least I'm getting to test it in the real world. I built a new system for a client, and didn't realize I couldn't use a Realtek 8111e on-board NIC with pfSense 2.0. Thankfully, all is working now knock on wood - if it seems stable, I might not touch it until the final comes out :D

                                        1 Reply Last reply Reply Quote 0
                                        • jimpJ
                                          jimp Rebel Alliance Developer Netgate
                                          last edited by

                                          All of the PBI bits should be there now, and the other bits as well, on files.pfsense.org.

                                          https://github.com/bsdperimeter/pfsense-packages/commit/465839eb99cd094d6d7e5b7d76e82c432165a82b

                                          Give things another test, see how they go.

                                          Remember: Upvote with the 👍 button for any user/post you find to be helpful, informative, or deserving of recognition!

                                          Need help fast? Netgate Global Support!

                                          Do not Chat/PM for help!

                                          1 Reply Last reply Reply Quote 0
                                          • B
                                            blasterreal
                                            last edited by

                                            Installation error

                                            error.PNG
                                            error.PNG_thumb

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post
                                            Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.