diff options
author | Bob Gilligan <gilligan@sydney.vyatta.com> | 2007-12-14 18:26:36 -0800 |
---|---|---|
committer | Bob Gilligan <gilligan@sydney.vyatta.com> | 2007-12-14 18:26:36 -0800 |
commit | 543de3ad1e144d0ab8f31a47bee8b21bb1fae264 (patch) | |
tree | 6d3b8ec7df301c01c1a0e9b203a0ce50ea03064d /src/xsl/show_firewall_detail.xsl | |
download | vyatta-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/show_firewall_detail.xsl')
-rw-r--r-- | src/xsl/show_firewall_detail.xsl | 236 |
1 files changed, 236 insertions, 0 deletions
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 " "> +]> + +<!-- /* + * 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> |