+ function handler_aadmin(&$page, $lfull = null)
+ {
+ global $globals;
+
+ if (!$globals->asso('mail_domain') || is_null($lfull)) {
+ return PL_NOT_FOUND;
+ }
+ $page->changeTpl('xnetlists/alias-admin.tpl');
+
+ if (Env::has('add_member')) {
+ S::assert_xsrf_token();
+
+ $add = Env::t('add_member');
+ $user = User::getSilent($add);
+ if ($user) {
+ $add = $user->forlifeEmail();
+ } else if (!User::isForeignEmailAddress($add)) {
+ $add = null;
+ }
+ if (!empty($add)) {
+ XDB::execute('INSERT INTO virtual_redirect (vid, redirect)
+ SELECT vid, {?}
+ FROM virtual
+ WHERE alias = {?}', strtolower($add), $lfull);
+ $page->trigSuccess($add . ' ajouté.');
+ } else {
+ $page->trigError($add . " n'existe pas.");
+ }
+ }
+
+ if (Env::has('del_member')) {
+ S::assert_xsrf_token();
+ XDB::query(
+ "DELETE FROM virtual_redirect
+ USING virtual_redirect
+ INNER JOIN virtual USING(vid)
+ WHERE redirect={?} AND alias={?}", Env::v('del_member'), $lfull);
+ pl_redirect('alias/admin/'.$lfull);
+ }
+
+ global $globals;
+ $emails = XDB::fetchColumn('SELECT redirect
+ FROM virtual_redirect AS vr
+ INNER JOIN virtual AS v USING(vid)
+ WHERE v.alias = {?}
+ ORDER BY redirect', $lfull);
+ $mem = array();
+ foreach ($emails as $email) {
+ $user = User::getSilent($email);
+ if ($user) {
+ $mem[] = array('user' => $user, 'email' => $email);
+ } else {
+ $mem[] = array('email' => $email);
+ }
+ }
+ $page->assign('mem', $mem);
+ }
+
+ function handler_acreate(&$page)
+ {
+ global $globals;
+
+ if (!$globals->asso('mail_domain')) {
+ return PL_NOT_FOUND;
+ }
+ $page->changeTpl('xnetlists/alias-create.tpl');
+
+ if (!Post::has('submit')) {
+ return;
+ } else {
+ S::assert_xsrf_token();
+ }
+
+ if (!Post::has('liste')) {
+ $page->trigError('Le champs « adresse souhaitée » est vide.');
+ return;
+ }
+ $liste = Post::v('liste');
+ if (!preg_match("/^[a-zA-Z0-9\-\.]*$/", $liste)) {
+ $page->trigError('le nom de l\'alias ne doit contenir que des lettres,'
+ .' chiffres, tirets et points');
+ return;
+ }
+
+ $new = $liste.'@'.$globals->asso('mail_domain');
+ $res = XDB::query('SELECT COUNT(*) FROM virtual WHERE alias = {?}', $new);
+ $n = $res->fetchOneCell();
+ if ($n) {
+ $page->trigError('cet alias est déjà pris');
+ return;
+ }
+
+ XDB::query('INSERT INTO virtual (alias,type) VALUES({?}, "user")', $new);
+
+ pl_redirect("alias/admin/$new");
+ }
+