rt 4.2.14 (#13852)
[freeside.git] / rt / share / html / Admin / Users / Keys.html
1 %# BEGIN BPS TAGGED BLOCK {{{
2 %#
3 %# COPYRIGHT:
4 %#
5 %# This software is Copyright (c) 1996-2017 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 => loc("[_1]'s encryption keys",$UserObj->Name)  &>
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 <form action="<%RT->Config->Get('WebPath')%>/Admin/Users/Keys.html" method="post" enctype="multipart/form-data">
60 <input type="hidden" class="hidden" name="id" value="<% $UserObj->Id %>" />
61
62 % if (RT::Crypt->UseForOutgoing eq 'GnuPG') {
63 <&|/Widgets/TitleBox, title => loc('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
74 % if (RT::Crypt->UseForOutgoing eq 'SMIME') {
75 <&|/Widgets/TitleBox, title => loc('SMIME Certificate') &>
76 <textarea name="SMIMECertificate"><% $UserObj->SMIMECertificate || '' %></textarea>
77 </&>
78 % }
79
80 <& /Elements/Submit, Name => 'Update', Label => loc('Save Changes') &>
81 </form>
82
83 <%ARGS>
84 $id         => undef
85 $Update     => undef
86 </%ARGS>
87 <%INIT>
88 return unless RT->Config->Get('Crypt')->{'Enable'};
89
90 my @results;
91
92 my $UserObj = RT::User->new( $session{'CurrentUser'} );
93 $UserObj->Load( $id );
94 unless ( $UserObj->id ) {
95     Abort( loc("Couldn't load user #[_1]", $id) );
96 }
97 $id = $ARGS{'id'} = $UserObj->id;
98
99 my @potential_keys;
100 my $email = $UserObj->EmailAddress;
101
102 if (RT::Crypt->UseForOutgoing eq 'GnuPG') {
103     my %keys_meta = RT::Crypt->GetKeysForSigning( Signer => $email, Protocol => 'GnuPG' );
104     @potential_keys = map $_->{'Key'}, @{ $keys_meta{'info'} || [] };
105
106     $ARGS{'PrivateKey'} = $m->comp('/Widgets/Form/Select:Process',
107         Name      => 'PrivateKey',
108         Arguments => \%ARGS,
109         Default   => 1,
110     );
111
112     if ( $Update ) {
113         if (not $ARGS{'PrivateKey'} or grep {$_ eq $ARGS{'PrivateKey'}} @potential_keys) {
114             if (($ARGS{'PrivateKey'}||'') ne ($UserObj->PrivateKey||'')) {
115                 my ($status, $msg) = $UserObj->SetPrivateKey( $ARGS{'PrivateKey'} );
116                 push @results, $msg;
117             }
118         } else {
119             push @results, loc("Invalid key [_1] for address '[_2]'", $ARGS{'PrivateKey'}, $email);
120         }
121     }
122 }
123
124 if (RT::Crypt->UseForOutgoing eq 'SMIME') {
125     if ( $Update and ($ARGS{'SMIMECertificate'}||'') ne ($UserObj->SMIMECertificate||'') ) {
126         my ($status, $msg) = $UserObj->SetSMIMECertificate( $ARGS{'SMIMECertificate'} );
127         push @results, $msg;
128     }
129 }
130
131 </%INIT>