<?xml version="1.0"?> <!-- Wireguard key management --> <interfaceDefinition> <node name="generate"> <children> <node name="wireguard"> <properties> <help>Generate Wireguard keys</help> </properties> <children> <tagNode name="client-config"> <properties> <help>Generate Client config QR code</help> <completionHelp> <list><client-name></list> </completionHelp> </properties> <children> <tagNode name="interface"> <properties> <help>Local interface used for connection</help> <completionHelp> <script>${vyos_completion_dir}/list_interfaces.py --type wireguard</script> </completionHelp> </properties> <children> <tagNode name="server"> <properties> <help>IP address/FQDN used for client connection</help> <completionHelp> <script>${vyos_completion_dir}/list_local_ips.sh --both</script> <list><hostname></list> </completionHelp> </properties> <command>sudo ${vyos_op_scripts_dir}/wireguard_client.py --name "$4" --interface "$6" --server "$8"</command> <children> <tagNode name="address"> <properties> <help>IPv4/IPv6 address used by client</help> <completionHelp> <list><x.x.x.x> <h:h:h:h:h:h:h:h></list> </completionHelp> </properties> <command>sudo ${vyos_op_scripts_dir}/wireguard_client.py --name "$4" --interface "$6" --server "$8" --address "${10}"</command> <children> <tagNode name="address"> <properties> <help>IPv4/IPv6 address used by client</help> <completionHelp> <list><x.x.x.x> <h:h:h:h:h:h:h:h></list> </completionHelp> </properties> <command>sudo ${vyos_op_scripts_dir}/wireguard_client.py --name "$4" --interface "$6" --server "$8" --address "${10}" --address "${12}"</command> </tagNode> </children> </tagNode> </children> </tagNode> </children> </tagNode> </children> </tagNode> </children> </node> </children> </node> <node name="show"> <children> <node name="wireguard"> <properties> <help>Show Wireguard properties</help> </properties> <children> <node name="keypairs"> <properties> <help>Show Wireguard keys</help> </properties> <children> <leafNode name="pubkey"> <properties> <help>Show Wireguard public keys</help> </properties> <command>${vyos_op_scripts_dir}/wireguard.py --showpub</command> </leafNode> <leafNode name="privkey"> <properties> <help>Show Wireguard private keys</help> </properties> <command>${vyos_op_scripts_dir}/wireguard.py --showpriv</command> </leafNode> </children> <command>${vyos_op_scripts_dir}/wireguard.py --showpub --showpriv</command> </node> </children> </node> <node name="interfaces"> <children> <tagNode name="wireguard"> <properties> <help>Show Wireguard interface information</help> <completionHelp> <script>${vyos_completion_dir}/list_interfaces.py --type wireguard</script> </completionHelp> </properties> <command>sudo ${vyos_op_scripts_dir}/wireguard.py --showinterface "$4"</command> <children> <leafNode name="allowed-ips"> <properties> <help>Show all IP addresses allowed for the specified interface</help> </properties> <command>sudo wg show "$4" allowed-ips</command> </leafNode> <leafNode name="endpoints"> <properties> <help>Show all endpoints for the specified interface</help> </properties> <command>sudo wg show "$4" endpoints</command> </leafNode> <leafNode name="peers"> <properties> <help>Show all peer IDs for the specified interface</help> </properties> <command>sudo wg show "$4" peers</command> </leafNode> <leafNode name="summary"> <properties> <help>Shows current configuration and device information</help> </properties> <command>sudo wg show "$4"</command> </leafNode> </children> </tagNode> <node name="wireguard"> <properties> <help>Show Wireguard interface information</help> </properties> <command>${vyos_op_scripts_dir}/show_interfaces.py --intf-type=wireguard --action=show-brief</command> <children> <leafNode name="detail"> <properties> <help>Show detailed Wireguard interface information</help> </properties> <command>${vyos_op_scripts_dir}/show_interfaces.py --intf-type=wireguard --action=show</command> </leafNode> </children> </node> </children> </node> </children> </node> <node name="delete"> <children> <node name="wireguard"> <properties> <help>Delete Wireguard properties</help> </properties> <children> <tagNode name="keypair"> <properties> <help>Delete a Wireguard keypair</help> <completionHelp> <script>${vyos_op_scripts_dir}/wireguard.py --listkdir</script> </completionHelp> </properties> <command>sudo ${vyos_op_scripts_dir}/wireguard.py --delkdir --location "$4"</command> </tagNode> </children> </node> </children> </node> </interfaceDefinition>