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

    Email Notification - OpenVPN Client Connect (Common Name)

    Scheduled Pinned Locked Moved OpenVPN
    138 Posts 20 Posters 39.2k 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.
    • GertjanG
      Gertjan @aasimenator
      last edited by

      @aasimenator

      PHP getenv()

      I created a small test file /root/test.php :

      #!/usr/local/bin/php -q
      <?php
      print_r(getenv(), $output);
      echo $output;
      ?>
      

      Now (made it executable) :
      ./test.php

      works for me.

      Array
      (
          [SSH_CLIENT] => 192.168.1.2 59841 22
          [LOGNAME] => root
          [MAIL] => /var/mail/root
          [PATH] => /sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin:/usr/local/bin:/root/bin
          [PWD] => /root
          [TERM] => xterm
          [SSH_TTY] => /dev/pts/0
          [USER] => root
          [HOME] => /root
          [SSH_CONNECTION] => 192.168.1.2 59841 192.168.1.1 22
          [SHELL] => /bin/sh
          [BLOCKSIZE] => K
          [HOSTTYPE] => FreeBSD
          [VENDOR] => amd
          [OSTYPE] => FreeBSD
          [MACHTYPE] => x86_64
          [SHLVL] => 1
          [GROUP] => wheel
          [HOST] => pfsense.munetwork.net
          [REMOTEHOST] => 192.168.1.2
          [CLICOLOR] => true
          [LSCOLORS] => exfxcxdxbxegedabagacad
      )
      

      This was just a test - my script file

      Add $output to the $local_connect_value string, and have it mailed to you.
      Or log it :

      #!/usr/local/bin/php -q
      <?php
      	require_once("/etc/inc/notices.inc");
      	$local_connect_value = " user_name: " . getenv('common_name') . " vpn_client_ip: " . getenv('ifconfig_pool_remote_ip') . " on " . date('F j, Y, g:i a');
      	print_r(getenv(), $output);
      	log_error($output);
      	log_error("About to send a mail : Connecting");
      	notify_all_remote($local_connect_value);
      ?>
      

      No "help me" PM's please. Use the forum, the community will thank you.
      Edit : and where are the logs ??

      A 1 Reply Last reply Reply Quote 0
      • A
        aasimenator @Gertjan
        last edited by aasimenator

        @gertjan
        after changing the connect.sh file to your updated example i am not getting any new information in the email.
        e7cfb0bf-01c2-46d0-b331-e8c9f19897eb-image.png

        And this is what i see in the status of the VPN connection
        0ddfcd78-eb88-43ef-904b-d8c61ac1e4e3-image.png

        GertjanG 1 Reply Last reply Reply Quote 0
        • GertjanG
          Gertjan @aasimenator
          last edited by

          @aasimenator said in Email Notification - OpenVPN Client Connect (Common Name):

          i am not getting any new information in the email.

          Because the variable $output was send to the local log, the most important screens in pfSense are the logs.
          At the same place you will also have this line : Status > System Logs > System > General

          About to send a mail : Connecting
          

          That's what

          log_error("About to send a mail : Connecting");
          

          is all about.
          It logs an 'error' which is actually just an incontinent text message.to the logs.

          Same thing for the variables your looking for : check the logs.

          The output string $output can be added to $local_connect_value string, why not.

          No "help me" PM's please. Use the forum, the community will thank you.
          Edit : and where are the logs ??

          A 1 Reply Last reply Reply Quote 0
          • A
            aasimenator @Gertjan
            last edited by

            @gertjan 1f7f56cc-75e1-422a-8381-24b308ac9963-image.png
            No information in the logs near the Connecting message

            GertjanG 1 Reply Last reply Reply Quote 0
            • GertjanG
              Gertjan @aasimenator
              last edited by Gertjan

              @aasimenator

              There it is :

              46baf718-5061-45b7-8cb3-a46ab61d85b4-image.png

              Never the less : nothing.
              Unbelievable but I had to Google it up.

              Change

              	print_r(getenv(), $output);
              

              to

                      $output = print_r(getenv(), true);
              

              I've tested it.
              It shows a lot of info.
              One of them is the :

              08b356fe-95fe-46ac-bfc2-803b5204bdc8-image.png

              No "help me" PM's please. Use the forum, the community will thank you.
              Edit : and where are the logs ??

              A 1 Reply Last reply Reply Quote 0
              • A
                aasimenator @Gertjan
                last edited by

                @gertjan Thank you so much for that. It seems to have worked and I could get all the information needed to get the data out in an email.

                The only difference when using LDAP / Radius server in the getenv was changing ('common_name') to ('username')

                In hindsight, I think maybe having the following option enabled in the OpenVPN config might have done the trick.
                35dc686c-6483-4f73-879f-a23000a8884d-image.png

                I do have a follow-up question, is there any way we can format the email better? e.g. newlines instead of everything in 1 line, I already tried \n or \r\n and even /n but none of them seem to work.

                GertjanG 1 Reply Last reply Reply Quote 0
                • GertjanG
                  Gertjan @aasimenator
                  last edited by Gertjan

                  @aasimenator said in Email Notification - OpenVPN Client Connect (Common Name):

                  is there any way we can format the email better?

                  The small script file, see above, used by OpenVPN on a 'connect' event is written using PHP.
                  You can also use bash / sh / python / lua / or any high level copiled C or whatever ......

                  Use any language you like.

                  No "help me" PM's please. Use the forum, the community will thank you.
                  Edit : and where are the logs ??

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

                    Anyone's scripts just stop working?

                    I noticed sometime after August these scripts stopped working on my pfsense box. Not sure what is going on.

                    GertjanG 1 Reply Last reply Reply Quote 0
                    • GertjanG
                      Gertjan @boggie1688
                      last edited by

                      @boggie1688
                      There is a boatload of info present - above, to debug.
                      Can you say more as :

                      @boggie1688 said in Email Notification - OpenVPN Client Connect (Common Name):

                      scripts stopped

                      No "help me" PM's please. Use the forum, the community will thank you.
                      Edit : and where are the logs ??

                      B 1 Reply Last reply Reply Quote 0
                      • B
                        boggie1688 @Gertjan
                        last edited by

                        @gertjan said in Email Notification - OpenVPN Client Connect (Common Name):

                        @boggie1688
                        There is a boatload of info present - above, to debug.
                        Can you say more as :

                        @boggie1688 said in Email Notification - OpenVPN Client Connect (Common Name):

                        scripts stopped

                        Not sure where to start.

                        I've been using the same script for year or two and suddenly I stopped getting emails when I connect or disconnect. I haven't changed the scripts so I'm not entirely sure what would cause the lack of emails.

                        Given I changed nothing, I wondering if anyone experienced the same.

                        GertjanG 1 Reply Last reply Reply Quote 0
                        • GertjanG
                          Gertjan @boggie1688
                          last edited by Gertjan

                          @boggie1688

                          I haven't used what's being described here for a long time, as I'm the only one using my VPN access, and I already know when I am connected when I'm connected ;)

                          But :

                          I've added the third, "client-connect" line to the VPN server custom config :

                          cdbd16c7-63c8-4d1a-87c4-d73c50d4e80f-image.png

                          I've created a file called /root/vpn.sh :

                          #!/usr/local/bin/php -q
                          <?php
                          	require_once("/etc/inc/notices.inc");
                          	$local_connect_value = " user_name: " . getenv('common_name') . " vpn_client_ip: " . getenv('ifconfig_pool_remote_ip') . " from: " . getenv('trusted_ip') . " on " . date('F j, Y, g:i a');
                          	if ( strrchr (__FILE__ , 'disconnect') ) {
                          	$local_connect_value .= ", duration : " . getenv('time_duration') . " seconds, received : " . getenv('bytes_received') . " bytes, send : " . getenv('bytes_sent') ." bytes. DISCONNECTED.";
                          	}
                          	notify_all_remote($local_connect_value);
                          ?>
                          

                          and made it executable :

                          chmod +x /root/vpn.sh
                          

                          Now, when I connect, I see in the system log :

                          4c0f7cf6-8b38-4a31-8601-b866df523a1c-image.png

                          and I received the mail ....

                          As you said, nothing changed ;)

                          That is ..... there is something 'bad' going on.
                          I've changed the VPN server settings, so I had a look at the VPN server (re) startup log.
                          ( never change settings without looking at the logs afterswards - and if you don't
                          And there was a warning :

                          aa0d07e7-ae4b-4768-aa26-e36f49b7da2a-image.png

                          This means that my client-connect overrides another client-connect !! So pfSense is also using the "client-connect" VPN server config command.
                          Let's check the OpenVPN server config file : /var/etc/openvpn/config.ovpn :

                          ...
                          client-connect /usr/local/sbin/openvpn.attributes.sh
                          client-disconnect /usr/local/sbin/openvpn.attributes.sh
                          ...
                          client-connect /root/vpn.sh
                          

                          that's bad indeed.
                          I've removed my custom config line

                          client-connect /root/vpn.sh
                          

                          as something tells me its better that :

                          client-connect /usr/local/sbin/openvpn.attributes.sh
                          

                          is used as pfSense 'needs' it to work, to do what it has to do.

                          So, for now, forget about using "client-connect" in the custom config to have it call your own script (to send a mail or whatever).
                          It will 'break' other functionality.

                          When I look at /usr/local/sbin/openvpn.attributes.sh, I can see stuff is done with certs, and subsequent files like /usr/local/sbin/openvpn.connect_async.sh does session stuff, and also logs :

                          5e40ded8-d301-41cf-91cf-8d7ed631f6ff-image.png

                          Sending a mail would mean we have to "patch" this (these) files.

                          No "help me" PM's please. Use the forum, the community will thank you.
                          Edit : and where are the logs ??

                          B 1 Reply Last reply Reply Quote 2
                          • B
                            boggie1688 @Gertjan
                            last edited by

                            @gertjan

                            Thanks for the detailed reply.

                            I very much appreciate it.

                            I've never checked the system logs, so I learned something new today.

                            1 Reply Last reply Reply Quote 0
                            • JeGrJ
                              JeGr LAYER 8 Moderator
                              last edited by

                              @gertjan said in Email Notification - OpenVPN Client Connect (Common Name):

                              /usr/local/sbin/openvpn.attributes.sh

                              You are right with this @Gertjan

                              The script actually triggers another one depending on either being called at connect or disconnect:
                              /usr/bin/nohup /usr/local/sbin/openvpn.connect_async.sh

                              And that one is no small script! I digged through it for a bit and found it handles things like logging in syslog (e.g. calls logger to log the conn/disconn into openvpns logs) but it also does a bit of householding tasks.
                              At disconnect it kills the states of the VPN client was previously using so another caller getting that IP wouldn't have states already attached (multiple pfctl -k / -K calls).
                              But even more serious, it also seems to handle the connection limit setting or duplicate connections. So in overriding the script with a custom logging, you perhaps disable various features that you configured in the VPN server beforehand.

                              So all in all I wouldn't recommend replacing the client-(dis)connect scripts with own versions.

                              What would perhaps be possible is writing a quick patch for the caller-script /usr/local/sbin/openvpn.attributes.sh where the async script is called and insert another script (e.g. like @Gertjan /root/vpn.sh) into there. But that would have to be checked for, as the script calls various function via the OpenVPN "deferred" connection method and handles the deferring in the async script.

                              So I guess one could think about that one:

                              # Signal deferred handler
                              if [ "${script_type}" = "client-connect" ]; then
                                      /bin/echo 2 > "${client_connect_deferred_file}"
                                      if [ -f /tmp/"${common_name}" ]; then
                                              /bin/cat /tmp/"${common_name}" > "${client_connect_config_file}"
                                              /bin/rm /tmp/"${common_name}"
                                      fi
                              fi
                              
                              ###
                              --> insert HERE <--
                              ###
                              
                              # Handle 'client-connect' and 'client-disconnect'
                              /usr/bin/nohup /usr/local/sbin/openvpn.connect_async.sh > /dev/null &
                              
                              # Signal "deferred handler started OK" for client-connect
                              exit 0
                              

                              and to insert a small block with a check wether it's called by connect or disconnect state. But that would have to be tested first.

                              Cheers
                              \jens

                              Don't forget to upvote 👍 those who kindly offered their time and brainpower to help you!

                              If you're interested, I'm available to discuss details of German-speaking paid support (for companies) if needed.

                              bingo600B 1 Reply Last reply Reply Quote 1
                              • bingo600B
                                bingo600 @JeGr
                                last edited by bingo600

                                We ought to get Netgate to insert some "Official hooks" for User initiated connect/disconnect
                                ie.

                                if [ -x "/root/OpenVPN-User-Clientconnect.sh" ]; then
                                
                                if [ -x "/root/OpenVPN-User-Clientdisconnect.sh" ]; then
                                

                                I'm using these scripts too , and haven't noticed the consequence , until Gertjan pointed it out 👍

                                /Bingo

                                If you find my answer useful - Please give the post a 👍 - "thumbs up"

                                pfSense+ 23.05.1 (ZFS)

                                QOTOM-Q355G4 Quad Lan.
                                CPU  : Core i5 5250U, Ram : 8GB Kingston DDR3LV 1600
                                LAN  : 4 x Intel 211, Disk  : 240G SAMSUNG MZ7L3240HCHQ SSD

                                GertjanG B 2 Replies Last reply Reply Quote 0
                                • GertjanG
                                  Gertjan @bingo600
                                  last edited by Gertjan

                                  @bingo600 said in Email Notification - OpenVPN Client Connect (Common Name):

                                  We ought to get Netgate to insert some "Official hooks" for User initiated connect/disconnect

                                  I saw Jimp answering a comparable question a couple of days ago : implementing a hook for a user created script file : he doesn't "like it", as such a script could run with root rights, thus control the entire system.
                                  The situation right now isn't that bad : the admin that knows what he is doing :

                                  1. Can patch a pfSense script file with a test "if /root/myopenvpnscript.sh" file exist, and "if it is executable" and if both are ok, call it. (you could build a diff patch for this to make live easier)
                                  2. Write their own /root/myopenvpnscript.sh

                                  The user that can do both things will also know how to update, maintain, and re implement this functionality after a pfSense update.
                                  Permitting lamda users to write their own script files ..... => scary.

                                  Look here, last message, what happens when people use home made script / config files , and people forget about it .... https://forum.netgate.com/topic/175234/recent-pppoe-issues-not-auto-reconnecting-for-some-reason-used-to/9?_=1666084459780

                                  edit : just to be clear : I'm not against the idea, of course.

                                  No "help me" PM's please. Use the forum, the community will thank you.
                                  Edit : and where are the logs ??

                                  JeGrJ 1 Reply Last reply Reply Quote 0
                                  • JeGrJ
                                    JeGr LAYER 8 Moderator @Gertjan
                                    last edited by

                                    @gertjan said in Email Notification - OpenVPN Client Connect (Common Name):

                                    Can patch a pfSense script file with a test "if /root/myopenvpnscript.sh" file exist, and "if it is executable" and if both are ok, call it. (you could build a diff patch for this to make live easier)

                                    System Patches can do that just fine, indeed :)

                                    @gertjan said in Email Notification - OpenVPN Client Connect (Common Name):

                                    Write their own /root/myopenvpnscript.sh

                                    Filer package can take care of that, so that it survives a re-install or (perhaps even) an upgrade.

                                    But I feel Jimp here, that it would introduce an attack vector that Netgate can't control. I wouldn't be opposed to patching that ourselves as it's my own responsibility if something goes awry not shipped by Netgate so no one can blame them.

                                    Cheers
                                    \jens

                                    Don't forget to upvote 👍 those who kindly offered their time and brainpower to help you!

                                    If you're interested, I'm available to discuss details of German-speaking paid support (for companies) if needed.

                                    1 Reply Last reply Reply Quote 0
                                    • B
                                      boggie1688 @bingo600
                                      last edited by

                                      I use freeradius to auth the users for OpenVPN. Is it possible to have freeradius alert me when a user is correctly authorized?

                                      Eating breakfast and just wondering. I'll try to research this later.

                                      GertjanG 1 Reply Last reply Reply Quote 0
                                      • GertjanG
                                        Gertjan @boggie1688
                                        last edited by

                                        @boggie1688

                                        That's what this thread is all about.

                                        No "help me" PM's please. Use the forum, the community will thank you.
                                        Edit : and where are the logs ??

                                        1 Reply Last reply Reply Quote 1
                                        • M
                                          makq
                                          last edited by

                                          Hi all,
                                          I do not know much about pfsense command line.
                                          Wondering if someone can help me step by step ?
                                          Do I need command line access to the router or I can use the web access to the router ?
                                          Can I use the command prompt section ?
                                          So I have to create 2 executable files name notify.sh and disconnect.sh ? How I am going to create these files ?
                                          I think I got the part to set the permissions. How can I set the permissions ? by using Execute Shell Command section on the web ?
                                          What will be in those two files ?
                                          So same code in both files ?

                                          @Armstrong said in Email Notification - OpenVPN Client Connect (Common Name):

                                          #!/usr/local/bin/php -q
                                          <?php
                                          require_once("/etc/inc/notices.inc");
                                          $local_connect_value = " user_name: " . getenv('common_name') . " vpn_client_ip: " . getenv('ifconfig_pool_remote_ip') . " from: " . getenv('trusted_ip') . " on " . date('F j, Y, g:i a');
                                          if ( strrchr (FILE , 'disconnect') ) {
                                          $local_connect_value .= ", duration : " . getenv('time_duration') . " seconds, received : " . getenv('bytes_received') . " bytes, send : " . getenv('bytes_sent') ." bytes. DISCONNECTED.";
                                          }
                                          notify_all_remote($local_connect_value);
                                          ?>

                                          Am I coping from <?php or from #!/user ?
                                          If it is from <?php then what I have to do with first line #!/usr/local/bin/php -q

                                          Is it possible some one can help me step by step and also tell me which part of the webconfigurator I need to use to do all this please ?

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