summaryrefslogtreecommitdiff
path: root/src/xsl
diff options
context:
space:
mode:
authorBob Gilligan <gilligan@sydney.vyatta.com>2007-12-14 18:26:36 -0800
committerBob Gilligan <gilligan@sydney.vyatta.com>2007-12-14 18:26:36 -0800
commit543de3ad1e144d0ab8f31a47bee8b21bb1fae264 (patch)
tree6d3b8ec7df301c01c1a0e9b203a0ce50ea03064d /src/xsl
downloadvyatta-op-firewall-543de3ad1e144d0ab8f31a47bee8b21bb1fae264.tar.gz
vyatta-op-firewall-543de3ad1e144d0ab8f31a47bee8b21bb1fae264.zip
Initial commit of operational mode templates and scripts for the
firewall subsystem.
Diffstat (limited to 'src/xsl')
-rw-r--r--src/xsl/show_firewall.xsl202
-rw-r--r--src/xsl/show_firewall_detail.xsl236
-rw-r--r--src/xsl/show_firewall_statistics.xsl108
-rw-r--r--src/xsl/show_firewall_statistics_brief.xsl110
4 files changed, 656 insertions, 0 deletions
diff --git a/src/xsl/show_firewall.xsl b/src/xsl/show_firewall.xsl
new file mode 100644
index 0000000..d40f024
--- /dev/null
+++ b/src/xsl/show_firewall.xsl
@@ -0,0 +1,202 @@
+<?xml version="1.0"?>
+<!DOCTYPE stylesheet [
+<!ENTITY newln "&#10;">
+]>
+
+<!-- /*
+ * Copyright 2006, Vyatta, Inc.
+ *
+ * GNU General Public License
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License, version 2,
+ * as published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+ * 02110-1301 USA
+ *
+ * Module: show_firewall.xsl
+ *
+ * Author: Mike Horn
+ * Date: 2006
+ *
+ */ -->
+
+<!--XSL Template for formatting the "show firewall <name>" command-->
+
+<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
+
+<xsl:variable name="pad6" select="' '"/>
+<xsl:variable name="pad6_len" select="string-length($pad6)"/>
+<xsl:variable name="pad7" select="' '"/>
+<xsl:variable name="pad7_len" select="string-length($pad7)"/>
+<xsl:variable name="pad8" select="' '"/>
+<xsl:variable name="pad8_len" select="string-length($pad8)"/>
+<xsl:variable name="pad20" select="' '"/>
+<xsl:variable name="pad20_len" select="string-length($pad20)"/>
+
+<xsl:comment> FORMAT HEADER LINES </xsl:comment>
+
+<xsl:template match="opcommand">
+<xsl:text>&newln;</xsl:text>
+<xsl:text>&newln;</xsl:text>
+<xsl:text>State Codes: E - Established, I - Invalid, N - New, R - Related&newln;</xsl:text>
+<xsl:text>&newln;</xsl:text>
+<xsl:text>rule action source destination proto state</xsl:text>
+<xsl:text>&newln;</xsl:text>
+<xsl:text>---- ------ ------ ----------- ----- ----- </xsl:text>
+<xsl:text>&newln;</xsl:text>
+
+<xsl:for-each select="format/row">
+
+<xsl:value-of select="rule_number"/>
+<xsl:value-of select="substring($pad6,1,$pad6_len - string-length(rule_number))"/>
+
+<xsl:value-of select="action"/>
+<xsl:value-of select="substring($pad8,1,$pad8_len - string-length(action))"/>
+
+ <xsl:choose>
+ <xsl:when test="src_addr!='' and src_addr!='0.0.0.0'">
+ <xsl:value-of select="src_addr"/>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - string-length(src_addr))"/>
+ </xsl:when>
+
+ <xsl:when test="src_net!='' and src_addr!='0.0.0.0/0'">
+ <xsl:value-of select="src_net"/>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - string-length(src_net))"/>
+ </xsl:when>
+
+ <xsl:when test="src_addr_start!='' and src_addr_start!='0.0.0.0'">
+ <xsl:text>Range (use detail) </xsl:text>
+ </xsl:when>
+
+ <xsl:otherwise>
+ <xsl:text>0.0.0.0/0</xsl:text>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - 9)"/>
+ </xsl:otherwise>
+ </xsl:choose>
+
+ <xsl:choose>
+ <xsl:when test="dst_addr!='' and dst_addr!='0.0.0.0'">
+ <xsl:value-of select="dst_addr"/>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - string-length(dst_addr))"/>
+ </xsl:when>
+
+ <xsl:when test="dst_net!='' and dst_addr!='0.0.0.0/0'">
+ <xsl:value-of select="dst_net"/>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - string-length(dst_net))"/>
+ </xsl:when>
+
+ <xsl:when test="dst_addr_start!='' and dst_addr_start!='0.0.0.0'">
+ <xsl:text>Range (use detail) </xsl:text>
+ </xsl:when>
+
+ <xsl:otherwise>
+ <xsl:text>0.0.0.0/0</xsl:text>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - 9)"/>
+ </xsl:otherwise>
+ </xsl:choose>
+
+<xsl:value-of select="protocol"/>
+<xsl:value-of select="substring($pad7,1,$pad7_len - string-length(protocol))"/>
+
+ <xsl:choose>
+ <xsl:when test="contains(state, 'established%2C')">
+ <xsl:text>E,</xsl:text>
+ </xsl:when>
+ <xsl:when test="contains(state, 'established')">
+ <xsl:text>E</xsl:text>
+ </xsl:when>
+ </xsl:choose>
+ <xsl:choose>
+ <xsl:when test="contains(state, 'new%2C')">
+ <xsl:text>N,</xsl:text>
+ </xsl:when>
+ <xsl:when test="contains(state, 'new')">
+ <xsl:text>N</xsl:text>
+ </xsl:when>
+ </xsl:choose>
+ <xsl:choose>
+ <xsl:when test="contains(state, 'related%2C')">
+ <xsl:text>R,</xsl:text>
+ </xsl:when>
+ <xsl:when test="contains(state, 'related')">
+ <xsl:text>R</xsl:text>
+ </xsl:when>
+ </xsl:choose>
+ <xsl:choose>
+ <xsl:when test="contains(state, 'invalid%2C')">
+ <xsl:text>I,</xsl:text>
+ </xsl:when>
+ <xsl:when test="contains(state, 'invalid')">
+ <xsl:text>I</xsl:text>
+ </xsl:when>
+ </xsl:choose>
+ <xsl:choose>
+ <xsl:when test="state=''">
+ <xsl:text>any</xsl:text>
+ </xsl:when>
+ </xsl:choose>
+
+ <xsl:text>&newln;</xsl:text>
+
+ <xsl:if test="src_port_num!='' or src_port_name!='' or src_port_start!=''">
+ <xsl:value-of select="$pad6"/>
+ <xsl:value-of select="$pad8"/>
+ <xsl:text>src ports: </xsl:text>
+ <xsl:if test="src_port_num!=''">
+ <xsl:value-of select="src_port_num"/>
+ <xsl:if test="src_port_name!='' or src_port_start!=''">
+ <xsl:text>,</xsl:text>
+ </xsl:if>
+ </xsl:if>
+ <xsl:if test="src_port_name!=''">
+ <xsl:value-of select="src_port_name"/>
+ <xsl:if test="src_port_start!=''">
+ <xsl:text>,</xsl:text>
+ </xsl:if>
+ </xsl:if>
+ <xsl:if test="src_port_start!=''">
+ <xsl:value-of select="src_port_start"/>
+ <xsl:text>-</xsl:text>
+ <xsl:value-of select="src_port_stop"/>
+ </xsl:if>
+ <xsl:text>&newln;</xsl:text>
+ </xsl:if>
+
+ <xsl:if test="dst_port_num!='' or dst_port_name!='' or dst_port_start!=''">
+ <xsl:value-of select="$pad6"/>
+ <xsl:value-of select="$pad8"/>
+ <xsl:value-of select="$pad20"/>
+ <xsl:text>dst ports: </xsl:text>
+ <xsl:if test="dst_port_num!=''">
+ <xsl:value-of select="dst_port_num"/>
+ <xsl:if test="dst_port_name!='' or dst_port_start!=''">
+ <xsl:text>,</xsl:text>
+ </xsl:if>
+ </xsl:if>
+ <xsl:if test="dst_port_name!=''">
+ <xsl:value-of select="dst_port_name"/>
+ <xsl:if test="dst_port_start!=''">
+ <xsl:text>,</xsl:text>
+ </xsl:if>
+ </xsl:if>
+ <xsl:if test="dst_port_start!=''">
+ <xsl:value-of select="dst_port_start"/>
+ <xsl:text>-</xsl:text>
+ <xsl:value-of select="dst_port_stop"/>
+ </xsl:if>
+ <xsl:text>&newln;</xsl:text>
+ </xsl:if>
+
+</xsl:for-each>
+</xsl:template>
+
+</xsl:stylesheet>
diff --git a/src/xsl/show_firewall_detail.xsl b/src/xsl/show_firewall_detail.xsl
new file mode 100644
index 0000000..6e970cb
--- /dev/null
+++ b/src/xsl/show_firewall_detail.xsl
@@ -0,0 +1,236 @@
+<?xml version="1.0"?>
+<!DOCTYPE stylesheet [
+<!ENTITY newln "&#10;">
+]>
+
+<!-- /*
+ * Copyright 2006, Vyatta, Inc.
+ *
+ * GNU General Public License
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License, version 2,
+ * as published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+ * 02110-1301 USA
+ *
+ * Module: show_firewall_detail.xsl
+ *
+ * Author: Mike Horn
+ * Date: 2006
+ *
+ */ -->
+
+<!--XSL Template for formatting the "show firewall <name> detail" command-->
+
+<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
+
+<xsl:variable name="pad10" select="' '"/>
+<xsl:variable name="pad10_len" select="string-length($pad10)"/>
+<xsl:variable name="pad20" select="' '"/>
+<xsl:variable name="pad20_len" select="string-length($pad20)"/>
+<xsl:variable name="pad22" select="' '"/>
+<xsl:variable name="pad22_len" select="string-length($pad22)"/>
+<xsl:variable name="pad34" select="' '"/>
+<xsl:variable name="pad34_len" select="string-length($pad34)"/>
+
+<xsl:template match="opcommand">
+
+<xsl:text>&newln;</xsl:text>
+<xsl:text>&newln;</xsl:text>
+
+<xsl:for-each select="format/row">
+
+<xsl:text>Rule: </xsl:text>
+<xsl:value-of select="rule_number"/>
+<xsl:text>&newln;</xsl:text>
+
+<xsl:text>Packets: </xsl:text>
+<xsl:value-of select="pkts"/>
+<xsl:value-of select="substring($pad10,1,$pad10_len - string-length(pkts))"/>
+
+<xsl:text>Bytes: </xsl:text>
+<xsl:value-of select="bytes"/>
+<xsl:text>&newln;</xsl:text>
+
+<xsl:text>Action: </xsl:text>
+<xsl:value-of select="action"/>
+<xsl:text>&newln;</xsl:text>
+
+<xsl:text>Protocol: </xsl:text>
+<xsl:value-of select="protocol"/>
+<xsl:text>&newln;</xsl:text>
+
+<xsl:text>State: </xsl:text>
+ <xsl:choose>
+ <xsl:when test="contains(state, 'established%2C')">
+ <xsl:text>E,</xsl:text>
+ </xsl:when>
+ <xsl:when test="contains(state, 'established')">
+ <xsl:text>E</xsl:text>
+ </xsl:when>
+ </xsl:choose>
+ <xsl:choose>
+ <xsl:when test="contains(state, 'new%2C')">
+ <xsl:text>N,</xsl:text>
+ </xsl:when>
+ <xsl:when test="contains(state, 'new')">
+ <xsl:text>N</xsl:text>
+ </xsl:when>
+ </xsl:choose>
+ <xsl:choose>
+ <xsl:when test="contains(state, 'related%2C')">
+ <xsl:text>R,</xsl:text>
+ </xsl:when>
+ <xsl:when test="contains(state, 'related')">
+ <xsl:text>R</xsl:text>
+ </xsl:when>
+ </xsl:choose>
+ <xsl:choose>
+ <xsl:when test="contains(state, 'invalid%2C')">
+ <xsl:text>I,</xsl:text>
+ </xsl:when>
+ <xsl:when test="contains(state, 'invalid')">
+ <xsl:text>I</xsl:text>
+ </xsl:when>
+ </xsl:choose>
+ <xsl:choose>
+ <xsl:when test="state=''">
+ <xsl:text>any</xsl:text>
+ </xsl:when>
+ </xsl:choose>
+<xsl:text>&newln;</xsl:text>
+
+<xsl:text>Source</xsl:text>
+<xsl:text>&newln;</xsl:text>
+<xsl:text> Address: </xsl:text>
+ <xsl:choose>
+ <xsl:when test="src_addr!='' and src_addr!='0.0.0.0'">
+ <xsl:value-of select="src_addr"/>
+ </xsl:when>
+
+ <xsl:when test="src_net!='' and src_addr!='0.0.0.0/0'">
+ <xsl:value-of select="src_net"/>
+ </xsl:when>
+
+ <xsl:when test="src_addr_start!='' and src_addr_start!='0.0.0.0'">
+ <xsl:value-of select="src_addr_start"/>
+ <xsl:text> - </xsl:text>
+ <xsl:value-of select="src_addr_stop"/>
+ </xsl:when>
+
+ <xsl:otherwise>
+ <xsl:text>0.0.0.0/0</xsl:text>
+ </xsl:otherwise>
+ </xsl:choose>
+<xsl:text>&newln;</xsl:text>
+<xsl:text> Ports: </xsl:text>
+
+ <xsl:choose>
+ <xsl:when test="src_port_num!='0'">
+ <xsl:value-of select="src_port_num"/>
+ </xsl:when>
+
+ <xsl:when test="src_port_start!='0'">
+ <xsl:value-of select="src_port_start"/>
+ <xsl:text>:</xsl:text>
+ <xsl:value-of select="src_port_stop"/>
+ </xsl:when>
+
+ <xsl:when test="src_port_name!=''">
+ <xsl:value-of select="src_port_name"/>
+ </xsl:when>
+
+ <xsl:otherwise>
+ <xsl:text>all</xsl:text>
+ </xsl:otherwise>
+ </xsl:choose>
+
+<xsl:text>&newln;</xsl:text>
+<xsl:text>Destination</xsl:text>
+<xsl:text>&newln;</xsl:text>
+<xsl:text> Address: </xsl:text>
+ <xsl:choose>
+ <xsl:when test="dst_addr!='' and dst_addr!='0.0.0.0'">
+ <xsl:value-of select="dst_addr"/>
+ </xsl:when>
+
+ <xsl:when test="dst_net!='' and dst_addr!='0.0.0.0/0'">
+ <xsl:value-of select="dst_net"/>
+ </xsl:when>
+
+ <xsl:when test="dst_addr_start!='' and dst_addr_start!='0.0.0.0'">
+ <xsl:value-of select="dst_addr_start"/>
+ <xsl:text> - </xsl:text>
+ <xsl:value-of select="dst_addr_stop"/>
+ </xsl:when>
+
+ <xsl:otherwise>
+ <xsl:text>0.0.0.0/0</xsl:text>
+ </xsl:otherwise>
+ </xsl:choose>
+<xsl:text>&newln;</xsl:text>
+<xsl:text> Ports: </xsl:text>
+
+ <xsl:choose>
+ <xsl:when test="dst_port_num!='0'">
+ <xsl:value-of select="dst_port_num"/>
+ </xsl:when>
+
+ <xsl:when test="dst_port_start!='0'">
+ <xsl:value-of select="dst_port_start"/>
+ <xsl:text>:</xsl:text>
+ <xsl:value-of select="dst_port_stop"/>
+ </xsl:when>
+
+ <xsl:when test="dst_port_name!=''">
+ <xsl:value-of select="dst_port_name"/>
+ </xsl:when>
+
+ <xsl:otherwise>
+ <xsl:text>all</xsl:text>
+ </xsl:otherwise>
+ </xsl:choose>
+
+<xsl:text>&newln;</xsl:text>
+
+<xsl:text>ICMP Code: </xsl:text>
+ <xsl:if test="icmp_code=''">
+ <xsl:text>-</xsl:text>
+ </xsl:if>
+ <xsl:if test="icmp_code!=''">
+ <xsl:value-of select="icmp_code"/>
+ </xsl:if>
+
+<xsl:text>&newln;</xsl:text>
+
+<xsl:text>ICMP Type: </xsl:text>
+ <xsl:if test="icmp_type=''">
+ <xsl:text>-</xsl:text>
+ </xsl:if>
+ <xsl:if test="icmp_type!=''">
+ <xsl:value-of select="icmp_type"/>
+ </xsl:if>
+
+<xsl:text>&newln;</xsl:text>
+<xsl:text>Logging: </xsl:text>
+<xsl:value-of select="log"/>
+
+<xsl:text>&newln;</xsl:text>
+ <xsl:if test="rule_number!='1025'">
+ <xsl:text>------------------------</xsl:text>
+ <xsl:text>&newln;</xsl:text>
+ </xsl:if>
+
+</xsl:for-each>
+</xsl:template>
+
+</xsl:stylesheet>
diff --git a/src/xsl/show_firewall_statistics.xsl b/src/xsl/show_firewall_statistics.xsl
new file mode 100644
index 0000000..3c91dbe
--- /dev/null
+++ b/src/xsl/show_firewall_statistics.xsl
@@ -0,0 +1,108 @@
+<?xml version="1.0"?>
+<!DOCTYPE stylesheet [
+<!ENTITY newln "&#10;">
+]>
+
+<!-- /*
+ * Copyright 2006, Vyatta, Inc.
+ *
+ * GNU General Public License
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License, version 2,
+ * as published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+ * 02110-1301 USA
+ *
+ * Module: show_firewall_statistics.xsl
+ *
+ * Author: Mike Horn
+ * Date: 2006
+ *
+ */ -->
+
+<!--XSL Template for formatting the "show firewall <name> statistics" command-->
+
+<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
+
+<xsl:variable name="pad6" select="' '"/>
+<xsl:variable name="pad6_len" select="string-length($pad6)"/>
+<xsl:variable name="pad8" select="' '"/>
+<xsl:variable name="pad8_len" select="string-length($pad8)"/>
+<xsl:variable name="pad10" select="' '"/>
+<xsl:variable name="pad10_len" select="string-length($pad10)"/>
+<xsl:variable name="pad20" select="' '"/>
+<xsl:variable name="pad20_len" select="string-length($pad20)"/>
+
+<xsl:template match="opcommand">
+<xsl:text>&newln;</xsl:text>
+<xsl:text>&newln;</xsl:text>
+<xsl:text>rule packets bytes action source destination</xsl:text>
+<xsl:text>&newln;</xsl:text>
+<xsl:text>---- ------- ----- ------ ------ -----------</xsl:text>
+<xsl:text>&newln;</xsl:text>
+
+<xsl:for-each select="format/row">
+
+ <xsl:value-of select="rule_number"/>
+ <xsl:value-of select="substring($pad6,1,$pad6_len - string-length(rule_number))"/>
+
+ <xsl:value-of select="pkts"/>
+ <xsl:value-of select="substring($pad10,1,$pad10_len - string-length(pkts))"/>
+
+ <xsl:value-of select="bytes"/>
+ <xsl:value-of select="substring($pad10,1,$pad10_len - string-length(bytes))"/>
+
+ <xsl:value-of select="action"/>
+ <xsl:value-of select="substring($pad8,1,$pad8_len - string-length(action))"/>
+
+ <xsl:choose>
+ <xsl:when test="src_addr!='' and src_addr!='0.0.0.0'">
+ <xsl:value-of select="src_addr"/>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - string-length(src_addr))"/>
+ </xsl:when>
+ <xsl:when test="src_net!='' and src_addr!='0.0.0.0/0'">
+ <xsl:value-of select="src_net"/>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - string-length(src_net))"/>
+ </xsl:when>
+ <xsl:when test="src_addr_start!='' and src_addr_start!='0.0.0.0'">
+ <xsl:text>Range (use detail) </xsl:text>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:text>0.0.0.0/0</xsl:text>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - 9)"/>
+ </xsl:otherwise>
+ </xsl:choose>
+
+ <xsl:choose>
+ <xsl:when test="dst_addr!='' and dst_addr!='0.0.0.0'">
+ <xsl:value-of select="dst_addr"/>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - string-length(dst_addr))"/>
+ </xsl:when>
+ <xsl:when test="dst_net!='' and dst_addr!='0.0.0.0/0'">
+ <xsl:value-of select="dst_net"/>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - string-length(dst_net))"/>
+ </xsl:when>
+ <xsl:when test="dst_addr_start!='' and dst_addr_start!='0.0.0.0'">
+ <xsl:text>Range (use detail) </xsl:text>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:text>0.0.0.0/0</xsl:text>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - 9)"/>
+ </xsl:otherwise>
+ </xsl:choose>
+
+<xsl:text>&newln;</xsl:text>
+
+</xsl:for-each>
+</xsl:template>
+
+</xsl:stylesheet>
diff --git a/src/xsl/show_firewall_statistics_brief.xsl b/src/xsl/show_firewall_statistics_brief.xsl
new file mode 100644
index 0000000..fb03dc1
--- /dev/null
+++ b/src/xsl/show_firewall_statistics_brief.xsl
@@ -0,0 +1,110 @@
+<?xml version="1.0"?>
+<!DOCTYPE stylesheet [
+<!ENTITY newln "&#10;">
+]>
+
+<!-- /*
+ * Copyright 2006, Vyatta, Inc.
+ *
+ * GNU General Public License
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License, version 2,
+ * as published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+ * 02110-1301 USA
+ *
+ * Module: show_firewall_statistics_brief.xsl
+ *
+ * Author: Mike Horn
+ * Date: 2006
+ *
+ */ -->
+
+<!--XSL Template for formatting "show firewall <name> statistics brief"-->
+
+<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
+
+<xsl:variable name="pad6" select="' '"/>
+<xsl:variable name="pad6_len" select="string-length($pad6)"/>
+<xsl:variable name="pad7" select="' '"/>
+<xsl:variable name="pad7_len" select="string-length($pad7)"/>
+<xsl:variable name="pad8" select="' '"/>
+<xsl:variable name="pad8_len" select="string-length($pad8)"/>
+<xsl:variable name="pad10" select="' '"/>
+<xsl:variable name="pad10_len" select="string-length($pad10)"/>
+<xsl:variable name="pad20" select="' '"/>
+<xsl:variable name="pad20_len" select="string-length($pad20)"/>
+
+<xsl:comment> FORMAT HEADER LINES </xsl:comment>
+
+<xsl:template match="opcommand">
+<xsl:text>&newln;</xsl:text>
+<xsl:text>&newln;</xsl:text>
+<xsl:text>State Codes: E - Established, I - Invalid, N - New, R - Related&newln;</xsl:text>
+<xsl:text>&newln;</xsl:text>
+<xsl:text>rule packets bytes action source destination</xsl:text>
+<xsl:text>&newln;</xsl:text>
+<xsl:text>---- ------- ----- ------ ------ -----------</xsl:text>
+<xsl:text>&newln;</xsl:text>
+
+<xsl:for-each select="format/row">
+
+<xsl:value-of select="rule_number"/>
+<xsl:value-of select="substring($pad6,1,$pad6_len - string-length(rule_number))"/>
+
+<xsl:value-of select="pkts"/>
+<xsl:value-of select="substring($pad10,1,$pad10_len - string-length(pkts))"/>
+
+<xsl:value-of select="bytes"/>
+<xsl:value-of select="substring($pad10,1,$pad10_len - string-length(pkts))"/>
+
+<xsl:value-of select="action"/>
+<xsl:value-of select="substring($pad8,1,$pad8_len - string-length(action))"/>
+
+ <xsl:choose>
+ <xsl:when test="src_addr!='0.0.0.0'">
+ <xsl:value-of select="src_addr"/>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - string-length(src_addr))"/>
+ </xsl:when>
+
+ <xsl:when test="src_addr_start!='0.0.0.0'">
+ <xsl:text>Range (use detail) </xsl:text>
+ </xsl:when>
+
+ <xsl:when test="src_addr='0.0.0.0'">
+ <xsl:value-of select="src_net"/>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - string-length(src_net))"/>
+ </xsl:when>
+ </xsl:choose>
+
+ <xsl:choose>
+ <xsl:when test="dst_addr!='0.0.0.0'">
+ <xsl:value-of select="dst_addr"/>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - string-length(dst_addr))"/>
+ </xsl:when>
+
+ <xsl:when test="dst_addr_start!='0.0.0.0'">
+ <xsl:text>Range (use detail) </xsl:text>
+ </xsl:when>
+
+ <xsl:when test="dst_addr='0.0.0.0'">
+ <xsl:value-of select="dst_net"/>
+ <xsl:value-of select="substring($pad20,1,$pad20_len - string-length(dst_net))"/>
+ </xsl:when>
+ </xsl:choose>
+
+ <xsl:text>&newln;</xsl:text>
+
+</xsl:for-each>
+</xsl:template>
+
+</xsl:stylesheet>