From d205976815c1e4241a8f712b45bfe7a87e9886c2 Mon Sep 17 00:00:00 2001 From: Mike Taylor Date: Mon, 25 Sep 2006 14:58:20 +0000 Subject: [PATCH] Consistent quoting for both URL-encoding and HTML. --- web/htdocs/details/found.mc | 65 +++++++++++++++++++++++++++---------------- 1 file changed, 41 insertions(+), 24 deletions(-) diff --git a/web/htdocs/details/found.mc b/web/htdocs/details/found.mc index 9ede0f4..c502dd1 100644 --- a/web/htdocs/details/found.mc +++ b/web/htdocs/details/found.mc @@ -1,7 +1,29 @@ -%# $Id: found.mc,v 1.9 2006-09-23 07:14:05 mike Exp $ +%# $Id: found.mc,v 1.10 2006-09-25 14:58:20 mike Exp $ <%once> use XML::LibXML; use XML::LibXML::XPathContext; +use ZOOM::IRSpy::Record qw(xml_encode); +use URI::Escape; + +sub print_navlink { + my($params, $cond, $caption, $skip) = @_; + + if ($cond) { + print(' $caption\n"); + } else { + print qq[ $caption\n]; + } +} + +sub navlink { + my($params, $caption, $skip) = @_; + local $params->{_skip} = $skip; + my $url = "?" . join("&", map { "$_=" . $params->{$_} } sort keys %$params); + $url = xml_encode($url); + return $url; +} + <%perl> my %params = map { ( $_, $r->param($_)) } grep { $r->param($_) } $r->param(); @@ -44,7 +66,7 @@ my $first = $skip+1; my $last = $first+$count-1; $last = $n if $last > $n; -

<% $query %>

+

<% xml_encode($query) %>

% if ($n == 0) { No matches @@ -54,20 +76,8 @@ $last = $n if $last > $n; % } else { Records <% $first %> to <% $last %> of <% $n %>
<%perl> -if ($skip > 0) { - $params{_skip} = $count < $skip ? $skip-$count : 0; - my $prev = "?" . join("&", map { "$_=" . $params{$_} } sort keys %params); - print qq[ Prev\n]; -} else { - print qq[ Prev\n]; -} -if ($last < $n) { - $params{_skip} = $skip+$count; - my $next = "?" . join("&", map { "$_=" . $params{$_} } sort keys %params); - print qq[ Next\n]; -} else { - print qq[ Next\n]; -} +print_navlink(\%params, $skip > 0, "Prev", $count < $skip ? $skip-$count : 0); +print_navlink(\%params, $last < $n, "Next", $skip+$count); % }

@@ -104,18 +114,25 @@ push @ids, $id; <% $i %> - <% $title %> - <% $author %> - <% $host %> - <% $port %> - <% $db %> - ">[Test] - ">[Raw] + <% xml_encode($title) %> + <% xml_encode($author) %> + <% xml_encode($host) %> + <% xml_encode($port) %> + <% xml_encode($db) %> + [Test] + [Raw] % } +<%perl> +print_navlink(\%params, $skip > 0, "Prev", $count < $skip ? $skip-$count : 0); +print_navlink(\%params, $last < $n, "Next", $skip+$count); +

- [Test all targets on this list]

% } -- 1.7.10.4