17961 Commits

Author SHA1 Message Date
Ad Schellevis
03f96eb008 Interfaces: Virtual IPs / xmlrpc - skip nosync processing on vips, for https://github.com/opnsense/core/issues/8387 2025-03-02 17:05:33 +01:00
Gavin Chappell
1498728e47
feat: switch CLI MOTD to the new-style logo (#8382)
* feat: switch CLI MOTD to the new-style logo

* update bootloader logo

* better quality MOTD
2025-03-01 09:53:06 +01:00
Franco Fichtner
0b1b0cb932 src: sync 2025-02-28 15:27:13 +01:00
Ad Schellevis
a253e05da5 mvc: decode html tags in menu items to prevent ampersand (&) being rendered as & 2025-02-28 14:07:17 +01:00
Ad Schellevis
a893cdc7a5
VPN: IPsec: Mobile Clients - move charon attributes to "Advanced settings" for https://github.com/opnsense/core/issues/8349 (#8380)
Rename previous "advanced settings" to "mobile & advanced settings" to guide people into the right direction, strongswan.conf contains both sets of data.
Keep legacy page for settings that are only relevant for the old components.

Since our pam authenticator hooks into the configuration, refactor to use the model as well.

Cleanup code in the model that was only used in the legacy glue.
2025-02-28 13:53:25 +01:00
Monviech
387c381300
mvc/view: Ensure fields stay aligned relatively to another when headers are used in forms (#8364)
* mvc/view: Ensure fields stay aligned relatively to another when headers are used in forms.

* mvc/view: Add style that forces consistency in smaller viewport sizes in base forms.

* mvc/view: Make classes more selective so the style does not leak when modal-dialog and form-inline exist in the same view (e.g. dnsmasq).

* mvc/view: Ensure the change in base_dialog is backwards compatible when msgzone_width is defined (e.g. in Intrusion Detection)
2025-02-28 13:45:51 +01:00
Ad Schellevis
81ec98007d Firewall: Aliases - performance improvement by using pf's overal table stats instead of dumping them.
This commit changes PF.list_tables() to yield both the name of the aliases as well as (limited) stats, in places where we only check for totals, these are faster to collect than counting them in python.

There should be no functional impact.
2025-02-27 17:46:10 +01:00
Ad Schellevis
8524771f52 dnsmasq: Backend migration and add dhcp support for https://github.com/opnsense/core/issues/8329
When dnsmasq is not used for dns services, no default dns is being send to the client for dhcp.
Add a non specific option, which can be overwritten using tags.
2025-02-27 13:08:03 +01:00
Ad Schellevis
98e7a16dce mvc: templates - implement <type>ignore</type> in forms.
In some cases it's practical to document the field so grids may use them, but skip them on input processing as the information is not that relevant to ask (or show using an info type)
2025-02-27 12:35:11 +01:00
Ad Schellevis
c91903fccd theme/fontawesome - include "all" instead of "solid" and "brands" 2025-02-27 11:11:17 +01:00
Franco Fichtner
a722c36552 plugins: style 2025-02-27 10:11:32 +01:00
Monviech
f64be4a3ca dhcrelay: Add missing status column, regression from a556e10d06 2025-02-27 09:29:46 +01:00
Franco Fichtner
3a68aac583 plugins: treat empty string like null on argument map
The backend will turn optional parameters into empty string
arguments which should mean all was selected and not one that
has a blank name.
2025-02-27 09:28:08 +01:00
Ad Schellevis
3e299b29b9 dnsmasq/unbound - mark 'template reload' action as cleanup.
Ideally these spots should not be needed as the frontend generates the configuration and on boot these are flushed as well, ... but, when interfaces change during boot or triggered by the wizard, these parts are not aware of these facts.

as discussed with @fichtner
2025-02-26 16:56:38 +01:00
Franco Fichtner
b50a9eec0f src: style sweep 2025-02-26 15:00:01 +01:00
Ad Schellevis
128536b778 mvc: move "lazy loading" option to base model implementation and force usage on run_migrations.php.
In rare cases it is possible to lock the system during boot while drivers are loaded and tunables try to fetch all information from sysctl.
Since we already implemented a lazy loading pattern on the Alias model, it seems to make sense to push this up the chain and reuse it.

For consistency reasons, we should also push the "lazy" attribute when constructing new ModelRelationField types.
2025-02-26 14:33:53 +01:00
Monviech
dd999d732c
vpn/openvpn: Implement base_bootgrid_table and base_apply_button (#8332)
* vpn/openvpn: Implement base_bootgrid_table and base_apply_button for https://github.com/opnsense/core/issues/8318

* vpn/openvpn: overflow-y in column dropdown due to amount of items in grid
2025-02-25 15:15:56 +01:00
Franco Fichtner
b94578935f dnsmasq: migrate to rc.d scripting 2025-02-25 00:11:04 +01:00
Ad Schellevis
d1b4277047 filter: add missing "persist" on bogonsv6, closes https://github.com/opnsense/core/issues/8376 2025-02-24 18:20:45 +01:00
Ad Schellevis
1a18ff50d7 Mvc/Security - safeguard checkToken() to prevent fetching an non existing POST item (which produces a warning in development mode). 2025-02-24 18:10:44 +01:00
Monviech
3caf9e182d
dnsmasq: Correct typo in label (#8362) 2025-02-20 11:51:26 +01:00
Monviech
169019649c
dns/unbound: Integrate layout_partials/base_apply_button (#8315) 2025-02-20 10:52:54 +01:00
Monviech
a0e3e0a28f
dnsmasq: implement base_apply_button (#8359) 2025-02-20 10:49:30 +01:00
Franco Fichtner
1581bcd87c dnsmasq: repair the dns_ports validation 2025-02-20 10:34:27 +01:00
Franco Fichtner
ef39fdde85 dnsmasq: more style 2025-02-20 10:34:12 +01:00
Franco Fichtner
333cd9c25e unbound: style reorder 2025-02-20 10:20:28 +01:00
Franco Fichtner
a3b78775d8 dnsmasq: uppercase 'Leases' menu, whitespace 2025-02-20 09:33:48 +01:00
Ad Schellevis
5ea401df84 Services: Dnsmasq DNS & DHCP - extend model with a dns_port property which reflects the current listening port (for dns) 2025-02-20 08:54:51 +01:00
Franco Fichtner
17b5859872 dnsmasq: add port hint 2025-02-20 07:49:18 +01:00
Franco Fichtner
655c74255a firewall: reformat, no change in file so dail back to previous year state 2025-02-20 07:47:20 +01:00
Ad Schellevis
48ec3b9850 ipsec/openvpn: add deprecation notices for legacy components, closes https://github.com/opnsense/core/issues/8350
Add a note on top of the legacy pages about the end of maintenance, depending on version, this will be version 26.1 ot 26.4 [BE].
In the meantime components will move to plugins. When maintenance ends, it will still be possible to install the component, but may break unexpectedly.
2025-02-19 20:04:57 +01:00
Ad Schellevis
bcf8f9ae75
dnsmasq: Backend migration and add dhcp support for https://github.com/opnsense/core/issues/8329 (#8355)
This rather large commit implements most relevant dhcp options and rewrites dnsmasq's backend.

By default dnsmasq is disabled, eventually we do want dnsmasq enabled for dhcp services by default, but dns itself disabled. For this reason we support port "0" as implemented at dnsmasq (not listening for dns).

For cases where users want to integrate dns and dhcp services, the advise is to make dnsmasq listen on a non standard port and point unbound to the zones where dnsmasq is responsible for. This has the advantage of a direct connection between dhcp registered hosts and the requesting service. In these cases dnsmasq's dns service acts like a "connector".

In the long run we should deprecate `regdhcpstatic` and `regdhcp` as these either belong to legacy isc-dhcp or hook kea entries (which are better served via unbound).

The first mvc migration phase implemented IndexController.php, which we rename to SettingsController.php now as these results in more logical ui endpoints.

Since we don't bind to addresses directly (unless specifically configured and adviced only for static setups), we can skip the newwanip event which means we don't restart the service on interface changes. dnsmasq is able to filter the relevant networks on the fly, which is the advised scenario and can cope more easily with changes.

When different clients need to receive different options, we can use "tags" now. Requests can add tags to filter options which will be offered to the client, in the most simple scenario one would tag on a range or a host reservation, but more advanced choices can also be achieved using match statements (for example architecture [client-arch])
2025-02-19 17:40:55 +01:00
Franco Fichtner
c3994d14c6 mvc: style sweep 2025-02-19 17:12:46 +01:00
Ad Schellevis
fdded458e0 Firewall: Aliases - offer better pluggability for dynamic alias types and move current json static_aliases and interface networks into their own classes.
When services offer aliases which are less static, the current json option isn't very practical as we only want the package manager to ship files into these directories.
The new DynamicAliases namespace may contain simple php classes, which return a named set of aliases to merge into the set.

Since all of these classes are created on each alias query, it's highly advisable to keep their implementations as lightweight as possible.
2025-02-19 16:14:03 +01:00
Monviech
2cc36105da
vpn/wireguard: Change tracking of wg peer status, improve widget and diagnostics (#8337)
* vpn/wireguard: Introduce latest-handshake-age to calculate if tunnel is online in backend. Implement it in wireguard.js widget and diagnostics.volt

* vpn/wireguard: expose peer-connected via API to approximate state of wireguard peers online/offline status, change status formatter to show statos of interfaces and peers, improve diagnostic grid

* vpn/wireguard: Move epoch calculation from frontend to controller

* vpn/wireguard: Track 3 different status instead of a boolean offline/online. Online means a handshake happened recently, Stale means a handshake happened in the past above a threshold of 300s, Offline means there was never a handshake yet. The same icons are implemented in the widget and the wireguard diagnostics page.

* vpn/wireguard: Remote peer disconnected translation since this is tracked by the icon now. Add stale translation.

* vpn/wireguard: Compact widget information for better readability
2025-02-19 08:58:54 +01:00
Franco Fichtner
82b36deee3 interfaces: exclude automatic radvd like we do for manual #8295 2025-02-19 07:27:40 +01:00
Ad Schellevis
d85cde207a System: Access: Users - implement export/import functionality to the grid, closes https://github.com/opnsense/core/issues/8340
This commit changes the default update handling slightly as we need setBaseHook() to do it's work on imports as well so we can't trust $POST to be populated.
As a result, we need to query the node (which has already been set in either our import or addBase, setBase), which only causes some challenges when reading the password.
Passwords are being flushed plaintext to the model, but not returned, so we need to validate isFieldChanged() and check if actual content was offered.

To trigger setBaseHook() from the import hook, we extended the importRecordSet() with another callback called when the node has been populated with data, in which case it's the same as a regular ui update.

Added a config lock early in the importCsv() method to prevent race conditions on updates.
2025-02-18 17:38:59 +01:00
Monviech
dc4cd4535d
vpn/wireguard: Integrate base_bootgrid_table and base_apply_button (#8313)
* vpn/wireguard: Integrate layout_partials/base_bootgrid_table and layout_partials/base_apply_button

* vpn/wireguard: Change spot of base_form, add formatter for Instance so that wg0,wg1 etc is displayed again in the grid as before the change

* Fix whitespace
2025-02-18 15:48:08 +01:00
Franco Fichtner
d7adee30a1 dnsmasq: call normalizeValue() during interface migration 2025-02-18 14:51:34 +01:00
Franco Fichtner
caf8d65b28 system: straighten out syslog-ng rc.d scripting
Make sure that 'pluginctl -s xxx stop' isn't used here as it
does not stop a disabled instance.  The point is moot for
syslog-ng since you cannot disable it but that only leaves
a tiny amount of daemons that still use it in core (nothing
in plugins uses it).

Also consolidate away from service(8) since we expect and
call the rc.d script directly.
2025-02-18 13:50:08 +01:00
Franco Fichtner
2842e1bee7 interfaces: style sweep 2025-02-18 13:49:54 +01:00
Franco Fichtner
4a2f273c45 mvc: use fa-fw for consistency
fixed-width ensures the buttons will have the same width across all icons
since they do not enforce their width as mono-space.
2025-02-18 10:18:56 +01:00
Franco Fichtner
d4d9b3f2e5 interfaces: reorder the reconfigure logic for compactness and robustness
This was steered by the need to let 'other' mode VIPs not cause any
regression with the other logic so now we only have one clear spot and
reload condition and ignore unknown modes gracefully.
2025-02-18 08:26:50 +01:00
Ad Schellevis
8e0461c9d6 theme/opnsense-dark - change backdrop background color to black, closes https://github.com/opnsense/core/issues/8339 2025-02-17 18:25:06 +01:00
Franco Fichtner
98ec4a91bc mvc: probably this for previous 2025-02-17 18:06:59 +01:00
Stephan de Wit
bab1d3b176 wireguard: diagnostics: typo 2025-02-17 16:59:14 +01:00
Stephan de Wit
146f8573ea system: high availability: move 'disable preempt' to advanced mode 2025-02-17 16:55:43 +01:00
Ad Schellevis
ccb3c92f52 mvc:ApiMutableModelControllerBase - wrap locks around updates and perform some minor cleanups.
delBase() already added a lock, but in practice, when automation is in play, there's a risk for other updates as well, which means we need to synchronize them to avoid data being lost.
2025-02-17 15:19:26 +01:00
Monviech
c689c7e25b
interface: Integrate base_bootgrid_table and base_apply_button (#8257)
* interface: gif.volt - Integrate layout_partials/base_bootgrid_table

* interface: gre.volt - Integrate layout_partials/base_bootgrid_table

* interface: lagg.volt - Integrate layout_partials/base_bootgrid_table

* interface: loopback.volt - Integrate layout_partials/base_bootgrid_table

* interface: neighbor.volt - Integrate layout_partials/base_bootgrid_table

* interface: vip.volt - Integrate layout_partials/base_bootgrid_table

* interface: vlan.volt - Integrate layout_partials/base_bootgrid_table

* interface: vxlan.volt - Integrate layout_partials/base_bootgrid_table

* interface: Change location of Configuration Change Message above Apply

* interface: Fix search base so all grid columns are populated with data

* interface: Integrate layout_partials/base_apply_button https://github.com/opnsense/core/issues/8284

* interface: Missed a spot

* interface: Do not render VHID group password in grid

* interface: vip.volt adjust view more to look like the previous grid

* interface: vip.volt add network formatter, remove vhid formatter since these fields are now displayed by default as separate rows

* interface: loopback.volt add loFormatter to turn device ID into loX in the grid

* interface: vxlan.volt add vxlanFormatter to turn device ID into vxlanX in the grid
2025-02-17 15:14:03 +01:00
Franco Fichtner
83d1565133 reporting: remove $unused for 25.7 2025-02-17 15:02:29 +01:00