← Index
Performance Profile   « block view • line view • sub view »
For opac/opac-main.pl
  Run on Thu Jul 17 22:22:09 2008
Reported on Thu Jul 17 22:22:21 2008

FileC4/NewsChannels.pm
Statements Executed11
Total Time0.000405 seconds

Subroutines — ordered by inclusive time then name
CallsInclusive
Time
Subroutine
10.00138C4::NewsChannels::GetNewsToDisplay
00C4::NewsChannels::BEGIN
00C4::NewsChannels::add_channel
00C4::NewsChannels::add_channel_category
00C4::NewsChannels::add_opac_electronic
00C4::NewsChannels::add_opac_new
00C4::NewsChannels::del_channels
00C4::NewsChannels::del_channels_categories
00C4::NewsChannels::del_opac_electronic
00C4::NewsChannels::del_opac_new
00C4::NewsChannels::get_new_channel
00C4::NewsChannels::get_new_channel_category
00C4::NewsChannels::get_opac_electronic
00C4::NewsChannels::get_opac_electronics
00C4::NewsChannels::get_opac_new
00C4::NewsChannels::get_opac_news
00C4::NewsChannels::news_channels
00C4::NewsChannels::news_channels_by_category
00C4::NewsChannels::news_channels_categories
00C4::NewsChannels::upd_opac_electronic
00C4::NewsChannels::upd_opac_new
00C4::NewsChannels::update_channel
00C4::NewsChannels::update_channel_category

LineStmts.Exclusive
Time
Avg.Code
1package C4::NewsChannels;
2
3# Copyright 2000-2002 Katipo Communications
4#
5# This file is part of Koha.
6#
7# Koha is free software; you can redistribute it and/or modify it under the
8# terms of the GNU General Public License as published by the Free Software
9# Foundation; either version 2 of the License, or (at your option) any later
10# version.
11#
12# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
13# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
14# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
15#
16# You should have received a copy of the GNU General Public License along with
17# Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
18# Suite 330, Boston, MA 02111-1307 USA
19
20use strict;
21
22use C4::Context;
23use C4::Dates qw(format_date);
24
25use vars qw($VERSION @ISA @EXPORT);
26
27BEGIN {
28 $VERSION = 3.01; # set the version for version checking
29 @ISA = qw(Exporter);
30 @EXPORT = qw(
31 &GetNewsToDisplay
32 &news_channels &get_new_channel &del_channels &add_channel &update_channel
33 &news_channels_categories &get_new_channel_category &del_channels_categories
34 &add_channel_category &update_channel_category &news_channels_by_category
35 &add_opac_new &upd_opac_new &del_opac_new &get_opac_new &get_opac_news
36 &add_opac_electronic &upd_opac_electronic &del_opac_electronic &get_opac_electronic &get_opac_electronics
37 );
38}
39
40=head1 NAME
41
42C4::NewsChannels - Functions to manage the news channels and its categories
43
44=head1 DESCRIPTION
45
46This module provides the functions needed to admin the news channels and its categories
47
48=head1 FUNCTIONS
49
50=over 2
51
52=item news_channels
53
54 ($count, @channels) = &news_channels($channel_name, $id_category, $unclassified);
55
56Looks up news channels by name or category.
57
58C<$channel_name> is the channel name to search.
59
60C<$id_category> is the channel category code to search.
61
62C<$$unclassified> if it is set and $channel_name and $id_category search for the news channels without a category
63
64if none of the params are set C<&news_channels> returns all the news channels.
65
66C<&news_channels> returns two values: an integer giving the number of
67news channels found and a reference to an array
68of references to hash, which has the news_channels and news_channels_categories fields.
69
70=cut
71
72sub news_channels {
73 my ($channel_name, $id_category, $unclassified) = @_;
74 my $dbh = C4::Context->dbh;
75 my @channels;
76 my $query = "SELECT * FROM news_channels LEFT JOIN news_channels_categories ON news_channels.id_category = news_channels_categories.id_category";
77 if ( ($channel_name ne '') && ($id_category ne '') ) {
78 $query.= " WHERE channel_name like '" . $channel_name . "%' AND news_channels.id_category = " . $id_category;
79 } elsif ($channel_name ne '') {
80 $query.= " WHERE channel_name like '" . $channel_name . "%'";
81 } elsif ($id_category ne '') {
82 $query.= " WHERE news_channels.id_category = " . $id_category;
83 } elsif ($unclassified) {
84 $query.= " WHERE news_channels.id_category IS NULL ";
85 }
86 my $sth = $dbh->prepare($query);
87 $sth->execute();
88 while (my $row = $sth->fetchrow_hashref) {
89 push @channels, $row;
90 }
91 $sth->finish;
92 return (scalar(@channels), @channels);
93}
94
95=item news_channels_by_category
96
97 ($count, @results) = &news_channels_by_category();
98
99Looks up news channels grouped by category.
100
101C<&news_channels_by_category> returns two values: an integer giving the number of
102categories found and a reference to an array
103of references to hash, which the following keys:
104
105=over 4
106
107=item C<channels_count>
108
109The number of news channels in that category
110
111=item C<channels>
112
113A reference to an array of references to hash which keys are the new_channels fields.
114
115Additionally the last index of results has a reference to all the news channels which don't have a category
116
117=cut
118
119sub news_channels_by_category {
120
121 my ($categories_count, @results) = &news_channels_categories();
122 foreach my $row (@results) {
123
124 my ($channels_count, @channels) = &news_channels('', $row->{'id_category'});
125 $row->{'channels_count'} = $channels_count;
126 $row->{'channels'} = \@channels;
127 }
128
129 my ($channels_count, @channels) = &news_channels('', '', 1);
130 my %row;
131 $row{'id_category'} = -1;
132 $row{'unclassified'} = 1;
133 $row{'channels_count'} = $channels_count;
134 $row{'channels'} = \@channels;
135 push @results, \%row;
136
137 return (scalar(@results), @results);
138}
139
140sub get_new_channel {
141 my ($id) = @_;
142 my $dbh = C4::Context->dbh;
143 my $sth = $dbh->prepare("SELECT * FROM news_channels WHERE id = ?");
144 $sth->execute($id);
145 my $channel = $sth->fetchrow_hashref;
146 $sth->finish;
147 return $channel;
148}
149
150sub del_channels {
151 my ($ids) = @_;
152 if ($ids ne '') {
153 my $dbh = C4::Context->dbh;
154 my $sth = $dbh->prepare("DELETE FROM news_channels WHERE id IN ($ids) ");
155 $sth->execute();
156 $sth->finish;
157 return $ids;
158 }
159 return 0;
160}
161
162sub add_channel {
163 my ($name, $url, $id_category, $notes) = @_;
164 my $dbh = C4::Context->dbh;
165 my $sth = $dbh->prepare("INSERT INTO news_channels (channel_name, url, id_category, notes) VALUES (?,?,?,?)");
166 $sth->execute($name, $url, $id_category, $notes);
167 $sth->finish;
168 return 1;
169}
170
171sub update_channel {
172 my ($id, $name, $url, $id_category, $notes) = @_;
173 my $dbh = C4::Context->dbh;
174 my $sth = $dbh->prepare("UPDATE news_channels SET channel_name = ?, url = ?, id_category = ?, notes = ? WHERE id = ?");
175 $sth->execute($name, $url, $id_category, $notes, $id);
176 $sth->finish;
177 return 1;
178}
179
180sub news_channels_categories {
181 my $dbh = C4::Context->dbh;
182 my @categories;
183 my $query = "SELECT * FROM news_channels_categories";
184 my $sth = $dbh->prepare($query);
185 $sth->execute();
186 while (my $row = $sth->fetchrow_hashref) {
187 push @categories, $row;
188 }
189 $sth->finish;
190 return (scalar(@categories), @categories);
191
192}
193
194sub get_new_channel_category {
195 my ($id) = @_;
196 my $dbh = C4::Context->dbh;
197 my $sth = $dbh->prepare("SELECT * FROM news_channels_categories WHERE id_category = ?");
198 $sth->execute($id);
199 my $category = $sth->fetchrow_hashref;
200 $sth->finish;
201 return $category;
202}
203
204sub del_channels_categories {
205 my ($ids) = @_;
206 if ($ids ne '') {
207 my $dbh = C4::Context->dbh;
208 my $sth = $dbh->prepare("UPDATE news_channels SET id_category = NULL WHERE id_category IN ($ids) ");
209 $sth->execute();
210 $sth = $dbh->prepare("DELETE FROM news_channels_categories WHERE id_category IN ($ids) ");
211 $sth->execute();
212 $sth->finish;
213 return $ids;
214 }
215 return 0;
216}
217
218sub add_channel_category {
219 my ($name) = @_;
220 my $dbh = C4::Context->dbh;
221 my $sth = $dbh->prepare("INSERT INTO news_channels_categories (category_name) VALUES (?)");
222 $sth->execute($name);
223 $sth->finish;
224 return 1;
225}
226
227sub update_channel_category {
228 my ($id, $name) = @_;
229 my $dbh = C4::Context->dbh;
230 my $sth = $dbh->prepare("UPDATE news_channels_categories SET category_name = ? WHERE id_category = ?");
231 $sth->execute($name, $id);
232 $sth->finish;
233 return 1;
234}
235
236sub add_opac_new {
237 my ($title, $new, $lang, $expirationdate, $number) = @_;
238 my $dbh = C4::Context->dbh;
239 my $sth = $dbh->prepare("INSERT INTO opac_news (title, new, lang, expirationdate, number) VALUES (?,?,?,?,?)");
240 $sth->execute($title, $new, $lang, $expirationdate, $number);
241 $sth->finish;
242 return 1;
243}
244
245sub upd_opac_new {
246 my ($idnew, $title, $new, $lang, $expirationdate, $number) = @_;
247 my $dbh = C4::Context->dbh;
248 my $sth = $dbh->prepare("
249 UPDATE opac_news SET
250 title = ?,
251 new = ?,
252 lang = ?,
253 expirationdate = ?,
254 number = ?
255 WHERE idnew = ?
256 ");
257 $sth->execute($title, $new, $lang, $expirationdate,$number,$idnew);
258 $sth->finish;
259 return 1;
260}
261
262sub del_opac_new {
263 my ($ids) = @_;
264 if ($ids) {
265 my $dbh = C4::Context->dbh;
266 my $sth = $dbh->prepare("DELETE FROM opac_news WHERE idnew IN ($ids)");
267 $sth->execute();
268 $sth->finish;
269 return 1;
270 } else {
271 return 0;
272 }
273}
274
275sub get_opac_new {
276 my ($idnew) = @_;
277 my $dbh = C4::Context->dbh;
278 my $sth = $dbh->prepare("SELECT * FROM opac_news WHERE idnew = ?");
279 $sth->execute($idnew);
280 my $data = $sth->fetchrow_hashref;
281 $data->{$data->{'lang'}} = 1;
282 $data->{expirationdate} = format_date($data->{expirationdate});
283 $sth->finish;
284 return $data;
285}
286
287sub get_opac_news {
288 my ($limit, $lang) = @_;
289 my $dbh = C4::Context->dbh;
290 my $query = "SELECT *, timestamp AS newdate FROM opac_news";
291 if ($lang) {
292 $query.= " WHERE lang = '" .$lang ."' ";
293 }
294 $query.= " ORDER BY timestamp DESC ";
295 #if ($limit) {
296 # $query.= "LIMIT 0, " . $limit;
297 #}
298 my $sth = $dbh->prepare($query);
299 $sth->execute();
300 my @opac_news;
301 my $count = 0;
302 while (my $row = $sth->fetchrow_hashref) {
303 if ((($limit) && ($count < $limit)) || (!$limit)) {
304 $row->{'newdate'} = format_date($row->{'newdate'});
305 $row->{'expirationdate'} = format_date($row->{'expirationdate'});
306 push @opac_news, $row;
307 }
308 $count++;
309 }
310 return ($count, \@opac_news);
311}
312
313=head2 GetNewsToDisplay
314
315 $news = &GetNewsToDisplay($lang);
316 C<$news> is a ref to an array which containts
317 all news with expirationdate > today or expirationdate is null.
318
319=cut
320
321
# spent 0.00138s within C4::NewsChannels::GetNewsToDisplay which was called: # 1 times (0.00138s) at line 51 of opac/opac-main.pl
sub GetNewsToDisplay {
322100.000400.00004 my $lang = shift;
323 my $dbh = C4::Context->dbh;
# spent 0.00014s making 1 calls to C4::Context::dbh
324 # SELECT *,DATE_FORMAT(timestamp, '%d/%m/%Y') AS newdate
325 my $query = "
326 SELECT *,timestamp AS newdate
327 FROM opac_news
328 WHERE (
329 expirationdate > CURRENT_DATE()
330 OR expirationdate IS NULL
331 OR expirationdate = '00-00-0000'
332 )
333 AND lang = ?
334 ORDER BY number
335 "; # expirationdate field is NOT in ISO format?
33615e-065e-06 my $sth = $dbh->prepare($query);
# spent 0.00006s making 1 calls to DBI::db::prepare
337 $sth->execute($lang);
# spent 0.00027s making 1 calls to DBI::st::execute
338 my @results;
339 while ( my $row = $sth->fetchrow_hashref ){
# spent 0.00004s making 1 calls to DBI::st::fetchrow_hashref # spent 0.00001s making 1 calls to DBI::common::FETCH # spent 0.00001s making 1 calls to DBI::st::fetch
340 $row->{newdate} = format_date($row->{newdate});
# spent 0.00077s making 1 calls to C4::Dates::format_date
341 push @results, $row;
# spent 0.00003s making 1 calls to DBI::st::fetchrow_hashref # spent 0.00001s making 1 calls to DBI::common::FETCH # spent 0.00001s making 1 calls to DBI::st::fetch
342 }
343 return \@results;
344}
345
346### get electronic databases
347
348sub add_opac_electronic {
349 my ($title, $edata, $lang,$image,$href,$section) = @_;
350 my $dbh = C4::Context->dbh;
351 my $sth = $dbh->prepare("INSERT INTO opac_electronic (title, edata, lang,image,href,section) VALUES (?,?,?,?,?,?)");
352 $sth->execute($title, $edata, $lang,$image,$href,$section);
353 $sth->finish;
354 return 1;
355}
356
357sub upd_opac_electronic {
358 my ($idelectronic, $title, $edata, $lang, $image, $href,$section) = @_;
359 my $dbh = C4::Context->dbh;
360 my $sth = $dbh->prepare("UPDATE opac_electronic SET title = ?, edata = ?, lang = ? , image=?, href=? ,section=? WHERE idelectronic = ?");
361 $sth->execute($title, $edata, $lang, $image,$href ,$section, $idelectronic);
362 $sth->finish;
363 return 1;
364}
365
366sub del_opac_electronic {
367 my ($ids) = @_;
368 if ($ids) {
369 my $dbh = C4::Context->dbh;
370 my $sth = $dbh->prepare("DELETE FROM opac_electronic WHERE idelectronic IN ($ids)");
371 $sth->execute();
372 $sth->finish;
373 return 1;
374 } else {
375 return 0;
376 }
377}
378
379sub get_opac_electronic {
380 my ($idelectronic) = @_;
381 my $dbh = C4::Context->dbh;
382 my $sth = $dbh->prepare("SELECT * FROM opac_electronic WHERE idelectronic = ?");
383 $sth->execute($idelectronic);
384 my $data = $sth->fetchrow_hashref;
385 $data->{$data->{'lang'}} = 1;
386 $data->{$data->{'section'}} = 1;
387 $sth->finish;
388 return $data;
389}
390
391sub get_opac_electronics {
392 my ($section, $lang) = @_;
393 my $dbh = C4::Context->dbh;
394 my $query = "SELECT *, DATE_FORMAT(timestamp, '%d/%m/%Y') AS newdate FROM opac_electronic";
395 if ($lang) {
396 $query.= " WHERE lang = '" .$lang ."' ";
397 }
398 if ($section) {
399 $query.= " and section= '" . $section."' ";
400 }
401 $query.= " ORDER BY title ";
402
403 my $sth = $dbh->prepare($query);
404 $sth->execute();
405 my @opac_electronic;
406 my $count = 0;
407 while (my $row = $sth->fetchrow_hashref) {
408 push @opac_electronic, $row;
409 $count++;
410 }
411
412 return ($count,\@opac_electronic);
413}
414
4151;
416__END__
417
418=back
419
420=head1 AUTHOR
421
422TG
423
424=cut