[Svn] r2006 - in trunk/roundcubemail: . config installer program/include program/js program/steps/settings skins/default skins/default/templates

trac at roundcube.net trac at roundcube.net
Fri Oct 24 09:57:22 CEST 2008


Author: alec
Date: 2008-10-24 02:57:21 -0500 (Fri, 24 Oct 2008)
New Revision: 2006

Modified:
   trunk/roundcubemail/CHANGELOG
   trunk/roundcubemail/config/main.inc.php.dist
   trunk/roundcubemail/installer/config.php
   trunk/roundcubemail/program/include/rcmail.php
   trunk/roundcubemail/program/js/app.js
   trunk/roundcubemail/program/steps/settings/edit_identity.inc
   trunk/roundcubemail/program/steps/settings/func.inc
   trunk/roundcubemail/program/steps/settings/identities.inc
   trunk/roundcubemail/program/steps/settings/save_identity.inc
   trunk/roundcubemail/skins/default/settings.css
   trunk/roundcubemail/skins/default/templates/editidentity.html
   trunk/roundcubemail/skins/default/templates/identities.html
Log:
- Added option 'identities_level', removed 'multiple_identities'
- Allow deleting identities when multiple_identities=false (#1485435)


Modified: trunk/roundcubemail/CHANGELOG
===================================================================
--- trunk/roundcubemail/CHANGELOG	2008-10-22 22:05:59 UTC (rev 2005)
+++ trunk/roundcubemail/CHANGELOG	2008-10-24 07:57:21 UTC (rev 2006)
@@ -1,6 +1,11 @@
 CHANGELOG RoundCube Webmail
 ---------------------------
 
+2008/10/24 (alec)
+----------
+- Added option 'identities_level', removed 'multiple_identities'
+- Allow deleting identities when multiple_identities=false (#1485435)
+
 2008/10/22 (alec)
 ----------
 - Added option focus_on_new_message (#1485374)

Modified: trunk/roundcubemail/config/main.inc.php.dist
===================================================================
--- trunk/roundcubemail/config/main.inc.php.dist	2008-10-22 22:05:59 UTC (rev 2005)
+++ trunk/roundcubemail/config/main.inc.php.dist	2008-10-24 07:57:21 UTC (rev 2006)
@@ -285,8 +285,12 @@
 // don't allow these settings to be overriden by the user
 $rcmail_config['dont_override'] = array();
 
-// allow users to add and delete sender identities
-$rcmail_config['multiple_identities'] = true;
+// Set identities access level:
+// 0 - many identities with possibility to edit all params
+// 1 - many identities with possibility to edit all params but not email address
+// 2 - one identity with possibility to edit all params
+// 3 - one identity with possibility to edit all params but not email address
+$rcmail_config['identities_level'] = 0;
 
 // try to load host-specific configuration
 // see http://trac.roundcube.net/wiki/Howto_Config for more details

Modified: trunk/roundcubemail/installer/config.php
===================================================================
--- trunk/roundcubemail/installer/config.php	2008-10-22 22:05:59 UTC (rev 2005)
+++ trunk/roundcubemail/installer/config.php	2008-10-24 07:57:21 UTC (rev 2006)
@@ -122,6 +122,22 @@
 <p class="hint">It is based on GoogieSpell what implies that the message content will be sent to Google in order to check the spelling.</p>
 </dd>
 
+<dt class="propname">identities_level</dt>
+<dd>
+<?php
+
+$input_ilevel = new html_select(array('name' => '_identities_level', 'id' => "cfgidentitieslevel"));
+$input_ilevel->add('many identities with possibility to edit all params', 0);
+$input_ilevel->add('many identities with possibility to edit all params but not email address', 1);
+$input_ilevel->add('one identity with possibility to edit all params', 2);
+$input_ilevel->add('one identity with possibility to edit all params but not email address', 3);
+echo $input_ilevel->show($RCI->getprop('identities_level'), 0);
+
+?>
+<div>Level of identities access</div>
+<p class="hint">Defines what users can do with their identities.</p>
+</dd>
+
 </dl>
 </fieldset>
 

Modified: trunk/roundcubemail/program/include/rcmail.php
===================================================================
--- trunk/roundcubemail/program/include/rcmail.php	2008-10-22 22:05:59 UTC (rev 2005)
+++ trunk/roundcubemail/program/include/rcmail.php	2008-10-24 07:57:21 UTC (rev 2006)
@@ -433,7 +433,7 @@
 
     // lowercase username if it's an e-mail address (#1484473)
     if (strpos($username, '@'))
-      $username = strtolower($username);
+      $username = rc_strtolower($username);
 
     // user already registered -> overwrite username
     if ($user = rcube_user::query($username, $host))

Modified: trunk/roundcubemail/program/js/app.js
===================================================================
--- trunk/roundcubemail/program/js/app.js	2008-10-22 22:05:59 UTC (rev 2005)
+++ trunk/roundcubemail/program/js/app.js	2008-10-24 07:57:21 UTC (rev 2006)
@@ -288,8 +288,8 @@
         this.enable_command('preferences', 'identities', 'save', 'folders', true);
         
         if (this.env.action=='identities' || this.env.action=='edit-identity' || this.env.action=='add-identity') {
-          this.enable_command('add', 'delete', this.env.multiple_identities);
-          this.enable_command('edit', true);
+          this.enable_command('add', this.env.identities_level < 2);
+          this.enable_command('delete', 'edit', true);
         }
 
         if (this.env.action=='edit-identity' || this.env.action=='add-identity')

Modified: trunk/roundcubemail/program/steps/settings/edit_identity.inc
===================================================================
--- trunk/roundcubemail/program/steps/settings/edit_identity.inc	2008-10-22 22:05:59 UTC (rev 2005)
+++ trunk/roundcubemail/program/steps/settings/edit_identity.inc	2008-10-24 07:57:21 UTC (rev 2006)
@@ -19,24 +19,28 @@
 
 */
 
-$OUTPUT->set_pagetitle(rcube_label('identities'));
+define('IDENTITIES_LEVEL', intval($RCMAIL->config->get('identities_level', 0)));
 
+// edit-identity
 if (($_GET['_iid'] || $_POST['_iid']) && $RCMAIL->action=='edit-identity') {
   $IDENTITY_RECORD = $USER->get_identity(get_input_value('_iid', RCUBE_INPUT_GPC));
   
   if (is_array($IDENTITY_RECORD))
     $OUTPUT->set_env('iid', $IDENTITY_RECORD['identity_id']);
 }
-else if (!$RCMAIL->config->get('multiple_identities', true)) {
-  $OUTPUT->show_message('opnotpermitted', 'error');
-  // go to identities page
-  rcmail_overwrite_action('identities');
-  return;
+// add-identity
+else {
+  if (IDENTITIES_LEVEL > 1) {
+    $OUTPUT->show_message('opnotpermitted', 'error');
+    // go to identities page
+    rcmail_overwrite_action('identities');
+    return;
+  }
+  else if (IDENTITIES_LEVEL == 1)
+    $IDENTITY_RECORD['email'] = rcmail_get_email();
 }
 
-$OUTPUT->include_script('list.js');
 
-
 function rcube_identity_form($attrib)
   {
   global $IDENTITY_RECORD, $RCMAIL, $OUTPUT;
@@ -85,7 +89,12 @@
                        'html_signature'=>array('type' => 'checkbox', 'label' => 'htmlsignature', 'onclick' => 'return rcmail.toggle_editor(this, \'rcmfd_signature\');'),
                        'standard'     => array('type' => 'checkbox', 'label' => 'setdefault'));
 
-
+  // disable some field according to access level
+  if (IDENTITIES_LEVEL == 1 || IDENTITIES_LEVEL == 3) {
+    $a_show_cols['email']['disabled'] = true;
+    $a_show_cols['email']['class'] = 'disabled';
+  }
+  
   // a specific part is requested
   if ($attrib['part'])
     {
@@ -131,7 +140,9 @@
   return $out;  
   }
 
+$OUTPUT->include_script('list.js');
 $OUTPUT->add_handler('identityform', 'rcube_identity_form');
+$OUTPUT->set_env('identities_level', IDENTITIES_LEVEL);
 
 $OUTPUT->set_pagetitle(rcube_label(($RCMAIL->action=='add-identity' ? 'newidentity' : 'edititem')));
 
@@ -139,4 +150,5 @@
   $OUTPUT->send('addidentity');
 
 $OUTPUT->send('editidentity');
+
 ?>

Modified: trunk/roundcubemail/program/steps/settings/func.inc
===================================================================
--- trunk/roundcubemail/program/steps/settings/func.inc	2008-10-22 22:05:59 UTC (rev 2005)
+++ trunk/roundcubemail/program/steps/settings/func.inc	2008-10-24 07:57:21 UTC (rev 2006)
@@ -401,8 +401,25 @@
   return $skins;
   }
 
-$OUTPUT->set_env('multiple_identities', $RCMAIL->config->get('multiple_identities', true));
 
+function rcmail_get_email()
+  {
+  global $RCMAIL;
+  
+  if (strpos($RCMAIL->user->data['username'], '@'))
+    return $RCMAIL->user->data['username'];
+  else {
+    if ($RCMAIL->config->get('virtuser_file'))
+      $user_email = rcube_user::user2email($RCMAIL->user->data['username']);
+
+    if ($user_email == '')
+      $user_email = sprintf('%s@%s', $RCMAIL->user->data['username'], 
+    	    $RCMAIL->config->mail_domain($_SESSION['imap_host']));
+
+    return $user_email;
+    }		      
+  }
+
 // register UI objects
 $OUTPUT->add_handlers(array(
   'userprefs' => 'rcmail_user_prefs_form',

Modified: trunk/roundcubemail/program/steps/settings/identities.inc
===================================================================
--- trunk/roundcubemail/program/steps/settings/identities.inc	2008-10-22 22:05:59 UTC (rev 2005)
+++ trunk/roundcubemail/program/steps/settings/identities.inc	2008-10-24 07:57:21 UTC (rev 2006)
@@ -19,6 +19,8 @@
 
 */
 
+define('IDENTITIES_LEVEL', intval($RCMAIL->config->get('identities_level', 0)));
+
 $OUTPUT->set_pagetitle(rcube_label('identities'));
 
 $OUTPUT->include_script('list.js');
@@ -40,6 +42,7 @@
   }
 
 $OUTPUT->add_handler('identityframe', 'rcmail_identity_frame');
+$OUTPUT->set_env('identities_level', IDENTITIES_LEVEL);
 
 $OUTPUT->send('identities');
 ?>
\ No newline at end of file

Modified: trunk/roundcubemail/program/steps/settings/save_identity.inc
===================================================================
--- trunk/roundcubemail/program/steps/settings/save_identity.inc	2008-10-22 22:05:59 UTC (rev 2005)
+++ trunk/roundcubemail/program/steps/settings/save_identity.inc	2008-10-24 07:57:21 UTC (rev 2006)
@@ -19,13 +19,15 @@
 
 */
 
+define('IDENTITIES_LEVEL', intval($RCMAIL->config->get('identities_level', 0)));
+
 $a_save_cols = array('name', 'email', 'organization', 'reply-to', 'bcc', 'standard', 'signature', 'html_signature');
 $a_html_cols = array('signature');
 $a_boolean_cols = array('standard', 'html_signature');
 $updated = $default_id = false;
 
 // check input
-if (empty($_POST['_name']) || empty($_POST['_email']))
+if (empty($_POST['_name']) || (empty($_POST['_email']) && IDENTITIES_LEVEL != 1 && IDENTITIES_LEVEL != 3))
   {
   $OUTPUT->show_message('formincomplete', 'warning');
   rcmail_overwrite_action('edit-identity');
@@ -50,7 +52,11 @@
     $save_data[$col] = 0;
 }
 
+// unset email address if user has no rights to change it
+if (IDENTITIES_LEVEL == 1 || IDENTITIES_LEVEL == 3)
+  unset($save_data['email']);
 
+
 // update an existing contact
 if ($_POST['_iid'])
 {
@@ -77,9 +83,12 @@
 }
 
 // insert a new identity record
-else if ($RCMAIL->config->get('multiple_identities', true))
+else if (IDENTITIES_LEVEL < 2)
 {
-  if ($insert_id = $USER->insert_identity($save_data))
+  if (IDENTITIES_LEVEL == 1)
+    $save_data['email'] = rcmail_get_email();
+
+  if ($save_data['email'] && ($insert_id = $USER->insert_identity($save_data)))
   {
     $OUTPUT->show_message('successfullysaved', 'confirmation');
     
@@ -107,4 +116,4 @@
 // go to next step
 rcmail_overwrite_action('identities');
 
-?>
\ No newline at end of file
+?>

Modified: trunk/roundcubemail/skins/default/settings.css
===================================================================
--- trunk/roundcubemail/skins/default/settings.css	2008-10-22 22:05:59 UTC (rev 2005)
+++ trunk/roundcubemail/skins/default/settings.css	2008-10-24 07:57:21 UTC (rev 2006)
@@ -161,6 +161,11 @@
   padding-right: 10px;
 }
 
+input.disabled
+{
+  color: #999999;
+}
+
 #bottomboxes
 {
   position: absolute;

Modified: trunk/roundcubemail/skins/default/templates/editidentity.html
===================================================================
--- trunk/roundcubemail/skins/default/templates/editidentity.html	2008-10-22 22:05:59 UTC (rev 2005)
+++ trunk/roundcubemail/skins/default/templates/editidentity.html	2008-10-24 07:57:21 UTC (rev 2006)
@@ -17,7 +17,7 @@
 </div>
 
 <p id="listbuttons">
-<roundcube:button command="add" type="input" label="newidentity" class="button" condition="config:multiple_identities:true" />
+<roundcube:button command="add" type="input" label="newidentity" class="button" condition="config:identities_level:0<2" />
 </p>
 
 <div id="identity-details">
@@ -27,7 +27,7 @@
 <roundcube:object name="identityform" size="40" textareacols="60" textarearows="6" />
 
 <p><br />
-<roundcube:button command="delete" type="input" class="button" label="delete" condition="env:action=='edit-identity'&&config:multiple_identities:true" style="margin-right:0.5em" />
+<roundcube:button command="delete" type="input" class="button" label="delete" condition="env:action=='edit-identity'" style="margin-right:0.5em" />
 <roundcube:button command="save" type="input" class="button mainaction" label="save" />
 </p>
 </div>

Modified: trunk/roundcubemail/skins/default/templates/identities.html
===================================================================
--- trunk/roundcubemail/skins/default/templates/identities.html	2008-10-22 22:05:59 UTC (rev 2005)
+++ trunk/roundcubemail/skins/default/templates/identities.html	2008-10-24 07:57:21 UTC (rev 2006)
@@ -17,7 +17,7 @@
 </div>
 
 <p id="listbuttons">
-<roundcube:button command="add" type="input" label="newidentity" class="button" condition="config:multiple_identities:true" />
+<roundcube:button command="add" type="input" label="newidentity" class="button" condition="config:identities_level:0<2" />
 </p>
 
 <div id="identity-details">

_______________________________________________
http://lists.roundcube.net/mailman/listinfo/svn



More information about the Svn mailing list