/[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 99 - (hide annotations)
Tue Nov 22 14:45:12 2005 UTC (18 years, 5 months ago) by dpavlin
File size: 2861 byte(s)
 r9038@llin:  dpavlin | 2005-11-22 14:46:42 +0100
 better logging

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     $self->{template} ||= $c->config->{webpac}->{template};
82    
83 dpavlin 96 $self->{iconv} = new Text::Iconv(
84     $c->config->{webpac}->{webpac_encoding},
85     $c->config->{webpac}->{out_encoding}
86     );
87    
88 dpavlin 99 $log->debug("converting encoding from webpac_encoding '" ,
89     $c->config->{webpac}->{webpac_encoding},
90     "' to '",
91     $c->config->{webpac}->{out_encoding},
92     "'"
93     );
94 dpavlin 96
95 dpavlin 92 return $self;
96    
97     }
98    
99 dpavlin 93 sub search {
100     my ( $self, $query ) = @_;
101    
102 dpavlin 95 my $log = $self->{log};
103 dpavlin 94
104 dpavlin 99 $log->debug("search model query: -->$query<--");
105 dpavlin 95
106     my $template_filename = $self->{template};
107    
108 dpavlin 93 my @results = $self->{est}->search(
109     query => $query,
110     attr => [ '@uri' ],
111     max => 100,
112     );
113    
114 dpavlin 99 $log->debug("loading " . ($#results + 1) . " results");
115    
116 dpavlin 95 for my $i ( 0 .. $#results ) {
117    
118     my $mfn = $1 if ( $results[$i]->{'@uri'} =~ m#/(\d+)$#);
119    
120 dpavlin 99 # $log->debug("load_ds( $mfn )");
121 dpavlin 95
122     my $ds = $self->{db}->load_ds( $mfn ) || next;
123 dpavlin 96 $results[$i]->{ html } = $self->{iconv}->convert(
124     $self->{out}->apply(
125 dpavlin 95 template => $template_filename,
126     data => $ds,
127 dpavlin 96 ) );
128 dpavlin 95 }
129    
130     return \@results;
131 dpavlin 93 }
132    
133    
134    
135    
136 dpavlin 92 =head1 AUTHOR
137    
138     Dobrica Pavlinusic
139    
140     =head1 LICENSE
141    
142     This library is free software, you can redistribute it and/or modify
143     it under the same terms as Perl itself.
144    
145     =cut
146    
147     1;

  ViewVC Help
Powered by ViewVC 1.1.26