From 3412e50b54e3daac8745234e21ab6e72be0ed165 Mon Sep 17 00:00:00 2001
From: Thomas Bruederli <thomas@roundcube.net>
Date: Wed, 04 Jun 2014 11:20:33 -0400
Subject: [PATCH] Fix attachment menu structure and aria-attributes

---
 program/steps/settings/delete_identity.inc |   64 ++++++++++++++++---------------
 1 files changed, 33 insertions(+), 31 deletions(-)

diff --git a/program/steps/settings/delete_identity.inc b/program/steps/settings/delete_identity.inc
index 24bf99c..f776204 100644
--- a/program/steps/settings/delete_identity.inc
+++ b/program/steps/settings/delete_identity.inc
@@ -4,9 +4,12 @@
  +-----------------------------------------------------------------------+
  | program/steps/settings/delete_identity.inc                            |
  |                                                                       |
- | This file is part of the RoundCube Webmail client                     |
- | Copyright (C) 2005, RoundCube Dev. - Switzerland                      |
- | Licensed under the GNU GPL                                            |
+ | This file is part of the Roundcube Webmail client                     |
+ | Copyright (C) 2005-2013, The Roundcube Dev Team                       |
+ |                                                                       |
+ | Licensed under the GNU General Public License version 3 or            |
+ | any later version with exceptions for skins & plugins.                |
+ | See the README file for a full license statement.                     |
  |                                                                       |
  | PURPOSE:                                                              |
  |   Delete the submitted identities (IIDs) from the database            |
@@ -14,40 +17,39 @@
  +-----------------------------------------------------------------------+
  | Author: Thomas Bruederli <roundcube@gmail.com>                        |
  +-----------------------------------------------------------------------+
-
- $Id$
-
 */
 
-$REMOTE_REQUEST = $_GET['_remote'] ? TRUE : FALSE;
+$iid = rcube_utils::get_input_value('_iid', rcube_utils::INPUT_GPC);
 
-if ($_GET['_iid'] && preg_match('/^[0-9]+(,[0-9]+)*$/',$_GET['_iid']))
-  {
-  $DB->query("UPDATE ".get_table_name('identities')."
-              SET    del=1
-              WHERE  user_id=?
-              AND    identity_id IN (".$_GET['_iid'].")",
-              $_SESSION['user_id']);
+// check request token
+if (!$OUTPUT->ajax_call && !$RCMAIL->check_request(rcube_utils::INPUT_GPC)) {
+    $OUTPUT->show_message('invalidrequest', 'error');
+    $RCMAIL->overwrite_action('identities');
+    return;
+}
 
-  $count = $DB->affected_rows();
-  if ($count)
-    {
-    $commands = show_message('deletedsuccessfully', 'confirmation');
+if ($iid && preg_match('/^[0-9]+(,[0-9]+)*$/', $iid)) {
+    $plugin = $RCMAIL->plugins->exec_hook('identity_delete', array('id' => $iid));
+
+    $deleted = !$plugin['abort'] ? $RCMAIL->user->delete_identity($iid) : $plugin['result'];
+
+    if ($deleted > 0 && $deleted !== false) {
+        $OUTPUT->show_message('deletedsuccessfully', 'confirmation', null, false);
+    }
+    else {
+        $msg = $plugin['message'] ? $plugin['message'] : ($deleted < 0 ? 'nodeletelastidentity' : 'errorsaving');
+        $OUTPUT->show_message($msg, 'error', null, false);
     }
 
-  // send response
-  if ($REMOTE_REQUEST)
-    rcube_remote_response($commands);
-  }
+    // send response
+    if ($OUTPUT->ajax_call) {
+        $OUTPUT->send();
+    }
+}
 
-
-if ($REMOTE_REQUEST)
-  exit;
-
+if ($OUTPUT->ajax_call) {
+    exit;
+}
 
 // go to identities page
-$_action = 'identities';
-
-// overwrite action variable  
-$OUTPUT->add_script(sprintf("\n%s.set_env('action', '%s');", $JS_OBJECT_NAME, $_action));
-?>
+$RCMAIL->overwrite_action('identities');

--
Gitblit v1.9.1