From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from firstgate.proxmox.com (firstgate.proxmox.com [212.224.123.68]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits)) (No client certificate requested) by lists.proxmox.com (Postfix) with ESMTPS id 3796A68DD5 for ; Fri, 28 Aug 2020 14:37:05 +0200 (CEST) Received: from firstgate.proxmox.com (localhost [127.0.0.1]) by firstgate.proxmox.com (Proxmox) with ESMTP id 1D69620E91 for ; Fri, 28 Aug 2020 14:37:05 +0200 (CEST) Received: from mailpro.odiso.net (mailpro.odiso.net [89.248.211.110]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by firstgate.proxmox.com (Proxmox) with ESMTPS id D3C9A20E26 for ; Fri, 28 Aug 2020 14:37:00 +0200 (CEST) Received: from localhost (localhost [127.0.0.1]) by mailpro.odiso.net (Postfix) with ESMTP id D846B15F9DFE; Fri, 28 Aug 2020 14:36:54 +0200 (CEST) Received: from mailpro.odiso.net ([127.0.0.1]) by localhost (mailpro.odiso.net [127.0.0.1]) (amavisd-new, port 10032) with ESMTP id oZrPSHRRpuvI; Fri, 28 Aug 2020 14:36:54 +0200 (CEST) Received: from localhost (localhost [127.0.0.1]) by mailpro.odiso.net (Postfix) with ESMTP id BA8F015F9E06; Fri, 28 Aug 2020 14:36:54 +0200 (CEST) X-Virus-Scanned: amavisd-new at mailpro.odiso.com Received: from mailpro.odiso.net ([127.0.0.1]) by localhost (mailpro.odiso.net [127.0.0.1]) (amavisd-new, port 10026) with ESMTP id BeC-9TfdoF0B; Fri, 28 Aug 2020 14:36:54 +0200 (CEST) Received: from pve.fritz.box (unknown [213.211.148.86]) by mailpro.odiso.net (Postfix) with ESMTPSA id 83CA715F9DFE; Fri, 28 Aug 2020 14:36:54 +0200 (CEST) From: Alexandre Derumier To: pve-devel@lists.proxmox.com Date: Fri, 28 Aug 2020 14:36:28 +0200 Message-Id: <20200828123649.11125-1-aderumier@odiso.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-SPAM-LEVEL: Spam detection results: 0 AWL 0.000 Adjusted score from AWL reputation of From: address KAM_DMARC_STATUS 0.01 Test Rule for DKIM or SPF Failure with Strict Alignment RCVD_IN_DNSWL_NONE -0.0001 Sender listed at https://www.dnswl.org/, no trust SPF_HELO_NONE 0.001 SPF: HELO does not publish an SPF Record SPF_PASS -0.001 SPF: sender matches SPF record URIBL_BLOCKED 0.001 ADMINISTRATOR NOTICE: The query to URIBL was blocked. See http://wiki.apache.org/spamassassin/DnsBlocklists#dnsbl-block for more information. [vlanplugin.pm, netboxplugin.pm, vnets.pm, vnetplugin.pm, powerdnsplugin.pm, controllers.pm, phpipamplugin.pm, zones.pm, plugin.pm, simpleplugin.pm, qinqplugin.pm, subnetplugin.pm, pveplugin.pm, vxlanplugin.pm, ipams.pm, generateconfig.pl, evpnplugin.pm, sdn.pm, subnets.pm, dns.pm] Subject: [pve-devel] [PATCH v7 pve-network 00/21] sdn : add subnets management X-BeenThere: pve-devel@lists.proxmox.com X-Mailman-Version: 2.1.29 Precedence: list List-Id: Proxmox VE development discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 28 Aug 2020 12:37:05 -0000 This patch series add basic subnets managements. Subnets will be use for multiple things:=20 - defined gateway ip on vnets - enable snat on a subnet - add cloudnit|dhcp default network configs (gateway, static routes, name= servers,searchdomain,....) - add ipam management. (ip registrations to external ipam, for vm|ct ip m= anagement) - add dns registration. (reverse dns for subnet, and searchdomain regisra= tion in external dns like powerdns ) - ... Already implemented: - gateway option is implemented: It's currently replace ip management on vnets for layer3 plugins, through the option "gateway". If the option gateway is defined, for layer3 plugins (evpn && simple), the ip will be used for the vnet. A vnet can have multiple subnets, with multiples ipv4/ipv6. - ipam - dns registration Changelog v2: - add ipams plugins. Currently netbox && phpipam. - the subnet && the subnet gateway are registered to ipam - add/del/find_next_free ip are implemented, so it should be easy to use = them in qemu && lxc config. Changelog v3: - add an internal ipam plugin Changelog v4: - fix pveipam plugin find_free_ip - detect ipv4/ipv6 in find_free_ip Changelog v5: - add vnets add_ip,del_ip,... should be ok for use in lxc/qemuserver Changelog v6: - add dns plugins - internal ipam fixes - rework vnet-subnet association - fixes && cleanup Changelog v7: - add snat to simple|evpn plugin - cleanup subnet options - fix reversedns Alexandre Derumier (21): add subnet plugin vnets: add subnets add subnets verifications hooks zones: simple|evpn: add gateway ip from subnets to vnet zone: add vnet_update_hook vnets: subnets: use cidr subnet: fix on_delete_hook api2: subnet create: convert cidr to subnetid api2: increase version on apply/reload only add ipams plugins add pve internal ipam plugin vnets: find_free_ip : add ipversion detection vnets: add add_ip vnets: add del_ip + rework add_ip/find_free_ip add dns plugin Fix vnet gateway for routed setup + /32 pointopoint subnet ipam : pveplugin : fix find_next_free_ip add vnet to subnets && remove subnetlist from vnet zones: evpn|simple: add snat iptables rules subnet: disable route option for now and add dns domain format dns: fix reverse dns PVE/API2/Network/SDN.pm | 24 +++ PVE/API2/Network/SDN/Controllers.pm | 6 - PVE/API2/Network/SDN/Dns.pm | 242 +++++++++++++++++++++++ PVE/API2/Network/SDN/Ipams.pm | 242 +++++++++++++++++++++++ PVE/API2/Network/SDN/Makefile | 2 +- PVE/API2/Network/SDN/Subnets.pm | 237 +++++++++++++++++++++++ PVE/API2/Network/SDN/Vnets.pm | 16 +- PVE/API2/Network/SDN/Zones.pm | 6 - PVE/Network/SDN/Dns.pm | 57 ++++++ PVE/Network/SDN/Dns/Makefile | 8 + PVE/Network/SDN/Dns/Plugin.pm | 117 +++++++++++ PVE/Network/SDN/Dns/PowerdnsPlugin.pm | 201 +++++++++++++++++++ PVE/Network/SDN/Ipams.pm | 68 +++++++ PVE/Network/SDN/Ipams/Makefile | 8 + PVE/Network/SDN/Ipams/NetboxPlugin.pm | 169 ++++++++++++++++ PVE/Network/SDN/Ipams/PVEPlugin.pm | 166 ++++++++++++++++ PVE/Network/SDN/Ipams/PhpIpamPlugin.pm | 189 ++++++++++++++++++ PVE/Network/SDN/Ipams/Plugin.pm | 127 ++++++++++++ PVE/Network/SDN/Makefile | 4 +- PVE/Network/SDN/SubnetPlugin.pm | 181 +++++++++++++++++ PVE/Network/SDN/Subnets.pm | 257 +++++++++++++++++++++++++ PVE/Network/SDN/VnetPlugin.pm | 24 +-- PVE/Network/SDN/Vnets.pm | 65 +++++++ PVE/Network/SDN/Zones.pm | 4 +- PVE/Network/SDN/Zones/EvpnPlugin.pm | 54 +++++- PVE/Network/SDN/Zones/Plugin.pm | 7 +- PVE/Network/SDN/Zones/QinQPlugin.pm | 10 +- PVE/Network/SDN/Zones/SimplePlugin.pm | 46 ++++- PVE/Network/SDN/Zones/VlanPlugin.pm | 10 +- PVE/Network/SDN/Zones/VxlanPlugin.pm | 16 +- debian/control | 3 + test/generateconfig.pl | 3 +- 32 files changed, 2494 insertions(+), 75 deletions(-) create mode 100644 PVE/API2/Network/SDN/Dns.pm create mode 100644 PVE/API2/Network/SDN/Ipams.pm create mode 100644 PVE/API2/Network/SDN/Subnets.pm create mode 100644 PVE/Network/SDN/Dns.pm create mode 100644 PVE/Network/SDN/Dns/Makefile create mode 100644 PVE/Network/SDN/Dns/Plugin.pm create mode 100644 PVE/Network/SDN/Dns/PowerdnsPlugin.pm create mode 100644 PVE/Network/SDN/Ipams.pm create mode 100644 PVE/Network/SDN/Ipams/Makefile create mode 100644 PVE/Network/SDN/Ipams/NetboxPlugin.pm create mode 100644 PVE/Network/SDN/Ipams/PVEPlugin.pm create mode 100644 PVE/Network/SDN/Ipams/PhpIpamPlugin.pm create mode 100644 PVE/Network/SDN/Ipams/Plugin.pm create mode 100644 PVE/Network/SDN/SubnetPlugin.pm create mode 100644 PVE/Network/SDN/Subnets.pm --=20 2.20.1