Merge branch 'master' of https://github.com/jgoodman/Freeside
[freeside.git] / rt / share / html / Admin / Users / GnuPG.html
1 %# BEGIN BPS TAGGED BLOCK {{{
2 %#
3 %# COPYRIGHT:
4 %#
5 %# This software is Copyright (c) 1996-2014 Best Practical Solutions, LLC
6 %#                                          <sales@bestpractical.com>
7 %#
8 %# (Except where explicitly superseded by other copyright notices)
9 %#
10 %#
11 %# LICENSE:
12 %#
13 %# This work is made available to you under the terms of Version 2 of
14 %# the GNU General Public License. A copy of that license should have
15 %# been provided with this software, but in any event can be snarfed
16 %# from www.gnu.org.
17 %#
18 %# This work is distributed in the hope that it will be useful, but
19 %# WITHOUT ANY WARRANTY; without even the implied warranty of
20 %# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
21 %# General Public License for more details.
22 %#
23 %# You should have received a copy of the GNU General Public License
24 %# along with this program; if not, write to the Free Software
25 %# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
26 %# 02110-1301 or visit their web page on the internet at
27 %# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html.
28 %#
29 %#
30 %# CONTRIBUTION SUBMISSION POLICY:
31 %#
32 %# (The following paragraph is not intended to limit the rights granted
33 %# to you to modify and distribute this software under the terms of
34 %# the GNU General Public License and is only of importance to you if
35 %# you choose to contribute your changes and enhancements to the
36 %# community by submitting them to Best Practical Solutions, LLC.)
37 %#
38 %# By intentionally submitting any modifications, corrections or
39 %# derivatives to this work, or any other work intended for use with
40 %# Request Tracker, to Best Practical Solutions, LLC, you confirm that
41 %# you are the copyright holder for those contributions and you grant
42 %# Best Practical Solutions,  LLC a nonexclusive, worldwide, irrevocable,
43 %# royalty-free, perpetual, license to use, copy, create derivative
44 %# works based on those contributions, and sublicense and distribute
45 %# those contributions and any derivatives thereof.
46 %#
47 %# END BPS TAGGED BLOCK }}}
48 <& /Admin/Elements/Header, Title => $title  &>
49 <& /Elements/Tabs &>
50
51 <& /Elements/ListActions, actions => \@results &>
52
53 % if ( $email ) {
54 <& /Admin/Elements/ShowKeyInfo, EmailAddress => $email &>
55 % } else {
56 <h2><% loc("User has empty email address") %></h2>
57 % }
58
59
60 <form action="<%RT->Config->Get('WebPath')%>/Admin/Users/GnuPG.html" method="post" enctype="multipart/form-data">
61 <input type="hidden" class="hidden" name="id" value="<% $UserObj->Id %>" />
62
63 <&|/Widgets/TitleBox, title => 'GnuPG private key'&>
64 <& /Widgets/Form/Select,
65     Name         => 'PrivateKey',
66     Description  => loc('Private Key'),
67     Values       => \@potential_keys,
68     CurrentValue => $UserObj->PrivateKey,
69     DefaultLabel => loc('No private key'),
70 &>
71 </&>
72
73 <& /Elements/Submit, Name => 'Update', Label => loc('Save Changes') &>
74 </form>
75 <%ARGS>
76 $id         => undef
77 $Update     => undef
78 </%ARGS>
79 <%INIT>
80 return unless RT->Config->Get('GnuPG')->{'Enable'};
81
82 require RT::Crypt::GnuPG;
83
84 my @results;
85
86 my $UserObj = RT::User->new( $session{'CurrentUser'} );
87 $UserObj->Load( $id );
88 unless ( $UserObj->id ) {
89     Abort( loc("Couldn't load user #[_1]", $id) );
90 }
91 $id = $ARGS{'id'} = $UserObj->id;
92
93 my $email = $UserObj->EmailAddress;
94 my %keys_meta = RT::Crypt::GnuPG::GetKeysForSigning( $email );
95 my @potential_keys = map $_->{'Key'}, @{ $keys_meta{'info'} || [] };
96
97 $ARGS{'PrivateKey'} = $m->comp('/Widgets/Form/Select:Process',
98     Name      => 'PrivateKey',
99     Arguments => \%ARGS,
100     Default   => 1,
101 );
102
103 if ( $Update ) {
104     if (not $ARGS{'PrivateKey'} or grep {$_ eq $ARGS{'PrivateKey'}} @potential_keys) {
105         if (($ARGS{'PrivateKey'}||'') ne ($UserObj->PrivateKey||'')) {
106             my ($status, $msg) = $UserObj->SetPrivateKey( $ARGS{'PrivateKey'} );
107             push @results, $msg;
108         }
109     } else {
110         push @results, loc("Invalid key [_1] for address '[_2]'", $ARGS{'PrivateKey'}, $email);
111     }
112 }
113
114 my $title = loc("[_1]'s GnuPG keys",$UserObj->Name);
115
116 </%INIT>