* Migration 0012: firewall_zones (id, name UNIQUE, description, builtin),
Seed wan/lan/dmz/mgmt/cluster als builtin. CHECK-Constraints auf
network_interfaces.role + firewall_rules.{src,dst}_zone +
firewall_nat_rules.{in,out}_zone gedroppt — Validation lebt jetzt
app-side (Handler prüft Existenz in firewall_zones).
* Backend: firewall.ZonesRepo (CRUD + Exists + References-Lookup),
/api/v1/firewall/zones, builtin geschützt (Name nicht änderbar,
Delete blockiert), Rename eines Custom-Zone aktuell ohne Cascade
(Handler-Sorge bei Rules/NAT/Networks).
* Handler-Validation in CreateRule/UpdateRule/CreateNAT/UpdateNAT +
NetworksHandler: Zone-Existence-Check pro Mutation, 400 bei Tippfehler.
* Frontend: Firewall-Tab "Zonen" (CRUD mit builtin-Schutz). Networks-
Form lädt Rollen aus /firewall/zones (statt hardcoded Liste); Rules-
und NAT-Forms ziehen die Zone-Auswahl ebenfalls aus der API.
* Domain-Form bekommt Primary-Backend-Picker (Field war im Modell,
fehlte im UI). Backends-Tabelle zeigt umgekehrt welche Domains
darauf zeigen — bidirektionale Sicht ohne Schemaänderung.
* HAProxy-Renderer: safeID-FuncMap escaped Server-Namen mit Whitespace
("Control Master 1" → "Control_Master_1"). Vorher ist haproxy beim
Reload an Spaces im Backend-Namen kaputt gegangen.
* Version 1.0.3 → 1.0.6.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
33 lines
1.3 KiB
TypeScript
33 lines
1.3 KiB
TypeScript
import { Tabs, Typography } from 'antd'
|
|
import { useTranslation } from 'react-i18next'
|
|
|
|
import AddressObjectsTab from './AddressObjects'
|
|
import AddressGroupsTab from './AddressGroups'
|
|
import ServicesTab from './Services'
|
|
import ServiceGroupsTab from './ServiceGroups'
|
|
import RulesTab from './Rules'
|
|
import NATRulesTab from './NATRules'
|
|
import ZonesTab from './Zones'
|
|
|
|
export default function FirewallPage() {
|
|
const { t } = useTranslation()
|
|
|
|
const tabs = [
|
|
{ key: 'rules', label: t('fw.tabs.rules'), children: <RulesTab /> },
|
|
{ key: 'nat', label: t('fw.tabs.nat'), children: <NATRulesTab /> },
|
|
{ key: 'zones', label: t('fw.tabs.zones'), children: <ZonesTab /> },
|
|
{ key: 'addrObj', label: t('fw.tabs.addrObj'), children: <AddressObjectsTab /> },
|
|
{ key: 'addrGrp', label: t('fw.tabs.addrGrp'), children: <AddressGroupsTab /> },
|
|
{ key: 'services', label: t('fw.tabs.services'), children: <ServicesTab /> },
|
|
{ key: 'svcGrp', label: t('fw.tabs.svcGrp'), children: <ServiceGroupsTab /> },
|
|
]
|
|
|
|
return (
|
|
<div>
|
|
<Typography.Title level={3}>{t('fw.title')}</Typography.Title>
|
|
<Typography.Paragraph type="secondary">{t('fw.intro')}</Typography.Paragraph>
|
|
<Tabs items={tabs} defaultActiveKey="rules" />
|
|
</div>
|
|
)
|
|
}
|