/[webpac2]/Webpacus/lib/Webpacus/Model/WebPAC.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Annotation of /Webpacus/lib/Webpacus/Model/WebPAC.pm

Parent Directory Parent Directory | Revision Log Revision Log


Revision 115 - (hide annotations)
Wed Nov 23 00:15:01 2005 UTC (18 years, 5 months ago) by dpavlin
File size: 3183 byte(s)
 r9069@llin:  dpavlin | 2005-11-23 01:16:41 +0100
 minor tweaks

1 dpavlin 92 package Webpacus::Model::WebPAC;
2    
3     use strict;
4     use warnings;
5     use lib '/data/webpac2/lib';
6 dpavlin 93 use base qw/
7     Catalyst::Model
8     WebPAC::Search::Estraier
9     /;
10 dpavlin 92 use Data::Dumper;
11 dpavlin 95 use WebPAC::DB;
12     use WebPAC::Output::TT;
13 dpavlin 92
14     =head1 NAME
15    
16     Webpacus::Model::WebPAC - Catalyst Model
17    
18     =head1 SYNOPSIS
19    
20     See L<Webpacus> and L<WebPAC>.
21    
22     =head1 DESCRIPTION
23    
24     Catalyst Model for access to WebPAC data.
25    
26     =head2 new
27    
28     Configuration for hyperestraier in C<config.yaml> like this:
29    
30     --- #YAML:1.0
31     # DO NOT USE TABS FOR INDENTATION OR label/value SEPARATION!!!
32    
33     # configuration for hyper estraier full text search engine
34     hyperestraier:
35 dpavlin 96 url: 'http://localhost:1978/node/webpac2'
36     user: 'admin'
37     passwd: 'admin'
38 dpavlin 92
39 dpavlin 96 webpac:
40     db_path: '/data/webpac2/db'
41     template_path: '/data/webpac2/conf/output/tt'
42     template: 'html_ffzg_results_short.tt'
43     # encoding comming from webpac
44     webpac_encoding: 'iso-8859-2'
45     # encoding expected by Catalyst
46     out_encoding: 'UTF-8'
47    
48 dpavlin 92 =cut
49    
50     sub new {
51     my ( $self, $c, $config ) = @_;
52    
53     $self = $self->NEXT::new($c, $config);
54     $self->config($config);
55    
56     my $log = $c->log;
57 dpavlin 94 $self->{log} = $log;
58 dpavlin 92
59 dpavlin 93 my $est_cfg = $c->config->{hyperestraier};
60     $est_cfg->{'log'} = $log;
61 dpavlin 92
62 dpavlin 93 $log->debug("using config:" . Dumper($est_cfg) );
63 dpavlin 92
64 dpavlin 93 $self->{est} = new WebPAC::Search::Estraier( %{ $est_cfg } );
65 dpavlin 92
66 dpavlin 95 my $db_path = $c->config->{webpac}->{db_path};
67     my $template_path = $c->config->{webpac}->{template_path};
68    
69     $log->debug("using db path '$db_path', template path '$template_path'");
70    
71     $self->{db} = new WebPAC::DB(
72     path => $db_path,
73     read_only => 1,
74     );
75    
76     $self->{out} = new WebPAC::Output::TT(
77     include_path => $template_path,
78     filters => { foo => sub { shift } },
79     );
80    
81 dpavlin 101 # default template from config.yaml
82 dpavlin 95 $self->{template} ||= $c->config->{webpac}->{template};
83    
84 dpavlin 96 $self->{iconv} = new Text::Iconv(
85     $c->config->{webpac}->{webpac_encoding},
86     $c->config->{webpac}->{out_encoding}
87     );
88    
89 dpavlin 100 $log->debug("converting encoding from webpac_encoding '" .
90     $c->config->{webpac}->{webpac_encoding} .
91     "' to '" .
92     $c->config->{webpac}->{out_encoding} .
93 dpavlin 99 "'"
94     );
95 dpavlin 96
96 dpavlin 92 return $self;
97    
98     }
99    
100 dpavlin 93 sub search {
101 dpavlin 101 my ( $self, $query, $template ) = @_;
102 dpavlin 93
103 dpavlin 95 my $log = $self->{log};
104 dpavlin 94
105 dpavlin 99 $log->debug("search model query: -->$query<--");
106 dpavlin 95
107 dpavlin 101 my $template_filename = $template || $self->{template};
108 dpavlin 95
109 dpavlin 93 my @results = $self->{est}->search(
110     query => $query,
111     attr => [ '@uri' ],
112     max => 100,
113     );
114    
115 dpavlin 99 $log->debug("loading " . ($#results + 1) . " results");
116    
117 dpavlin 100 my @html_results;
118    
119 dpavlin 95 for my $i ( 0 .. $#results ) {
120    
121     my $mfn = $1 if ( $results[$i]->{'@uri'} =~ m#/(\d+)$#);
122    
123 dpavlin 115 #$log->debug("load_ds( $mfn )");
124 dpavlin 95
125 dpavlin 115 my $ds = $self->{db}->load_ds( $mfn ) || $log->error("can't load_ds( $mfn )") && next;
126 dpavlin 100
127 dpavlin 115 #$log->debug( "ds = " . Dumper( \@html_results ) );
128    
129 dpavlin 100 my $html = $self->{out}->apply(
130 dpavlin 95 template => $template_filename,
131     data => $ds,
132 dpavlin 100 );
133    
134     $html = $self->{iconv}->convert( $html ) || $log->error("can't convert: $html");
135    
136     push @html_results, $html;
137    
138 dpavlin 95 }
139    
140 dpavlin 115 #$log->debug( '@html_results = ' . Dumper( \@html_results ) );
141    
142 dpavlin 100 return \@html_results;
143 dpavlin 93 }
144    
145    
146    
147    
148 dpavlin 92 =head1 AUTHOR
149    
150     Dobrica Pavlinusic
151    
152     =head1 LICENSE
153    
154     This library is free software, you can redistribute it and/or modify
155     it under the same terms as Perl itself.
156    
157     =cut
158    
159     1;

  ViewVC Help
Powered by ViewVC 1.1.26