<?xml version="1.0"?> <!-- wireguard key management --> <interfaceDefinition> <node name="generate"> <children> <node name="wireguard"> <properties> <help>wireguard key generation utility</help> </properties> <children> <leafNode name="default-keypair"> <properties> <help>generates the wireguard default-keypair</help> </properties> <command>sudo ${vyos_op_scripts_dir}/wireguard.py --genkey</command> </leafNode> <leafNode name="preshared-key"> <properties> <help>generate a wireguard preshared key</help> </properties> <command>${vyos_op_scripts_dir}/wireguard.py --genpsk</command> </leafNode> <tagNode name="named-keypairs"> <properties> <help>Generates named wireguard keypairs</help> </properties> <command>sudo ${vyos_op_scripts_dir}/wireguard.py --genkey --location "$4"</command> </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>Shows named wireguard keys</help> </properties> <children> <tagNode name="pubkey"> <properties> <help>Show wireguard private named key</help> <completionHelp> <script>${vyos_op_scripts_dir}/wireguard.py --listkdir</script> </completionHelp> </properties> <command>${vyos_op_scripts_dir}/wireguard.py --showpub --location "$5"</command> </tagNode> <tagNode name="privkey"> <properties> <help>Show wireguard public named key</help> <completionHelp> <script>${vyos_op_scripts_dir}/wireguard.py --listkdir</script> </completionHelp> </properties> <command>${vyos_op_scripts_dir}/wireguard.py --showpriv --location "$5"</command> </tagNode> </children> </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 allowed-ips 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> <!-- more commands upon request --> </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>