Files
server/usr/share/psa-horde/imp/lib/Prefs/Special/SmimePrivateKey.php
2026-01-07 20:52:11 +01:00

103 lines
4.2 KiB
PHP

<?php
/**
* Copyright 2012-2017 Horde LLC (http://www.horde.org/)
*
* See the enclosed file COPYING for license information (GPL). If you
* did not receive this file, see http://www.horde.org/licenses/gpl.
*
* @category Horde
* @copyright 2012-2017 Horde LLC
* @license http://www.horde.org/licenses/gpl GPL
* @package IMP
*/
/**
* Special prefs handling for the 'smimeprivatekey' preference.
*
* @author Michael Slusarz <slusarz@horde.org>
* @category Horde
* @copyright 2012-2017 Horde LLC
* @license http://www.horde.org/licenses/gpl GPL
* @package IMP
*/
class IMP_Prefs_Special_SmimePrivateKey implements Horde_Core_Prefs_Ui_Special
{
/**
*/
public function init(Horde_Core_Prefs_Ui $ui)
{
}
/**
*/
public function display(Horde_Core_Prefs_Ui $ui)
{
global $injector, $page_output, $prefs, $session;
$page_output->addScriptPackage('IMP_Script_Package_Imp');
$view = new Horde_View(array(
'templatePath' => IMP_TEMPLATES . '/prefs'
));
$view->addHelper('Horde_Core_View_Helper_Help');
if (!Horde::isConnectionSecure()) {
$view->notsecure = true;
} else {
$smime_url = IMP_Basic_Smime::url();
$view->has_key = ($prefs->getValue('smime_public_key') && $prefs->getValue('smime_private_key'));
if ($view->has_key) {
$view->viewpublic = Horde::link($smime_url->copy()->add('actionID', 'view_personal_public_key'), _("View Personal Public Certificate"), null, 'view_key');
$view->infopublic = Horde::link($smime_url->copy()->add('actionID', 'info_personal_public_key'), _("Information on Personal Public Certificate"), null, 'info_key');
if ($injector->getInstance('IMP_Crypt_Smime')->getPassphrase()) {
$view->passphrase = Horde::link($ui->selfUrl(array(
'special' => true,
'token' => true
))->add('unset_smime_passphrase', 1), _("Unload Passphrase")) . _("Unload Passphrase");
} else {
$imple = $injector->getInstance('Horde_Core_Factory_Imple')->create('IMP_Ajax_Imple_PassphraseDialog', array(
'params' => array(
'reload' => $ui->selfUrl()->setRaw(true)
),
'type' => 'smimePersonal'
));
$view->passphrase = Horde::link('#', _("Enter Passphrase"), null, null, null, null, null, array('id' => $imple->getDomId())) . _("Enter Passphrase");
}
$view->viewprivate = Horde::link($smime_url->copy()->add('actionID', 'view_personal_private_key'), _("View Personal Private Key"), null, 'view_key');
$page_output->addInlineScript(array(
'$("delete_smime_personal").observe("click", function(e) { if (!window.confirm(' . json_encode(_("Are you sure you want to delete your keypair? (This is NOT recommended!)")) . ')) { e.stop(); } })'
), true);
} elseif ($session->get('imp', 'file_upload')) {
$view->import = true;
$page_output->addInlineScript(array(
'$("import_smime_personal").observe("click", function(e) { ' . Horde::popupJs($smime_url, array('params' => array('actionID' => 'import_personal_certs', 'reload' => base64_encode($ui->selfUrl()->setRaw(true))), 'height' => 275, 'width' => 750, 'urlencode' => true)) . '; e.stop(); })'
), true);
}
}
return $view->render('smimeprivatekey');
}
/**
*/
public function update(Horde_Core_Prefs_Ui $ui)
{
global $injector, $notification;
if (isset($ui->vars->delete_smime_personal)) {
$injector->getInstance('IMP_Crypt_Smime')->deletePersonalKeys();
$notification->push(_("Personal S/MIME keys deleted successfully."), 'horde.success');
} elseif (isset($ui->vars->unset_smime_passphrase)) {
$injector->getInstance('IMP_Crypt_Smime')->unsetPassphrase();
$notification->push(_("S/MIME passphrase successfully unloaded."), 'horde.success');
}
return false;
}
}