Bug 23075: Do not 'Send' if the url is not correct
[koha.git] / admin / share_content.pl
1 #!/usr/bin/perl
2
3 # This file is part of Koha.
4 #
5 # Koha is free software; you can redistribute it and/or modify it
6 # under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 3 of the License, or
8 # (at your option) any later version.
9 #
10 # Koha is distributed in the hope that it will be useful, but
11 # WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
14 #
15 # You should have received a copy of the GNU General Public License
16 # along with Koha; if not, see <http://www.gnu.org/licenses>.
17
18 use Modern::Perl;
19
20 use CGI qw ( -utf8 );
21 use JSON;
22 use HTTP::Request;
23
24 use C4::Auth;
25 use C4::Output;
26
27 use Koha::SharedContent;
28
29 my $query = new CGI;
30 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
31     {
32         template_name   => "admin/share_content.tt",
33         query           => $query,
34         type            => "intranet",
35         authnotrequired => 0,
36         flagsrequired   => { parameters => 'manage_mana' },
37         debug           => 1,
38     }
39 );
40
41 my $op = $query->param('op') || q{};
42 my $mana_base = C4::Context->config('mana_config') || '';
43 # Check the mana server actually exists at the other end
44 my $bad_url;
45 if ($mana_base) {
46     my $request = HTTP::Request->new( GET => $mana_base );
47     my $result = Koha::SharedContent::process_request($request);
48     $bad_url = 1 unless (exists($result->{version}));
49 }
50
51 if ( $op eq 'save' ) {
52     my $auto_share = $query->param('autosharewithmana') || q{};
53     my $mana = $query->param('mana');
54
55     C4::Context->set_preference('Mana', $mana);
56
57     if ( $auto_share ne '' ) {
58         C4::Context->set_preference('AutoShareWithMana', 'subscription');
59     } else {
60         C4::Context->set_preference('AutoShareWithMana', '');
61     }
62 }
63
64 if ( $op eq 'reset' ) {
65     C4::Context->set_preference('ManaToken', '');
66 }
67
68 if ( $op eq 'send' && not $bad_url ) {
69     my $name = $query->param('name');
70     my $email = $query->param('email');
71
72     my $content = to_json({name => $name,
73                            email => $email});
74
75     my $url = "$mana_base/getsecuritytoken";
76     my $request = HTTP::Request->new( POST => $url );
77     $request->content($content);
78     my $result = Koha::SharedContent::process_request($request);
79
80     $template->param( result => $result );
81
82     if ( $result->{code} eq '201' && $result->{token} ) {
83         C4::Context->set_preference('ManaToken', $result->{token});
84     }
85 }
86
87
88 $template->param(
89     mana_url    => $mana_base,
90     bad_url     => $bad_url,
91 );
92
93 output_html_with_http_headers $query, $cookie, $template->output;