Subcategories

  • Discussions about packages which handle caching and proxy functions such as squid, lightsquid, squidGuard, etc.

    4k Topics
    21k Posts
    J
    @qupfer What did I bang my head over this strange 502 issue. Your solution did it! Thank you so much, even 2.5 years later!
  • Discussions about packages whose functions are Intrusion Detection and Intrusion Prevention such as snort, suricata, etc.

    2k Topics
    16k Posts
    M
    Hi, I had a problem with my home network today, so I checked pfsense and discovered that suricata had blocked the wan ip. After some tests and triggering some suricata alerts, the wan ip was blocked. I restarted pfsense and ran some more tests, but the problem no longer occurred. I then checked the wan interface settings and indeed the ip list does not include the wan ip, both now that it's working and before, when it was blocked. I'm using pfsense 2.8.0 and suricata 7.0.8_2. I use PPPoE to access the Internet.
  • Discussions about packages that handle bandwidth and network traffic monitoring functions such as bandwidtd, ntopng, etc.

    571 Topics
    3k Posts
    dennypageD
    @Leon-Straathof Data retention settings are handled inside of ntopng. Documentation here. Pay attention to the RRD note. Also, if you've turned on some of the slice and dice time series information (is off by default), I'd suggest turning them back off. These balloon the storage requirements and are of little actual use.
  • Discussions about the pfBlockerNG package

    3k Topics
    20k Posts
    fireodoF
    @tinfoilmatt said in Failed or invalid Mime Type: [application/SIMH-tape-data|0]: (ASN data is IPinfo, not Maxmind) Thats correct but "GeoLite2-Country" is from Maxmind ... (that confused me) I'm considering simply adding "application/SIMH-tape-data" to the list to test. Thats what i tought too ... I'll try when I have the time for it ... Edit: I can confirm - adding "application/SIMH-tape-data" to the list at line 257 in /usr/local/pkg/pfblockerng/pfblockerng.inc did the trick - no more error! Edit: OK, problem resolved but I would like to know, whats the cause for that error! (SIMH-tape-data sounds like a "blast from the past" ...) Thanks a lot!
  • Discussions about Network UPS Tools and APCUPSD packages for pfSense

    101 Topics
    2k Posts
    dennypageD
    @jhg said in NUT fails to start after 2.7.2 -> 2.8.0 upgrade: Interesting. I would have thought the initial reboot, which occurred as part of the upgrade, would have done the trick, but it took a second reboot, just now, to get things working. Glad you have it sorted. There was no difference in the output of usbconfig show_ifdrv at any point -- before or after unplugging/replugging the USB cable, nor after rebooting. ... Question: What would tell me whether or not a driver was loaded? If there were an attached driver, it should have shown up with the show_ifdrv command. If you use the command and look at the other usb devices, I think they will show attached drivers. I don't expect to see a driver attached to the ups, because there is a quirk that tells the OS to ignore that device (and not attach a driver). Look for idVendor and idProduct in the above output. The Vendor ID for your device is 0764, which corresponds to Cyber Power Systems, and the Product ID for your device is 0601, which is registered as "PR1500LCDRT2U UPS" (don't sweat an exact match for the name). You can see the quirk with the following command: [25.07-RC][root@fw]/root: usbconfig dump_device_quirks | grep 0764 VID=0x0764 PID=0x0005 REVLO=0x0000 REVHI=0xffff QUIRK=UQ_HID_IGNORE VID=0x0764 PID=0x0501 REVLO=0x0000 REVHI=0xffff QUIRK=UQ_HID_IGNORE VID=0x0764 PID=0x0601 REVLO=0x0000 REVHI=0xffff QUIRK=UQ_HID_IGNORE [25.07-RC][root@fw]/root: Your device is third on the list. The HID_IGNORE quirk says to ignore the device and not attach a driver. @jhg said in NUT fails to start after 2.7.2 -> 2.8.0 upgrade: You might consider adding this resolution to the release notes for 2.8. LOL... sorry, I don't have input to the release notes (I don't work here). While I wrote and maintain various packages, including NUT, I'm still just a volunteer. Most packages are actually written by volunteers.
  • Discussions about the ACME / Let’s Encrypt package for pfSense

    496 Topics
    3k Posts
    GertjanG
    @jimp Done. I was on acme.sh 1.0 (25.07.1) and a downgrade was proposed. Now, the issue is gone.
  • Discussions about the FRR Dynamic Routing package on pfSense

    294 Topics
    1k Posts
    yon 0Y
    said in Please update frr on Pfsense+ to FRR 10.3: https://redmine.pfsense.org/issues/15785 now frr 10.4.1
  • Discussions about the Tailscale package

    90 Topics
    602 Posts
    S
    Hi guys, Just $0.01, because I faced same issue on pfSense+ 24.07.1 upgrade, but I think root cause may NOT be pfSense+ per se. To my understanding (which may be wrong): Tailscale uses 2 keys: node auth key - by default expires after 180 days. We do not see it, but you can disable its expiration and we normally do that, right? So node registration should not expire after 180 days and re-authentication should not be necessary. preauth key - it is valid for maximum 90 days and you input it to VPN / Tailscale / Authentication as Pre-authentication Key (eg. tskey-auth-123456789011CNTRL-2pz1kCcaSjJucckK7U5Xbz123456a890). Remember that this key is valid for no longer than 90 days. So usually when you upgrade pfSense+ (=> Tailscale upgrade) this key is well expired. Device can not (re)authenticate using it - it is expired: - not logged in, last login error=invalid key: API key does not exist (because key that pfSense+ tried to use is expired!) Tailscale says that device may sometimes require re-authentication. Here is info from Tailscale KB: Auth keys Auth keys are available for all plans. Pre-authentication keys (called auth keys) let you register new nodes without needing to sign in using a web browser. This is most useful when spinning up containers, IoT devices, or using infrastructure-as-code systems like Terraform. An auth key authenticates a device as the user who generated the key. That is, if Alice generates an auth key, and uses it to add a server to her tailnet, then that device is authenticated with Alice's identity. Think of it as logging into a device. However, if you use tags with an auth key, after a device logs in as the user who generated the auth key, the device assumes the identity of the auth key's tags. As an alternative to directly creating auth keys, consider using an OAuth client. You can use an OAuth client and the Tailscale API to programmatically create auth keys. Types of auth keys Auth keys can either be: One-off, for one-time use. They can only be used to connect a device or server one time. This is meant for situations where you can't authenticate on the device yourself, so using a key is more practical. For example, a cloud server might use a one-off key to connect. Reusable, for multiple uses. They can be used to connect multiple devices. For example, multiple instances of an on-premises database might use a reusable key to connect. Be very careful with reusable keys! These can be very dangerous if stolen. They're best kept in a key vault product specially designed for the purpose. Key expiry An auth key automatically expires after the number of days you specified when you generated the key. You can choose the number of days, between 1 and 90 inclusive, for the key expiry. If you don't specify an expiry time, the auth key will expire after the maximum of 90 days. If you want to continue using an auth key after it expires, you need to generate a new key. You can enable or disable key expiry on a device by using the Machines page of the admin console and by using the Update device key method in the Tailscale API. If an auth key expires, any device authorized by it remains authorized until its node key expires. Each device generates a node key when you log in to Tailscale and uses it to identify itself to the tailnet. By default, node keys automatically expire every 180 days. You can change the default node key expiry from the Key Expiry section of the Device management page of the admin console. Learn more about key management. You can use tags as "service accounts" and have some devices NOT bound to any specific user (removal of user removes devices he own). You can define 1 or multiple tag owners (users managing tag). Tag vs. user authentication Tags are parallel to user authentication. They serve the same role as a user account, except they're intended for service-based devices, such as a web server or an app connector. As a result, it's impossible for a user account identity and a tag identity to exist on the same device. Applying a tag to a device previously authenticated with a user account removes the user account. Similarly, authenticating a device with a user account removes all tags from the device. Because tags are intended for non-user devices, they have qualities and limitations that make them unsuitable for authenticating end-user devices, such as a MacBook or a mobile device. For example, devices with a tag-based identity cannot use SSH to connect to a device with a user-based identity. Key expiry When you apply a tag to a device for the first time and authenticate it, the tagged device's key expiry is disabled by default. If you re-authenticate a device tagged before March 10, 2022, its expiry will be disabled by default. If you change the tags on the device from the admin console, Tailscale CLI, or the Tailscale API, the device's key expiry will not change unless you re-authenticate. After you re-authenticate, the device's key expiry will be disabled. You can enable or disable key expiry on a device from the Machines page of the admin console or by using the Tailscale API. Key expiry for tagged devices Key expiry for tagged devices is disabled by default. If you change the tags on the device through the admin console, Tailscale CLI, or Tailscale API, the device's key expiry will not change unless you re-authenticate. That is, if it is enabled, it stays enabled; and if it is disabled, it stays disabled. After you re-authenticate, the device's key expiry will be disabled. You can find recently revoked or expired keys on the Keys page of the admin console. Best practices Depending on what devices you're authenticating, consider using an auth key that is: Ephemeral, for authenticating ephemeral nodes as part of short-lived workloads. Because node keys do not persist when a workload restarts, they reconnect as a different node. Tailscale automatically removes inactive nodes. For example, containers or Lambda functions should use an ephemeral key to connect. Pre-approved, for servers. If your tailnet has device approval enabled, this lets you add a device to your tailnet without further authorization. For example, shared devices, such as servers, should use a pre-approved auth key to connect in a network with device approval. Pre-signed, for nodes whose auth keys are signed locally on a signing node, which applies to tailnets with Tailnet Lock enabled. You can make an auth key (created by any means) pre-signed only by using the tailscale lock sign CLI command. Tagged, for servers. You can automatically apply a tag to a device by including the tag in the auth key. Access control policies restricting the device's permissions based on the tag apply after provisioning the device. For example, shared devices, such as servers, should use a tagged auth key to connect. I am personally going to try Tagged (preauth) key and all my pfSense+ exit nodes (3) are already tagged as "router". So I will remove nodes from tailnet and re-add with Tagged key providing "router" tag. I read that Tailscale on software upgrade MAY (rarely) REQUIRE device reauthentication. Having in mind that normal preauth keys expire after 90 days you should provide valid (non-expired) preauth key before pfSense+ upgrade? Eventually maybe if routers are tagged and preauth key is tagged then there will be no problem? Currently pfSense+ does not ask us about expiration date of Preauth Key, so it can not remind us that key is expired and it may lead to problems. When valid key is needed (reauthentication) then device will fail with the message we see. I would not blame pfSense+ yet, because I think Tailscale may require device reauthorisation sometimes and message you got tells you are trying to use expired key for authentication thus process is failing. I agree reauthentications should be rare or non-needed, but we may not know everything here.
  • Discussions about WireGuard

    696 Topics
    4k Posts
    Q
    Hi Team, I’m running pfSense Plus 25.07.1 with TorGuard WireGuard VPN as my primary tunnel for LAN traffic (for best possible speeds). The tunnel is mostly working now, but I had to go through several fixes and I’m still not confident the configuration is stable. Here’s what I’ve run into: TorGuard support originally helped set up the WireGuard client. It worked fine for about a day, but then the Unbound DNS Resolver stopped working. Even when I re-enabled Unbound manually, LAN clients still couldn’t reach the internet. The main issue seemed to be when switching between WAN (ISP public IP) and the VPN IP. Sometimes traffic didn’t switch over properly, and at one point pfSense even generated a crash report during the switch and restarted. To fix it, I reset the LAN firewall rule so that LAN traffic would route through the VPN gateway when active, and fall back to WAN when the VPN was down. After that, I was able to toggle the VPN on/off without pfSense crashing, and traffic correctly switched between ISP IP and VPN IP. At this point it works, but I don’t think the setup is completely stable. I’d like to ask for guidance on: How to make sure Unbound stays reliable when the VPN gateway goes up/down. Best practices for LAN firewall rules so clients use the VPN when it’s up, and either fall back to WAN or get blocked (kill switch) when the VPN is down. Correctly assigning DNS servers to WAN and VPN gateways. At the moment, in System → General Setup, I don’t see the gateway dropdown next to DNS entries, so my DNS servers are just “floating” with no interface binding. If anyone has suggestions, or can point me to a clean reference configuration for WireGuard + Unbound + proper DNS gateway assignment, I’d greatly appreciate it. I'd really like to have a conference with someone and go over this. I'd like to give them access using RustDesk or TeamViewer so we can talk and they can show me things. I am legally blind so I am one inch from the screen. I've also uploaded the crashdump so you can look over it. I've also been using AI, but I keep going in circles with it, so it's not perfect. Thanks in advance! Warm Regards, Jamestextdump.tar.0
  • Snort + barnyard2: full packet capture missing

    10
    0 Votes
    10 Posts
    1k Views
    bmeeksB
    @MichaelB: Upgraded to the latest Snort version. Now it seems like the full_syslog_full is working, but ONLY if you send it to a remote syslog server. So you can't send full events to a local syslog. I just modified my grok rules to be able to catch syslog events forwarded from the local system to a remote syslog (via status => system logs), but that format is different when you send them directly from snort to a remote syslog. I think it should work, I'll modify the grok rules later today. However, to improve consistency with other logs forwarded via the system, perhaps it is a good idea to also allow "local full syslog complete" . In other words, now I have: output log_syslog_full: sensor_name snort.WAN, server 192.168.2.2, protocol udp, port 514, operation_mode complete, payload_encoding hex, log_facility LOG_USER, log_priority LOG_INFO Which gives a different format on my remote syslog server then when using the following in combination with remote logging via the status => system logs setting: output log_syslog_full: sensor_name snort.WAN, operation_mode complete, payload_encoding hex, log_facility LOG_USER, log_priority LOG_INFO Kr, Michael I did in fact code it so that full packet capture only works to a remote syslog server.  It is not a good idea to fill up your local firewall system log with full packet captures, so I elected to not make that available. Bill
  • Snort OpenAppID RULES Detectors

    7
    0 Votes
    7 Posts
    2k Views
    K
    Hi bmeeks I have checked my settings and I do not have the RamDisk setting on. As I am new to pfSense can you list the steps to check? So far I have uninstalled Snort and them installed again keeping my original settings. There may be something that I have checked that is interfering with the download. Not sure what it is through.
  • Just want pfSense to shutdown when UPS goes to battery

    2
    0 Votes
    2 Posts
    1k Views
    dennypageD
    Using NUT on pfSense you have a couple of options: Directly monitor the UPS via SNMP The NUT client can talk to a remove apcupsd server. Given a choice, I would choose option 1 as this works regardless of whether the Windows system is functioning or not. I can't speak to apcupsd on pfSense.
  • Http-buffer-request

    5
    0 Votes
    5 Posts
    681 Views
    johnpozJ
    " a field for HTTP options to be injected into the header. " No as it states its where you put in options to passthru to the frontend.. This common theme on all packages and or services in pfsense.  There are gui settings for the obvious stuff… but more advanced features can be put into a custom box that are added to the conf file, etc. Look fired up a frontend - put your option in the box, check out the cfg file..  See attached pic you can also put that option in global or default section, etc. [image: frontendoptions.png] [image: frontendoptions.png_thumb]
  • Is Snort ignoring host names in pass lists?

    9
    0 Votes
    9 Posts
    5k Views
    L
    Hi BBcan177, Questions:- (1) Will it work on Suricata? (2) I have the passlist in place. Will the script wipe the passlist? If so, I want the passlist + the script run together. Is it possible?? (3) if multiple hostnames, how can I do it? If you use the pfctl -t xxxx -T delete, it just delete the IP from the block list. eventually, the ip will be blocked again. It is the other way around. How can I update the passlist ip using script? @BBcan177: I didn't test it, but try this in an sh script Create new script vi myip **#!/bin/sh MyIp="$(host -4 my.hostname.com | grep -oEw -e "[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}/[0-9]{1,2}" -e "[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}")" pfctl -t snort2c -T delete $MyIp** (Save and exit) :wq (make script executable) chmod +x myip
  • Snort configuration on 1Gbps/1Gbps uplink?

    7
    0 Votes
    7 Posts
    1k Views
    bmeeksB
    @msrachelchen: I ended up using Suricata instead. Though with cpu pinning, the load is still pretty intense atm Looking pretty juicy, 19.82 MB/s. Though most of the “CPU usage” went to NIC queues State Table: 47% (3987752/8500000) Load average: 9.39, 9.96, 9.60 CPU usage: 68% Nothing is running except Unbound, pfblockerng (DNSBL), IPSec and Suricata. I haven’t started HAProxy and TC yet… Suricata is multi-threaded whereas the current Snort release is still single-threaded.  That can help a little under high loading.  The new 3.x BETA versions of Snort are multi-threaded.  Once the 3.x tree goes to RELEASE, it will get pulled into pfSense. Bill
  • FreeRadius3 With WindowsAD 2008 as User Backend.

    2
    0 Votes
    2 Posts
    489 Views
    vallumV
    Any one using this feature?
  • Bandwidthd - Display Hostnames in Main Table

    2
    0 Votes
    2 Posts
    666 Views
    J
    Unfortunately, bandwidthd is no longer maintained, its last update was more than 10 years ago. I have made the modification myself to the bandwidthd source code and display the hostname next to the IP address, in addition, I also updated the maximum IP listed in the HTML from 20 to 50. 20 IPs were probably a lot back in 2005, but these days 50s are probably the norm. If you are comfortable with compiling c code, I can attach my changes here.
  • DHCP Web List

    1
    0 Votes
    1 Posts
    331 Views
    No one has replied
  • Feature request - Cron package - add a Name and/or Notes field

    1
    0 Votes
    1 Posts
    288 Views
    No one has replied
  • Having trouble installing php72-7.2.1.txz package

    2
    0 Votes
    2 Posts
    495 Views
    GertjanG
    Hi, Your lucky. The answer is simple. You can't do that. pfSense is using itself PHP for the GUI. There are probably many lines in the scripts of the GUI that wouldn't be compatible with PHP 7.2. Btw : this is like asking how to install core Windows 10 files on a Windows 8 PC. Experts can't (and won't ask the question).
  • Deny Video Streaming

    1
    0 Votes
    1 Posts
    441 Views
    No one has replied
  • Postfix Backup MX

    13
    0 Votes
    13 Posts
    3k Views
    jimpJ
    The only downside of not having a backup MX is having to wait hours (4+) for retries to come through, or longer if it's a prolonged outage. It's not the end of the world, though, messages will be resent. If you botch the backup MX config then it could be worse. You could accidentally reject mail and never receive it, or let even more spam through on a continuing basis. The best backup MX is an exact duplicate of your primary mail server hosted off-site.
  • Can snort block torrent streaming?

    2
    0 Votes
    2 Posts
    499 Views
    bmeeksB
    I don't know the answer definitively, but you can install it and try it out.  I would set it up in IDS (non-blocking) mode first and let it run a week or two in order to get a feel for the kinds of alerts generated.  Expect to see quite a bit of alerting related to the HTTP_INSPECT preprocessor.  You can search the IDS/IPS sub-forum here in Packages to find threads about configuring Snort. Bill
  • LAN is not passing through Squidgard

    2
    0 Votes
    2 Posts
    535 Views
    vallumV
    @Dezireman25: Hi All! Just want to ask for your help. I install 2.4.2 pfsense and add squid, squidguard and lightsquid packages. I followed some instructions in youtube (https://www.youtube.com/watch?v=W2gy1bLHm5o) and do some research but LAN did not pass through my squidguard. Squid and squidguard services are running. When i check using proxy test my internet users are not going through squidguard. please help TIA 1st :- You need to allow your LAN Subnet in squid:- Squid  Proxy Server  > ACLs >  Allowed Subnets (put your LAN subnet here) 2nd :- in squidguard by default everything is blocked , you need to allow some list:- SquidGuard Proxy Server > Common ACL  > target Rules List >Target Categories > (default is deny at bottom , allow specific list as required)
  • HAProxy, websockets, "timeout tunnel" and the defaults section

    3
    0 Votes
    3 Posts
    6k Views
    B
    Found your post whilst trying to fix a similar problem. I managed to get things to work with your hint. I simply added the "timeout tunnel 3600s" under the relevant backend -> advanced settings -> backend pass thru
  • Python 3?

    5
    0 Votes
    5 Posts
    2k Views
    U
    Hi, The linked post doesn't mention anything regarding Python 3. It's just about installing mitmproxy in a Python 2.7 virtualenv. Could you maybe give a brief explanation how you got python 3 on pfsense in the first place? Thanks.
  • Debugging Email Reports

    1
    0 Votes
    1 Posts
    535 Views
    No one has replied
  • Traffic Totals - All VLANS collects Parent Interface data? (Solved)

    5
    0 Votes
    5 Posts
    813 Views
    Raul RamosR
    I do the question before because i do not want to reset the data and could be other problem. Disabling and resetting and/or disable graphing and maybe not needed to delete and reinstall the package seams solve the problem. Maybe a broken déjà vu but i thin i have tried this before, months ago. Anyway thanks for the feedback and solutions, i should know this. I will wait couple of hours and put a solved on the topic if this stay good.
  • Bind 9.11 error in pfsense 2.33

    8
    0 Votes
    8 Posts
    3k Views
    johnpozJ
    Don't cross post, and dig up threads from year ago.. What part in your zone file do you think is correct about this? @ IN NS 192.168.1.1. So you think its ok to put in an IP for your NS record?
Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.