← Index
NYTProf Performance Profile   « block view • line view • sub view »
For /usr/share/koha/opac/cgi-bin/opac/opac-search.pl
  Run on Tue Oct 15 11:58:52 2013
Reported on Tue Oct 15 12:02:20 2013

Filename/usr/share/koha/lib/C4/Message.pm
StatementsExecuted 20 statements in 1.28ms
Subroutines
Calls P F Exclusive
Time
Inclusive
Time
Subroutine
11123µs109µsC4::Message::::BEGIN@26C4::Message::BEGIN@26
11119µs24µsC4::Message::::BEGIN@22C4::Message::BEGIN@22
11113µs65µsC4::Message::::BEGIN@27C4::Message::BEGIN@27
11113µs193µsC4::Message::::BEGIN@25C4::Message::BEGIN@25
11110µs12µsC4::Message::::BEGIN@24C4::Message::BEGIN@24
11110µs24µsC4::Message::::BEGIN@23C4::Message::BEGIN@23
0000s0sC4::Message::::AUTOLOADC4::Message::AUTOLOAD
0000s0sC4::Message::::DESTROYC4::Message::DESTROY
0000s0sC4::Message::::__ANON__[:287]C4::Message::__ANON__[:287]
0000s0sC4::Message::::_metadataC4::Message::_metadata
0000s0sC4::Message::::_to_addressC4::Message::_to_address
0000s0sC4::Message::::appendC4::Message::append
0000s0sC4::Message::::enqueueC4::Message::enqueue
0000s0sC4::Message::::findC4::Message::find
0000s0sC4::Message::::find_last_messageC4::Message::find_last_message
0000s0sC4::Message::::metadataC4::Message::metadata
0000s0sC4::Message::::newC4::Message::new
0000s0sC4::Message::::render_metadataC4::Message::render_metadata
0000s0sC4::Message::::updateC4::Message::update
Call graph for these subroutines as a Graphviz dot language file.
Line State
ments
Time
on line
Calls Time
in subs
Code
1package C4::Message;
2
3# Copyright Liblime 2009
4# Copyright Catalyst IT 2012
5#
6# This file is part of Koha.
7#
8# Koha is free software; you can redistribute it and/or modify it under the
9# terms of the GNU General Public License as published by the Free Software
10# Foundation; either version 2 of the License, or (at your option) any later
11# version.
12#
13# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
14# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
15# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
16#
17# You should have received a copy of the GNU General Public License along
18# with Koha; if not, write to the Free Software Foundation, Inc.,
19# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20
21
22331µs229µs
# spent 24µs (19+5) within C4::Message::BEGIN@22 which was called: # once (19µs+5µs) by C4::Circulation::BEGIN@35 at line 22
use strict;
# spent 24µs making 1 call to C4::Message::BEGIN@22 # spent 5µs making 1 call to strict::import
23327µs237µs
# spent 24µs (10+14) within C4::Message::BEGIN@23 which was called: # once (10µs+14µs) by C4::Circulation::BEGIN@35 at line 23
use warnings;
# spent 24µs making 1 call to C4::Message::BEGIN@23 # spent 14µs making 1 call to warnings::import
24325µs214µs
# spent 12µs (10+2) within C4::Message::BEGIN@24 which was called: # once (10µs+2µs) by C4::Circulation::BEGIN@35 at line 24
use C4::Context;
# spent 12µs making 1 call to C4::Message::BEGIN@24 # spent 2µs making 1 call to C4::Context::import
25339µs2374µs
# spent 193µs (13+181) within C4::Message::BEGIN@25 which was called: # once (13µs+181µs) by C4::Circulation::BEGIN@35 at line 25
use C4::Letters;
# spent 193µs making 1 call to C4::Message::BEGIN@25 # spent 181µs making 1 call to Exporter::import
26350µs2194µs
# spent 109µs (23+85) within C4::Message::BEGIN@26 which was called: # once (23µs+85µs) by C4::Circulation::BEGIN@35 at line 26
use YAML::Syck;
# spent 109µs making 1 call to C4::Message::BEGIN@26 # spent 85µs making 1 call to Exporter::import
2731.10ms2117µs
# spent 65µs (13+52) within C4::Message::BEGIN@27 which was called: # once (13µs+52µs) by C4::Circulation::BEGIN@35 at line 27
use Carp;
# spent 65µs making 1 call to C4::Message::BEGIN@27 # spent 52µs making 1 call to Exporter::import
28
29=head1 NAME
30
- -
711400nsour $AUTOLOAD;
72
73
74=head2 Class Methods
75
- -
82# C4::Message->new(\%attributes) -- constructor
83sub new {
84 my ($class, $opts) = @_;
85 $opts ||= {};
86 bless {%$opts} => $class;
87}
88
89
90=head3 C4::Message->find($id)
91
- -
97# C4::Message->find($id) -- find a message by its message_id
98sub find {
99 my ($class, $id) = @_;
100 my $dbh = C4::Context->dbh;
101 my $msgs = $dbh->selectall_arrayref(
102 qq{SELECT * FROM message_queue WHERE message_id = ?},
103 { Slice => {} },
104 $id,
105 );
106 if (@$msgs) {
107 return $class->new($msgs->[0]);
108 } else {
109 return;
110 }
111}
112
113=head3 C4::Message->find_last_message($borrower, $letter_code, $transport)
114
- -
121# C4::Message->find_last_message($borrower, $letter_code, $transport)
122# -- get the borrower's most recent pending checkin or checkout notification
123sub find_last_message {
124 my ($class, $borrower, $letter_code, $transport) = @_;
125 # $type is the message_transport_type
126 $transport ||= 'email';
127 my $dbh = C4::Context->dbh;
128 my $msgs = $dbh->selectall_arrayref(
129 qq{
130 SELECT *
131 FROM message_queue
132 WHERE status = 'pending'
133 AND borrowernumber = ?
134 AND letter_code = ?
135 AND message_transport_type = ?
136 },
137 { Slice => {} },
138 $borrower->{borrowernumber},
139 $letter_code,
140 $transport,
141 );
142 if (@$msgs) {
143 return $class->new($msgs->[0]);
144 } else {
145 return;
146 }
147}
148
149
150=head3 C4::Message->enqueue($letter, $borrower, $transport)
151
- -
157# C4::Message->enqueue($letter, $borrower, $transport)
158sub enqueue {
159 my ($class, $letter, $borrower, $transport) = @_;
160 my $metadata = _metadata($letter);
161 my $to_address = _to_address($borrower, $transport);
162 $letter->{metadata} = Dump($metadata);
163 #carp "enqueuing... to $to_address";
164 C4::Letters::EnqueueLetter({
165 letter => $letter,
166 borrowernumber => $borrower->{borrowernumber},
167 message_transport_type => $transport,
168 to_address => $to_address,
169 });
170}
171
172# based on message $transport, pick an appropriate address to send to
173sub _to_address {
174 my ($borrower, $transport) = @_;
175 my $address;
176 if ($transport eq 'email') {
177 $address = $borrower->{email}
178 || $borrower->{emailpro}
179 || $borrower->{B_email};
180 } elsif ($transport eq 'sms') {
181 $address = $borrower->{smsalertnumber}
182 || $borrower->{phone}
183 || $borrower->{phonepro}
184 || $borrower->{B_phone};
185 } else {
186 warn "'$transport' is an unknown message transport.";
187 }
188 if (not defined $address) {
189 warn "An appropriate $transport address "
190 . "for borrower $borrower->{userid} "
191 . "could not be found.";
192 }
193 return $address;
194}
195
196# _metadata($letter) -- return the letter split into head/body/footer
197sub _metadata {
198 my ($letter) = @_;
199 if ($letter->{content} =~ /----/) {
200 my ($header, $body, $footer) = split(/----\r?\n?/, $letter->{content});
201 return {
202 header => $header,
203 body => [$body],
204 footer => $footer,
205 };
206 } else {
207 return {
208 header => '',
209 body => [$letter->{content}],
210 footer => '',
211 };
212 }
213}
214
215=head2 Instance Methods
216
- -
224# $object->update -- save object to database
225sub update {
226 my ($self) = @_;
227 my $dbh = C4::Context->dbh;
228 $dbh->do(
229 qq{
230 UPDATE message_queue
231 SET
232 borrowernumber = ?,
233 subject = ?,
234 content = ?,
235 metadata = ?,
236 letter_code = ?,
237 message_transport_type = ?,
238 status = ?,
239 time_queued = ?,
240 to_address = ?,
241 from_address = ?,
242 content_type = ?
243 WHERE message_id = ?
244 },
245 {},
246 $self->borrowernumber,
247 $self->subject,
248 $self->content,
249 $self->{metadata}, # we want the raw YAML here
250 $self->letter_code,
251 $self->message_transport_type,
252 $self->status,
253 $self->time_queued,
254 $self->to_address,
255 $self->from_address,
256 $self->content_type,
257 $self->message_id
258 );
259}
260
261=head3 $message->metadata(\%new_metadata)
262
- -
268# $object->metadata -- this is a YAML serialized column that contains a
269# structured representation of $object->content
270sub metadata {
271 my ($self, $data) = @_;
272 if ($data) {
273 $data->{header} ||= '';
274 $data->{body} ||= [];
275 $data->{footer} ||= '';
276 $self->{metadata} = Dump($data);
277 $self->content($self->render_metadata);
278 return $data;
279 } else {
280 return Load($self->{metadata});
281 }
282}
283
284# turn $object->metadata into a string suitable for $object->content
285sub render_metadata {
286 my ($self, $format) = @_;
287 $format ||= sub { $_[0] || "" };
288 my $metadata = $self->metadata;
289 my $body = $metadata->{body};
290 my $text = join('', map { $format->($_) } @$body);
291 return $metadata->{header} . $text . $metadata->{footer};
292}
293
294=head3 $message->append(\%letter)
295
- -
306# $object->append($letter_or_item) -- add a new item to a message's content
307sub append {
308 my ($self, $letter_or_item, $format) = @_;
309 my $item;
310 if (ref($letter_or_item)) {
311 my $letter = $letter_or_item;
312 my $metadata = _metadata($letter);
313 $item = $metadata->{body}->[0];
314 } else {
315 $item = $letter_or_item;
316 }
317 if (not $self->metadata) {
318 carp "Can't append to messages that don't have metadata.";
319 return;
320 }
321 my $metadata = $self->metadata;
322 push @{$metadata->{body}}, $item;
323 $self->metadata($metadata);
324 my $new_content = $self->render_metadata($format);
325 return $self->content($new_content);
326}
327
328=head2 Attributes Accessors
329
- -
334=head3 $message->borrowernumber
335
- -
338=head3 $message->subject
339
- -
342=head3 $message->content
343
- -
346=head3 $message->metadata
347
- -
350=head3 $message->letter_code
351
- -
354=head3 $message->message_transport_type
355
- -
358=head3 $message->status
359
- -
362=head3 $message->time_queued
363
- -
366=head3 $message->to_address
367
- -
370=head3 $message->from_address
371
- -
374=head3 $message->content_type
375
- -
378# $object->$method -- treat keys as methods
379sub AUTOLOAD {
380 my ($self, @args) = @_;
381 my $attr = $AUTOLOAD;
382 $attr =~ s/.*://;
383 if (ref($self->{$attr}) eq 'CODE') {
384 $self->{$attr}->($self, @args);
385 } else {
386 if (@args) {
387 $self->{$attr} = $args[0];
388 } else {
389 $self->{$attr};
390 }
391 }
392}
393
394sub DESTROY { }
395
39613µs1;
397
398=head1 SEE ALSO
399
- -