<?xml version="1.0"?>
<interfaceDefinition>
  <node name="show">
    <children>
      <node name="log">
        <properties>
          <help>Show contents of current master log file</help>
        </properties>
        <command>journalctl --no-hostname --boot</command>
        <children>
          <leafNode name="all">
            <properties>
              <help>Show contents of all master log files</help>
            </properties>
            <command>sudo bash -c 'eval $(lesspipe); less $_vyatta_less_options --prompt=".logm, file %i of %m., page %dt of %D" -- `printf "%s\n" /var/log/messages* | sort -nr`'</command>
          </leafNode>
          <leafNode name="authorization">
            <properties>
              <help>Show listing of authorization attempts</help>
            </properties>
            <command>journalctl --no-hostname --boot --quiet SYSLOG_FACILITY=10 SYSLOG_FACILITY=4</command>
          </leafNode>
          <leafNode name="cluster">
            <properties>
              <help>Show log for Cluster</help>
            </properties>
            <command>cat $(printf "%s\n" /var/log/messages* | sort -nr) | grep -e heartbeat -e cl_status -e mach_down -e ha_log</command>
          </leafNode>
          <leafNode name="conntrack-sync">
            <properties>
              <help>Show log for Conntrack-sync</help>
            </properties>
            <command>journalctl --no-hostname --boot --unit conntrackd.service</command>
          </leafNode>
          <node name="dhcp">
            <properties>
              <help>Show log for Dynamic Host Control Protocol (DHCP)</help>
            </properties>
            <children>
              <node name="server">
                <properties>
                  <help>Show log for DHCP server</help>
                </properties>
                <command>journalctl --no-hostname --boot --unit isc-dhcp-server.service</command>
              </node>
              <node name="client">
                <properties>
                  <help>Show DHCP client logs</help>
                </properties>
                <command>journalctl --no-hostname --boot --unit "dhclient@*.service"</command>
                <children>
                  <tagNode name="interface">
                    <properties>
                      <help>Show DHCP client log on specific interface</help>
                      <completionHelp>
                        <script>${vyos_completion_dir}/list_interfaces.py --broadcast</script>
                      </completionHelp>
                    </properties>
                    <command>journalctl --no-hostname --boot --unit "dhclient@$6.service"</command>
                  </tagNode>
                </children>
              </node>
            </children>
          </node>
          <node name="dhcpv6">
            <properties>
              <help>Show log for Dynamic Host Control Protocol IPv6 (DHCPv6)</help>
            </properties>
            <children>
              <node name="server">
                <properties>
                  <help>Show log for DHCPv6 server</help>
                </properties>
                <command>journalctl --no-hostname --boot --unit isc-dhcp-server6.service</command>
              </node>
              <node name="client">
                <properties>
                  <help>Show DHCPv6 client logs</help>
                </properties>
                <command>journalctl --no-hostname --boot --unit "dhcp6c@*.service"</command>
                <children>
                  <tagNode name="interface">
                    <properties>
                      <help>Show DHCPv6 client log on specific interface</help>
                      <completionHelp>
                        <script>${vyos_completion_dir}/list_interfaces.py</script>
                      </completionHelp>
                    </properties>
                    <command>journalctl --no-hostname --boot --unit "dhcp6c@$6.service"</command>
                  </tagNode>
                </children>
              </node>
            </children>
          </node>
          <node name="firewall">
            <properties>
              <help>Show log for Firewall</help>
            </properties>
            <children>
              <tagNode name="ipv6-name">
                <properties>
                  <help>Show log for a specified firewall (IPv6)</help>
                  <completionHelp>
                    <path>firewall ipv6-name</path>
                  </completionHelp>
                </properties>
                <command>cat $(printf "%s\n" /var/log/messages* | sort -nr ) | egrep "\[$5-([0-9]+|default)-[ADR]\]"</command>
                <children>
                  <tagNode name="rule">
                    <properties>
                      <help>Show log for a rule in the specified firewall</help>
                      <completionHelp>
                        <path>firewall ipv6-name ${COMP_WORDS[4]} rule</path>
                      </completionHelp>
                    </properties>
                    <command>cat $(printf "%s\n" /var/log/messages* | sort -nr) | grep -e "\[$5-$7-[ADR]\]"</command>
                  </tagNode>
                </children>
              </tagNode>
              <tagNode name="name">
                <properties>
                  <help>Show log for a specified firewall (IPv4)</help>
                  <completionHelp>
                    <path>firewall name</path>
                  </completionHelp>
                </properties>
                <command>cat $(printf "%s\n" /var/log/messages* | sort -nr ) | egrep "\[$5-([0-9]+|default)-[ADR]\]"</command>
                <children>
                  <tagNode name="rule">
                    <properties>
                      <help>Show log for a rule in the specified firewall</help>
                      <completionHelp>
                        <path>firewall name ${COMP_WORDS[4]} rule</path>
                      </completionHelp>
                    </properties>
                    <command>cat $(printf "%s\n" /var/log/messages* | sort -nr) | egrep "\[$5-$7-[ADR]\]"</command>
                  </tagNode>
                </children>
              </tagNode>
            </children>
          </node>
          <leafNode name="https">
            <properties>
              <help>Show log for HTTPs</help>
            </properties>
            <command>journalctl --no-hostname --boot --unit nginx.service</command>
          </leafNode>
          <tagNode name="image">
            <properties>
              <help>Show contents of master log file for image</help>
              <completionHelp>
                <script>compgen -f /lib/live/mount/persistence/boot/ | grep -v grub | sed -e s@/lib/live/mount/persistence/boot/@@</script>
              </completionHelp>
            </properties>
            <command>less $_vyatta_less_options --prompt=".log, page %dt of %D" -- /lib/live/mount/persistence/boot/$4/rw/var/log/messages</command>
            <children>
              <leafNode name="all">
                <properties>
                  <help>Show contents of all master log files for image</help>
                </properties>
                <command>eval $(lesspipe); less $_vyatta_less_options --prompt=".log?m, file %i of %m., page %dt of %D" -- `printf "%s\n" /lib/live/mount/persistence/boot/$4/rw/var/log/messages* | sort -nr`</command>
              </leafNode>
              <leafNode name="authorization">
                <properties>
                  <help>Show listing of authorization attempts for image</help>
                </properties>
                <command>less $_vyatta_less_options --prompt=".log, page %dt of %D" -- /lib/live/mount/persistence/boot/$4/rw/var/log/auth.log</command>
              </leafNode>
              <tagNode name="tail">
                <properties>
                  <help>Show last changes to messages</help>
                  <completionHelp>
                    <list>&lt;NUMBER&gt;</list>
                  </completionHelp>
                </properties>
                <command>tail -n "$6" /lib/live/mount/persistence/boot/$4/rw/var/log/messages | ${VYATTA_PAGER:-cat}</command>
              </tagNode>
            </children>
          </tagNode>
          <leafNode name="ipoe-server">
            <properties>
              <help>Show log for IPoE server</help>
            </properties>
            <command>journalctl --no-hostname --boot --unit accel-ppp@ipoe.service</command>
          </leafNode>
          <leafNode name="kernel">
            <properties>
              <help>Show messages in kernel ring buffer</help>
            </properties>
            <command>sudo dmesg</command>
          </leafNode>
          <leafNode name="lldp">
            <properties>
              <help>Show log for LLDP</help>
            </properties>
            <command>journalctl --no-hostname --boot --unit lldpd.service</command>
          </leafNode>
          <leafNode name="nat">
            <properties>
              <help>Show log for Network Address Translation (NAT)</help>
            </properties>
            <command>egrep -i "kernel:.*\[NAT-[A-Z]{3,}-[0-9]+(-MASQ)?\]" $(find /var/log -maxdepth 1 -type f -name messages\* | sort -t. -k2nr)</command>
          </leafNode>
          <node name="openvpn">
            <properties>
              <help>Show log for OpenVPN</help>
            </properties>
            <command>journalctl --no-hostname --boot --unit openvpn@*.service</command>
            <children>
              <tagNode name="interface">
                <properties>
                  <help>Show OpenVPN log on specific interface</help>
                  <completionHelp>
                    <path>interfaces openvpn</path>
                  </completionHelp>
                </properties>
                <command>journalctl --no-hostname --boot --unit openvpn@$5.service</command>
              </tagNode>
            </children>
          </node>
          <node name="pppoe">
            <properties>
              <help>Show log for PPPoE interface</help>
            </properties>
            <command>journalctl --no-hostname --boot --unit "ppp@pppoe*.service"</command>
            <children>
              <tagNode name="interface">
                <properties>
                  <help>Show PPPoE log on specific interface</help>
                  <completionHelp>
                    <path>interfaces pppoe</path>
                  </completionHelp>
                </properties>
                <command>journalctl --no-hostname --boot --unit "ppp@$5.service"</command>
              </tagNode>
            </children>
          </node>
          <leafNode name="pppoe-server">
            <properties>
              <help>Show log for PPPoE server</help>
            </properties>
            <command>journalctl --no-hostname --boot --unit accel-ppp@pppoe.service</command>
          </leafNode>
          <leafNode name="snmp">
            <properties>
              <help>Show log for Simple Network Monitoring Protocol (SNMP)</help>
            </properties>
            <command>journalctl --no-hostname --boot --unit snmpd.service</command>
          </leafNode>
          <tagNode name="tail">
            <properties>
              <help>Show last n changes to messages</help>
              <completionHelp>
                <list>&lt;NUMBER&gt;</list>
              </completionHelp>
            </properties>
            <command>tail -n "$4" /var/log/messages | ${VYATTA_PAGER:-cat}</command>
          </tagNode>
          <node name="tail">
            <properties>
              <help>Show last 10 lines of /var/log/messages file</help>
            </properties>
            <command>tail -n 10 /var/log/messages</command>
          </node>
          <node name="vpn">
            <properties>
              <help>Show log for Virtual Private Network (VPN)</help>
            </properties>
            <children>
              <leafNode name="all">
                <properties>
                  <help>Show log for ALL</help>
                </properties>
                <command>cat $(printf "%s\n" /var/log/messages* | sort -nr) | grep -e charon -e accel -e pptpd -e ppp</command>
              </leafNode>
              <leafNode name="ipsec">
                <properties>
                  <help>Show log for IPSec</help>
                </properties>
                <command>cat $(printf "%s\n" /var/log/messages* | sort -nr) | grep -e charon</command>
              </leafNode>
              <leafNode name="l2tp">
                <properties>
                  <help>Show log for L2TP</help>
                </properties>
                <command>cat $(printf "%s\n" /var/log/messages* | sort -nr) | grep -e remote-access-aaa-win -e remote-access-zzz-mac -e accel-l2tp -e ppp</command>
              </leafNode>
              <leafNode name="pptp">
                <properties>
                  <help>Show log for PPTP</help>
                </properties>
                <command>journalctl --no-hostname --boot --unit accel-ppp@pptp.service</command>
              </leafNode>
              <leafNode name="sstp">
                <properties>
                  <help>Show log for SSTP</help>
                </properties>
                <command>journalctl --no-hostname --boot --unit accel-ppp@sstp.service</command>
              </leafNode>
            </children>
          </node>
          <leafNode name="vrrp">
            <properties>
              <help>Show log for Virtual Router Redundancy Protocol (VRRP)</help>
            </properties>
            <command>journalctl --no-hostname --boot --unit keepalived.service</command>
          </leafNode>
          <leafNode name="webproxy">
            <properties>
              <help>Show log for Webproxy</help>
            </properties>
            <command>journalctl --no-hostname --boot --unit squid.service</command>
          </leafNode>
        </children>
      </node>
    </children>
  </node>
</interfaceDefinition>