martin: server/kolab-webadmin/kolab-webadmin/www/admin/user user.php.in, 1.19, 1.20

cvs at kolab.org cvs at kolab.org
Tue Jul 3 00:33:49 CEST 2007


Author: martin

Update of /kolabrepository/server/kolab-webadmin/kolab-webadmin/www/admin/user
In directory doto:/tmp/cvs-serv25723

Modified Files:
	user.php.in 
Log Message:
Martin Konold: unfinished support for kolabAllowSMTPRecipient (I am tired now)


Index: user.php.in
===================================================================
RCS file: /kolabrepository/server/kolab-webadmin/kolab-webadmin/www/admin/user/user.php.in,v
retrieving revision 1.19
retrieving revision 1.20
diff -u -d -r1.19 -r1.20
--- user.php.in	28 May 2007 19:24:10 -0000	1.19
+++ user.php.in	2 Jul 2007 22:33:47 -0000	1.20
@@ -165,6 +165,49 @@
   return '';
 }
 
+function checksmtprecipient ( $form, $key, $value ) {
+  $lst = array_unique( array_filter( array_map( 'trim', preg_split( '/\n/', $value ) ), 'strlen') );
+  $str = '';
+  foreach( $lst as $SMTPRecipient ) {
+    $trimmed = ltrim($SMTPRecipient, "-."); // potentially every entry is negated with a '-'
+    // $SMTPRecipient is either an 
+    // - email address
+    // - local part of an email address with an @ suffix
+    // - a domain part
+         
+    if (! ( valid_email_address($SMTPRecipient) 
+          | valid_domain($SMTPRecipient)
+          | valid_local_part($SMTPRecipient))
+      return sprintf(_("Syntax for Recipient %s is invalid"), $SMTPRecipient);
+    }
+  }
+  return '';
+}
+
+
+function valid_email_address($address) {
+// the following addresses are invalid
+// email1.. at kolab.org
+// email1.- at kolab.org
+// email1._ at kolab.org
+// email1 at 2sub.kolab.org
+// email1 at sub.sub.2sub.kolab.org
+  return preg_match("/^[a-z]+[a-z0-9]*[\.|\-|_]?[a-z0-9]+@([a-z]+[a-z0-9]*[\.|\-]?[a-z]+[a-z0-9]*[a-z0-9]+){1,4}\.[a-z]{2,4}$/i", $address));
+}
+
+function valid_domain($domain) {
+// the following subdomains are invalid
+// 2sub.kolab.org
+// sub.sub.2sub.kolab.org
+  return preg_match("/^[a-z]+[a-z0-9]*[\.|\-]?[a-z]+[a-z0-9]*[a-z0-9]+){1,4}\.[a-z]{2,4}$/i", $domain));
+}
+
+function valid_local_part($local_part) {
+  // the local part always has an @ appended
+  return preg_match("/^[a-z]+[a-z0-9]*[\.|\-|_]?[a-z0-9]+@/i", $local_part));
+}
+
+
 // Check uid/gid used in invitation policy
 // We're pretty relaxed about what is entered 
 // here and only check some basic syntax
@@ -443,15 +486,24 @@
 									 'comment' => _('For automatic invitation handling') . '<br/>' .
 									 _("NOTE: For regular accounts to use this feature, give the 'calendar' user access to the Calendar folder") ),
 		  'title_0' => array( 'name' => _('Title') ) );
+
 $entries['alias'] = array( 'name' => _('Email Aliases'), 
 						   'type' => 'textarea',
 						   'validation' => 'checkuniquealias',
 						   'comment' => _('One address per line') );
+
 $entries['kolabdelegate'] =array( 'name' => _('Email-Delegates'),
 		'type' => 'textarea',
 		'validation' => 'checkdelegate',
 		'comment' => _('Others allowed to send emails with a "from" address of this account.') . '<br/>' .
 			_('One email address per line.') );
+
+$entries['kolabAllowSMTPRecipient'] =array( 'name' => _('Allowed Recipients'),
+                'type' => 'textarea',
+                'validation' => 'checksmtprecipient',
+                'comment' => _('restrict allowed recipients of SMTP messages') . '<br/>' .
+                        _('One entry per line.') );
+
 $entries['o_0'] = array( 'name' => _('Organisation') );
 $entries['ou_0'] = array( 'name' => _('Organisational Unit') );
 $entries['roomNumber_0'] = array( 'name' => _('Room Number') );





More information about the commits mailing list