/[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

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

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 93 by dpavlin, Tue Nov 22 12:57:15 2005 UTC revision 100 by dpavlin, Tue Nov 22 14:45:17 2005 UTC
# Line 8  use base qw/ Line 8  use base qw/
8          WebPAC::Search::Estraier          WebPAC::Search::Estraier
9  /;  /;
10  use Data::Dumper;  use Data::Dumper;
11    use WebPAC::DB;
12    use WebPAC::Output::TT;
13    
14  =head1 NAME  =head1 NAME
15    
# Line 30  Configuration for hyperestraier in C<con Line 32  Configuration for hyperestraier in C<con
32    
33   # configuration for hyper estraier full text search engine   # configuration for hyper estraier full text search engine
34   hyperestraier:   hyperestraier:
35      url: 'http://localhost:1978/node/webpac2'    url: 'http://localhost:1978/node/webpac2'
36      user: 'admin'    user: 'admin'
37      passwd: 'admin'    passwd: 'admin'
38    
39     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  =cut  =cut
49    
# Line 43  sub new { Line 54  sub new {
54          $self->config($config);          $self->config($config);
55    
56          my $log = $c->log;          my $log = $c->log;
57            $self->{log} = $log;
58    
59          my $est_cfg = $c->config->{hyperestraier};          my $est_cfg = $c->config->{hyperestraier};
60          $est_cfg->{'log'} = $log;          $est_cfg->{'log'} = $log;
# Line 51  sub new { Line 63  sub new {
63    
64          $self->{est} = new WebPAC::Search::Estraier( %{ $est_cfg } );          $self->{est} = new WebPAC::Search::Estraier( %{ $est_cfg } );
65    
66  #       $c->stash->{est}->search(          my $db_path = $c->config->{webpac}->{db_path};
67  #               query => $c->req->params->{Title},          my $template_path = $c->config->{webpac}->{template_path};
68  #               max => 100,  
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            $self->{template} ||= $c->config->{webpac}->{template};
82    
83            $self->{iconv} = new Text::Iconv(
84                    $c->config->{webpac}->{webpac_encoding},
85                    $c->config->{webpac}->{out_encoding}
86            );
87    
88            $log->debug("converting encoding from webpac_encoding '" .
89                    $c->config->{webpac}->{webpac_encoding} .
90                    "' to '" .
91                    $c->config->{webpac}->{out_encoding} .
92                    "'"
93            );
94    
95          return $self;          return $self;
96    
# Line 63  sub new { Line 99  sub new {
99  sub search {  sub search {
100          my ( $self, $query ) = @_;          my ( $self, $query ) = @_;
101    
102            my $log = $self->{log};
103    
104            $log->debug("search model query: -->$query<--");
105    
106            my $template_filename = $self->{template};
107    
108          my @results = $self->{est}->search(          my @results = $self->{est}->search(
109                  query => $query,                  query => $query,
110                  attr => [ '@uri' ],                  attr => [ '@uri' ],
111                  max => 100,                  max => 100,
112          );          );
113    
114          return \@results;          $log->debug("loading " . ($#results + 1) . " results");
115    
116            my @html_results;
117    
118            for my $i ( 0 .. $#results ) {
119    
120                    my $mfn = $1 if ( $results[$i]->{'@uri'} =~ m#/(\d+)$#);
121    
122                    # $log->debug("load_ds( $mfn )");
123    
124                    my $ds = $self->{db}->load_ds( $mfn ) || next;
125            
126                    my $html = $self->{out}->apply(
127                            template => $template_filename,
128                            data => $ds,
129                    );
130    
131                    $html = $self->{iconv}->convert( $html ) || $log->error("can't convert: $html");
132    
133                    push @html_results, $html;
134    
135            }
136    
137            return \@html_results;
138  }  }
139    
140    

Legend:
Removed from v.93  
changed lines
  Added in v.100

  ViewVC Help
Powered by ViewVC 1.1.26