/usr/share/horde/turba/edit.php is in php-horde-turba 4.2.12-1ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 | <?php
/**
* Turba edit.php.
*
* Copyright 2000-2016 Horde LLC (http://www.horde.org/)
*
* See the enclosed file LICENSE for license information (ASL). If you
* did not receive this file, see http://www.horde.org/licenses/apache.
*
* @author Chuck Hagenbuch <chuck@horde.org>
* @category Horde
* @license http://www.horde.org/licenses/apache ASL
* @package Turba
*/
require_once __DIR__ . '/lib/Application.php';
Horde_Registry::appInit('turba');
$listView = null;
$vars = Horde_Variables::getDefaultVariables();
$source = $vars->source;
$key = $vars->key;
$groupedit = ($vars->actionID == 'groupedit');
$url = new Horde_Url($vars->get('url', Horde::url($prefs->getValue('initial_page'), true)));
/* Edit the first of a list of contacts? */
if ($groupedit && (!$key || $key == '**search')) {
if (!count($vars->objectkeys)) {
$notification->push(_("You must select at least one contact first."), 'horde.warning');
$url->redirect();
}
$original_source = ($key == '**search')
? $key
: $vars->original_source;
list($source, $key) = explode(':', $vars->objectkeys[0], 2);
if (empty($original_source)) {
$original_source = $source;
}
$vars->set('key', $key);
$vars->set('source', $source);
$vars->set('original_source', $original_source);
}
if (is_null($source) || !isset($cfgSources[$source])) {
$notification->push(_("Not found"), 'horde.error');
$url->redirect();
}
$driver = $injector->getInstance('Turba_Factory_Driver')->create($source);
/* Set the contact from the requested key. */
try {
$contact = $driver->getObject($key);
} catch (Horde_Exception $e) {
$notification->push($e);
$url->redirect();
}
/* Check permissions on this contact. */
if (!$contact->hasPermission(Horde_Perms::EDIT)) {
if (!$contact->hasPermission(Horde_Perms::READ)) {
$notification->push(_("You do not have permission to view this contact."), 'horde.error');
$url->redirect();
} else {
$notification->push(_("You only have permission to view this contact."), 'horde.error');
$contact->url('Contact', true)->redirect();
}
}
/* Create the edit form. */
$form = $groupedit
? new Turba_Form_EditContactGroup($vars, $contact)
: new Turba_Form_EditContact($vars, $contact);
/* Execute() checks validation first. */
try {
$edited = $form->execute();
$url = isset($vars->url)
? new Horde_Url($url, true)
: $contact->url('Contact', true);
$url->add('section', $form->getOpenSection())
->unique()
->redirect();
} catch (Turba_Exception $e) {}
$title = sprintf($contact->isGroup() ? _("Edit Contact List \"%s\"") : _("Edit \"%s\""), $contact->getValue('name'));
Horde::startBuffer();
$notification->notify(array('listeners' => 'status'));
$form->setTitle($title);
$form->renderActive($form->getRenderer(), $vars, Horde::url('edit.php'), 'post');
$formHtml = Horde::endBuffer();
$page_output->header(array(
'title' => $title
));
echo $formHtml;
$page_output->footer();
|