]> git.koha-community.org Git - koha.git/blob - opac/opac-ics.pl
Bug 19319: Only fetch the record if it exists
[koha.git] / opac / opac-ics.pl
1 #!/usr/bin/perl
2
3 # Copyright 2007 Liblime Ltd
4
5 # This file is part of Koha.
6 #
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
11 #
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
16 #
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>.
19
20 # This script builds an ICalendar file (rfc 2445) for use in programs such as Ical
21
22 use strict;
23 use warnings;
24
25 use CGI qw ( -utf8 );
26 use Data::ICal;
27 use Data::ICal::Entry::Event;
28 use DateTime;
29 use DateTime::Format::ICal;
30 use DateTime::Event::ICal;
31 use URI;
32
33 use C4::Auth;
34 use C4::Koha;
35 use C4::Circulation;
36 use C4::Members;
37 use Koha::DateUtils;
38
39 my $query = new CGI;
40 my ( $template, $borrowernumber, $cookie ) = get_template_and_user(
41     {
42         template_name   => "opac-ics.tt",
43         query           => $query,
44         type            => "opac",
45         authnotrequired => 0,
46         debug           => 1,
47     }
48 );
49
50 # Create Calendar
51 my $calendar = Data::ICal->new();
52
53 # get issued items ....
54 my $issues = GetPendingIssues($borrowernumber);
55
56 foreach my $issue ( @$issues ) {
57     my $vevent = Data::ICal::Entry::Event->new();
58     my $timestamp = DateTime->now(); # Defaults to UTC
59     # Send some values to the template to generate summary and description
60     $template->param(
61         overdue => $issue->{'overdue'},
62         title   => $issue->{'title'},
63         barcode => $issue->{'barcode'},
64     );
65     # Catch the result of the template and split on newline
66     my ($summary,$description) = split /\n/, $template->output;
67     my $datestart;
68     if ($issue->{'overdue'} && $issue->{'overdue'} == 1) {
69         # Not much use adding an event in the past for a book that is overdue
70         # so we set datestart = now
71         $datestart = $timestamp;
72     } else {
73         $datestart = dt_from_string($issue->{'date_due'});
74         $datestart->set_time_zone('UTC');
75     }
76     # Create a UID that includes the issue number and the domain
77     my $domain = '';
78     my $baseurl = C4::Context->preference('OPACBaseURL');
79     if ( $baseurl ne '' ) {
80         my $url = URI->new($baseurl);
81         $domain = $url->host;
82     } else {
83         warn "Make sure the systempreference OPACBaseURL is set!";
84     }
85     my $uid = 'issue-' . $issue->{'issue_id'} . '@' . $domain;
86     # Create the event
87     $vevent->add_properties(
88         summary     => $summary,
89         description => $description,
90         dtstamp     => DateTime::Format::ICal->format_datetime($timestamp),
91         dtstart     => DateTime::Format::ICal->format_datetime($datestart),
92         uid         => $uid,
93     );
94     # Add it to the calendar
95     $calendar->add_entry($vevent);
96 }
97
98 print $query->header(
99     -type       => 'application/octet-stream',
100     -attachment => 'koha.ics'
101 );
102
103 print $calendar->as_string;