From 41aa2f0441ae40ac91d4d30c6b3d3de96542849e Mon Sep 17 00:00:00 2001 From: Mike Rylander Date: Tue, 12 Mar 2013 16:01:25 -0400 Subject: [PATCH] Allow nesting of create_date and edit_date filters As gently suggested by tsbere, this commit allows nesting of said filters. Signed-off-by: Mike Rylander Signed-off-by: Lebbeous Fogle-Weekley Signed-off-by: Mike Rylander --- .../Application/Storage/Driver/Pg/QueryParser.pm | 75 +++++++++++----------- 1 file changed, 36 insertions(+), 39 deletions(-) diff --git a/Open-ILS/src/perlmods/lib/OpenILS/Application/Storage/Driver/Pg/QueryParser.pm b/Open-ILS/src/perlmods/lib/OpenILS/Application/Storage/Driver/Pg/QueryParser.pm index 9d713e60a1..fb49bbef21 100644 --- a/Open-ILS/src/perlmods/lib/OpenILS/Application/Storage/Driver/Pg/QueryParser.pm +++ b/Open-ILS/src/perlmods/lib/OpenILS/Application/Storage/Driver/Pg/QueryParser.pm @@ -958,45 +958,6 @@ sub toSQL { $agg_record = 'CASE WHEN COUNT(DISTINCT m.source) = 1 THEN FIRST(m.source) ELSE NULL END AS record'; } - # bre.create_date and bre.edit_date filtering - for my $datefilter ( qw/create_date edit_date/ ) { - my $cdate = $self->find_filter($datefilter); - if ($cdate && $cdate->args && scalar(@{$cdate->args}) > 0 && scalar(@{$cdate->args}) < 3) { - my ($cstart, $cend) = @{$cdate->args}; - - if (!$cstart and !$cend) { - # useless use of filter - } elsif (!$cstart or $cstart eq '-infinity') { # no start supplied - if ($cend eq 'infinity') { - # useless use of filter - } else { - # "before $cend" - $cend = cleanse_ISO8601($cend); - $limit_where .= <<" SQL"; - AND bre.$datefilter <= \$_$$\$$cend\$_$$\$ - SQL - } - - } elsif (!$cend or $cend eq 'infinity') { # no end supplied - if ($cstart eq '-infinity') { - # useless use of filter - } else { # "after $cstart" - $cstart = cleanse_ISO8601($cstart); - $limit_where .= <<" SQL"; - AND bre.$datefilter >= \$_$$\$$cstart\$_$$\$ - SQL - } - } else { # both supplied - # "between $cstart and $cend" - $cstart = cleanse_ISO8601($cstart); - $cend = cleanse_ISO8601($cend); - $limit_where .= <<" SQL"; - AND bre.$datefilter BETWEEN \$_$$\$$cstart\$_$$\$ AND \$_$$\$$cend\$_$$\$ - SQL - } - } - } - my $sql = <QueryParser->quote_value($_) } @{$filter->args}) . ')'; } + + } elsif ($filter->name eq 'edit_date' or $filter->name eq 'create_date') { + # bre.create_date and bre.edit_date filtering + my $datefilter = $filter->name; + + if ($filter && $filter->args && scalar(@{$filter->args}) > 0 && scalar(@{$filter->args}) < 3) { + my ($cstart, $cend) = @{$filter->args}; + + if (!$cstart and !$cend) { + # useless use of filter + } elsif (!$cstart or $cstart eq '-infinity') { # no start supplied + if ($cend eq 'infinity') { + # useless use of filter + } else { + # "before $cend" + $cend = cleanse_ISO8601($cend); + $where .= $joiner if $where ne ''; + $where .= "bre.$datefilter <= \$_$$\$$cend\$_$$\$"; + } + + } elsif (!$cend or $cend eq 'infinity') { # no end supplied + if ($cstart eq '-infinity') { + # useless use of filter + } else { # "after $cstart" + $cstart = cleanse_ISO8601($cstart); + $where .= $joiner if $where ne ''; + $where .= "bre.$datefilter >= \$_$$\$$cstart\$_$$\$"; + } + } else { # both supplied + # "between $cstart and $cend" + $cstart = cleanse_ISO8601($cstart); + $cend = cleanse_ISO8601($cend); + $where .= $joiner if $where ne ''; + $where .= "bre.$datefilter BETWEEN \$_$$\$$cstart\$_$$\$ AND \$_$$\$$cend\$_$$\$"; + } + } } elsif ($filter->name eq 'locations') { if (@{$filter->args} > 0) { my $spcdepth = $self->plan_level + 5; -- 2.11.0