dolibarr  7.0.0-beta
mailman.php
Go to the documentation of this file.
1 <?php
2 /* Copyright (C) 2003 Rodolphe Quiedeville <rodolphe@quiedeville.org>
3  * Copyright (C) 2003 Jean-Louis Bergamo <jlb@j1b.org>
4  * Copyright (C) 2004-2011 Laurent Destailleur <eldy@users.sourceforge.net>
5  * Copyright (C) 2004 Sebastien Di Cintio <sdicintio@ressource-toi.org>
6  * Copyright (C) 2004 Benoit Mortier <benoit.mortier@opensides.be>
7  * Copyright (C) 2005-2011 Regis Houssin <regis.houssin@capnetworks.com>
8  * Copyright (C) 2011-2013 Juanjo Menent <jmenent@2byte.es>
9  *
10  * This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 3 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with this program. If not, see <http://www.gnu.org/licenses/>.
22  */
23 
30 require '../main.inc.php';
31 require_once DOL_DOCUMENT_ROOT.'/core/lib/admin.lib.php';
32 require_once DOL_DOCUMENT_ROOT.'/core/lib/mailmanspip.lib.php';
33 require_once DOL_DOCUMENT_ROOT.'/categories/class/categorie.class.php';
34 
35 $langs->load("admin");
36 $langs->load("members");
37 $langs->load("mailmanspip");
38 
39 if (! $user->admin) accessforbidden();
40 
41 
42 $type=array('yesno','texte','chaine');
43 
44 $action = GETPOST('action','aZ09');
45 $testsubscribeemail = GETPOST("testsubscribeemail");
46 $testunsubscribeemail = GETPOST("testunsubscribeemail");
47 
48 /*
49  * Actions
50  */
51 
52 // Action mise a jour ou ajout d'une constante
53 if ($action == 'update' || $action == 'add')
54 {
55  foreach($_POST['constname'] as $key => $val)
56  {
57  $constname=$_POST["constname"][$key];
58  $constvalue=$_POST["constvalue"][$key];
59  $consttype=$_POST["consttype"][$key];
60  $constnote=$_POST["constnote"][$key];
61  $res=dolibarr_set_const($db,$constname,$constvalue,$type[$consttype],0,$constnote,$conf->entity);
62 
63  if (! $res > 0) $error++;
64  }
65 
66  if (! $error)
67  {
68  setEventMessages($langs->trans("SetupSaved"), null, 'mesgs');
69  }
70  else
71  {
72  setEventMessages($langs->trans("Error"), null, 'errors');
73  }
74 }
75 
76 // Action activation d'un sous module du module adherent
77 if ($action == 'set')
78 {
79  $result=dolibarr_set_const($db, $_GET["name"], $_GET["value"], '', 0, '', $conf->entity);
80  if ($result < 0)
81  {
82  dol_print_error($db);
83  }
84 }
85 
86 // Action desactivation d'un sous module du module adherent
87 if ($action == 'unset')
88 {
89  $result=dolibarr_del_const($db, $_GET["name"], $conf->entity);
90  if ($result < 0)
91  {
92  dol_print_error($db);
93  }
94 }
95 
96 if (($action == 'testsubscribe' || $action == 'testunsubscribe') && ! empty($conf->global->ADHERENT_USE_MAILMAN))
97 {
98  $email=GETPOST($action.'email');
99  if (! isValidEmail($email))
100  {
101  $langs->load("errors");
102  setEventMessages($langs->trans("ErrorBadEMail",$email), null, 'errors');
103  }
104  else
105  {
106  include_once DOL_DOCUMENT_ROOT.'/mailmanspip/class/mailmanspip.class.php';
107  $mailmanspip=new MailmanSpip($db);
108 
109  $object=new stdClass();
110  $object->email=$email;
111  $object->pass=$email;
112  /*$object->element='member';
113  $object->type='Preferred Partners'; */
114 
115  if ($action == 'testsubscribe')
116  {
117  $result=$mailmanspip->add_to_mailman($object);
118  if ($result < 0)
119  {
120  $error++;
121  setEventMessages($mailmanspip->error,$mailmanspip->errors,'errors');
122  }
123  else
124  {
125  setEventMessages($langs->trans("MailmanCreationSuccess"), null);
126  }
127  }
128  if ($action == 'testunsubscribe')
129  {
130  $result=$mailmanspip->del_to_mailman($object);
131  if ($result < 0)
132  {
133  $error++;
134  setEventMessages($mailmanspip->error,$mailmanspip->errors,'errors');
135  }
136  else
137  {
138  setEventMessages($langs->trans("MailmanDeletionSuccess"), null);
139  }
140  }
141  }
142 }
143 
144 
145 /*
146  * View
147  */
148 
149 $help_url='';
150 
151 llxHeader('',$langs->trans("MailmanSpipSetup"),$help_url);
152 
153 
154 $linkback='<a href="'.DOL_URL_ROOT.'/admin/modules.php">'.$langs->trans("BackToModuleList").'</a>';
155 print load_fiche_titre($langs->trans("MailmanSpipSetup"),$linkback,'title_setup');
156 
157 $head = mailmanspip_admin_prepare_head();
158 
159 
160 $var=true;
161 
162 if (! empty($conf->global->ADHERENT_USE_MAILMAN))
163 {
164  print '<form action="'.$_SERVER["PHP_SELF"].'" method="POST">';
165 
166  dol_fiche_head($head, 'mailman', $langs->trans("Setup"), 0, 'user');
167 
168  //$link=img_picto($langs->trans("Active"),'tick').' ';
169  $link='<a href="'.$_SERVER["PHP_SELF"].'?action=unset&value=0&name=ADHERENT_USE_MAILMAN">';
170  //$link.=$langs->trans("Disable");
171  $link.=img_picto($langs->trans("Activated"),'switch_on');
172  $link.='</a>';
173  // Edition des varibales globales
174  $constantes=array(
175  'ADHERENT_MAILMAN_ADMINPW',
176  'ADHERENT_MAILMAN_URL',
177  'ADHERENT_MAILMAN_UNSUB_URL',
178  'ADHERENT_MAILMAN_LISTS'
179  );
180 
181  print load_fiche_titre($langs->trans('MailmanTitle'), $link,'');
182 
183  print '<br>';
184 
185  // JQuery activity
186  print '<script type="text/javascript">
187  var i1=0;
188  var i2=0;
189  var i3=0;
190  jQuery(document).ready(function(){
191  jQuery("#exampleclick1").click(function(event){
192  if (i1 == 0) { jQuery("#example1").show(); i1=1; }
193  else if (i1 == 1) { jQuery("#example1").hide(); i1=0; }
194  });
195  jQuery("#exampleclick2").click(function(){
196  if (i2 == 0) { jQuery("#example2").show(); i2=1; }
197  else if (i2 == 1) { jQuery("#example2").hide(); i2=0; }
198  });
199  jQuery("#exampleclick3").click(function(){
200  if (i3 == 0) { jQuery("#example3").show(); i3=1; }
201  else if (i3 == 1) { jQuery("#example3").hide(); i3=0; }
202  });
203  });
204  </script>';
205 
206  form_constantes($constantes,2);
207 
208  print '*'.$langs->trans("FollowingConstantsWillBeSubstituted").'<br>';
209  print '%LISTE%, %MAILMAN_ADMINPW%, %EMAIL% <br>';
210 
211  dol_fiche_end();
212 
213  print '<div class="center"><input type="submit" class="button" value="'.$langs->trans("Update").'" name="update"></div>';
214 
215  print '</form>';
216 }
217 else
218 {
219  dol_fiche_head($head, 'mailman', $langs->trans("Setup"), 0, 'user');
220 
221  $link='<a href="'.$_SERVER["PHP_SELF"].'?action=set&value=1&name=ADHERENT_USE_MAILMAN">';
222  //$link.=img_$langs->trans("Activate")
223  $link.=img_picto($langs->trans("Disabled"),'switch_off');
224  $link.='</a>';
225  print load_fiche_titre($langs->trans('MailmanTitle'), $link,'');
226 
227  dol_fiche_end();
228 }
229 
230 
231 if (! empty($conf->global->ADHERENT_USE_MAILMAN))
232 {
233  print '<form action="'.$_SERVER["PHP_SELF"].'">';
234  print '<input type="hidden" name="action" value="testsubscribe">';
235  print $langs->trans("TestSubscribe").'<br>';
236  print $langs->trans("EMail").' <input type="email" class="flat" name="testsubscribeemail" value="'.GETPOST('testsubscribeemail').'"> <input class="button" type="submit" value="'.$langs->trans("Test").'"><br>';
237  print '</form>';
238  print '<form action="'.$_SERVER["PHP_SELF"].'">';
239  print '<input type="hidden" name="action" value="testunsubscribe">';
240  print $langs->trans("TestUnSubscribe").'<br>';
241  print $langs->trans("EMail").' <input type="email" class="flat" name="testunsubscribeemail" value="'.GETPOST('testunsubscribeemail').'"> <input class="button" type="submit" value="'.$langs->trans("Test").'"><br>';
242  print '</form>';
243 }
244 
245 
246 llxFooter();
247 
248 $db->close();
llxFooter()
Empty footer.
Definition: wrapper.php:58
img_picto($titlealt, $picto, $moreatt= '', $pictoisfullpath=false, $srconly=0, $notitle=0, $alt='', $morecss='')
Show picto whatever it's its name (generic function)
setEventMessages($mesg, $mesgs, $style='mesgs')
Set event messages in dol_events session object.
dol_fiche_head($links=array(), $active='0', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='')
Show tab header of a card.
dolibarr_set_const($db, $name, $value, $type='chaine', $visible=0, $note='', $entity=1)
Insert a parameter (key,value) into database (delete old key then insert it again).
Definition: admin.lib.php:485
dol_print_error($db='', $error='', $errors=null)
Affiche message erreur system avec toutes les informations pour faciliter le diagnostic et la remonte...
form_constantes($tableau, $strictw3c=0, $helptext='')
Show array with constants to edit.
Definition: admin.lib.php:1309
GETPOST($paramname, $check='none', $method=0, $filter=NULL, $options=NULL, $noreplace=0)
Return value of a param into GET or POST supervariable.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0)
Show a message to say access is forbidden and stop program Calling this function terminate execution ...
dolibarr_del_const($db, $name, $entity=1)
Effacement d'une constante dans la base de donnees.
Definition: admin.lib.php:410
dol_fiche_end($notab=0)
Show tab footer of a card.
load_fiche_titre($titre, $morehtmlright='', $picto='title_generic.png', $pictoisfullpath=0, $id=0, $morecssontable='', $morehtmlcenter='')
Load a title with picto.
llxHeader()
Empty header.
Definition: wrapper.php:46
print
Draft customers invoices.
Definition: index.php:91
Class to manage mailman and spip.
isValidEmail($address, $acceptsupervisorkey=0)
Return true if email syntax is ok.