2004-10-20 00:24:10 +02:00
< ? php
2005-02-11 16:34:56 +01:00
/* Copyright ( C ) 2003 , 2005 Rodolphe Quiedeville < rodolphe @ quiedeville . org >
2005-03-06 01:15:34 +01:00
* Copyright ( C ) 2003 Jean - Louis Bergamo < jlb @ j1b . org >
2007-10-10 01:15:25 +02:00
* Copyright ( C ) 2004 - 2007 Laurent Destailleur < eldy @ users . sourceforge . net >
2005-03-06 01:15:34 +01:00
* Copyright ( C ) 2004 Sebastien Di Cintio < sdicintio @ ressource - toi . org >
* Copyright ( C ) 2004 Benoit Mortier < benoit . mortier @ opensides . be >
2003-09-15 16:03:49 +02:00
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 2 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 59 Temple Place - Suite 330 , Boston , MA 02111 - 1307 , USA .
*
* $Id $
*/
2005-03-06 01:15:34 +01:00
/**
\defgroup adherent Module adherents
2004-08-14 14:21:24 +02:00
\brief Module pour g<EFBFBD> rer les adh<EFBFBD> rents d ' une association
*/
2005-01-14 19:46:23 +01:00
/**
2004-08-14 14:45:05 +02:00
\file htdocs / includes / modules / modAdherent . class . php
2004-08-15 14:40:18 +02:00
\ingroup adherent
2004-08-14 14:21:24 +02:00
\brief Fichier de description et activation du module adherents
*/
2007-10-10 01:15:25 +02:00
include_once ( DOL_DOCUMENT_ROOT . " /includes/modules/DolibarrModules.class.php " );
2003-09-15 16:03:49 +02:00
2005-09-04 20:58:06 +02:00
/**
\class modAdherent
2004-08-15 14:40:18 +02:00
\brief Classe de description et activation du module Adherent
*/
2003-11-15 18:42:11 +01:00
class modAdherent extends DolibarrModules
2003-09-15 16:03:49 +02:00
{
2005-09-04 20:58:06 +02:00
/**
* \brief Constructeur . Definit les noms , constantes et boites
* \param DB handler d ' acc<EFBFBD> s base
*/
function modAdherent ( $DB )
{
2007-05-21 03:49:37 +02:00
$this -> db = $DB ;
2006-01-22 19:31:56 +01:00
$this -> id = 'member' ; // Same value xxx than in file modXxx.class.php file
2005-09-04 20:58:06 +02:00
$this -> numero = 310 ;
2005-03-06 01:15:34 +01:00
2005-09-04 20:58:06 +02:00
$this -> family = " hr " ;
$this -> name = " Adh<EFBFBD> rents " ;
$this -> description = " Gestion des adh<64> rents d'une association " ;
$this -> version = 'dolibarr' ; // 'experimental' or 'dolibarr' or version
2005-10-22 15:45:24 +02:00
$this -> const_name = 'MAIN_MODULE_ADHERENT' ;
2006-03-31 20:03:11 +02:00
$this -> special = 2 ;
2005-09-04 20:58:06 +02:00
$this -> picto = 'user' ;
2005-05-14 16:22:08 +02:00
2005-09-04 20:58:06 +02:00
// Dir
//----
$this -> dirs = array ();
// Config pages
//-------------
2006-12-06 00:20:18 +01:00
$this -> config_page_url = array ( " adherent.php " );
2005-09-04 20:58:06 +02:00
// D<> pendances
//------------
$this -> depends = array ();
$this -> requiredby = array ();
2006-01-22 17:14:33 +01:00
$this -> langfiles = array ( " members " , " companies " );
2005-09-04 20:58:06 +02:00
// Constantes
//-----------
$this -> const = array ();
2007-02-10 15:47:32 +01:00
$this -> const [ 0 ] = array ( " ADHERENT_MAIL_RESIL " , " texte " , " Votre adhesion vient d'etre resiliee. \r \n Nous esperons vous revoir tres bientot " , " Mail de r<> siliation " );
$this -> const [ 1 ] = array ( " ADHERENT_MAIL_VALID " , " texte " , " Votre adhesion vient d'etre validee. \r \n Voici le rappel de vos coordonnees (toute information erronee entrainera la non validation de votre inscription) : \r \n \r \n %INFOS% \r \n \r \n Vous pouvez a tout moment, grace a votre login et mot de passe, modifier vos coordonnees a l'adresse suivante : \r \n %DOL_MAIN_URL_ROOT%/public/adherents/ " , " Mail de validation " );
$this -> const [ 3 ] = array ( " ADHERENT_MAIL_RESIL " , " texte " , " Votre adhesion vient d'etre resilie. \r \n Nous esperons vous revoir tres bientot " , " Mail de r<> siliation " );
2007-10-04 20:29:29 +02:00
$this -> const [ 5 ] = array ( " ADHERENT_MAIL_VALID_SUBJECT " , " chaine " , " Votre adhesion a ete validee " , " Sujet du mail de validation " );
$this -> const [ 6 ] = array ( " ADHERENT_MAIL_RESIL_SUBJECT " , " chaine " , " Resiliation de votre adhesion " , " Sujet du mail de resiliation " );
2005-09-04 20:58:06 +02:00
$this -> const [ 9 ] = array ( " ADHERENT_GLASNOST_SERVEUR " , " chaine " , " " , " serveur glasnost " );
2007-02-10 15:47:32 +01:00
$this -> const [ 10 ] = array ( " ADHERENT_MAILMAN_UNSUB_URL " , " chaine " , " http://lists.domain.com/cgi-bin/mailman/admin/%LISTE%/members?adminpw=%MAILMAN_ADMINPW%&user=%EMAIL% " , " Url de desinscription aux listes mailman " );
$this -> const [ 11 ] = array ( " ADHERENT_MAILMAN_URL " , " chaine " , " http://lists.domain.com/cgi-bin/mailman/admin/%LISTE%/members?adminpw=%MAILMAN_ADMINPW%&send_welcome_msg_to_this_batch=1&subscribees=%EMAIL% " , " Url pour les inscriptions mailman " );
2005-09-04 20:58:06 +02:00
$this -> const [ 12 ] = array ( " ADHERENT_MAILMAN_LISTS " , " chaine " , " " , " Listes auxquelles les nouveaux adh<64> rents sont inscris " );
$this -> const [ 13 ] = array ( " ADHERENT_GLASNOST_USER " , " chaine " , " " , " Administrateur glasnost " );
$this -> const [ 14 ] = array ( " ADHERENT_GLASNOST_PASS " , " chaine " , " " , " password de l'administrateur " );
$this -> const [ 15 ] = array ( " ADHERENT_USE_GLASNOST_AUTO " , " yesno " , " " , " inscription automatique a glasnost ? " );
$this -> const [ 16 ] = array ( " ADHERENT_USE_SPIP_AUTO " , " yesno " , " " , " Utilisation de SPIP automatiquement " );
2007-09-09 12:40:17 +02:00
$this -> const [ 17 ] = array ( " ADHERENT_SPIP_USER " , " chaine " , " " , " Utilisateur de connexion a la base spip " );
$this -> const [ 18 ] = array ( " ADHERENT_SPIP_PASS " , " chaine " , " " , " Mot de passe de connexion a la base spip " );
2005-09-04 20:58:06 +02:00
$this -> const [ 19 ] = array ( " ADHERENT_SPIP_SERVEUR " , " chaine " , " " , " serveur spip " );
$this -> const [ 20 ] = array ( " ADHERENT_SPIP_DB " , " chaine " , " " , " db spip " );
$this -> const [ 21 ] = array ( " ADHERENT_MAIL_FROM " , " chaine " , " " , " From des mails " );
2007-02-04 02:15:51 +01:00
$this -> const [ 22 ] = array ( " ADHERENT_MAIL_COTIS " , " texte " , " Bonjour %PRENOM%, \r \n Cet email confirme que votre cotisation a ete recue \r \n et enregistree " , " Mail de validation de cotisation " );
2007-02-10 15:47:32 +01:00
$this -> const [ 23 ] = array ( " ADHERENT_MAIL_COTIS_SUBJECT " , " chaine " , " Recu de votre cotisation " , " Sujet du mail de validation de cotisation " );
2005-09-04 20:58:06 +02:00
$this -> const [ 25 ] = array ( " ADHERENT_CARD_HEADER_TEXT " , " chaine " , " %ANNEE% " , " Texte imprime sur le haut de la carte adherent " );
2007-02-10 15:47:32 +01:00
$this -> const [ 26 ] = array ( " ADHERENT_CARD_FOOTER_TEXT " , " chaine " , " Association AZERTY " , " Texte imprime sur le bas de la carte adherent " );
2005-09-04 20:58:06 +02:00
$this -> const [ 27 ] = array ( " ADHERENT_CARD_TEXT " , " texte " , " %PRENOM% %NOM% \r \n Membre n<> %ID% \r \n %EMAIL% \r \n %ADRESSE% \r \n %CP% %VILLE% \r \n %PAYS% " , " Texte imprime sur la carte adherent " );
$this -> const [ 28 ] = array ( " ADHERENT_MAILMAN_ADMINPW " , " chaine " , " " , " Mot de passe Admin des liste mailman " );
$this -> const [ 29 ] = array ( " ADHERENT_MAILMAN_SERVER " , " chaine " , " " , " Serveur hebergeant les interfaces d'Admin des listes mailman " );
$this -> const [ 30 ] = array ( " ADHERENT_MAILMAN_LISTS_COTISANT " , " chaine " , " " , " Liste(s) auxquelles les nouveaux cotisants sont inscris automatiquement " );
$this -> const [ 31 ] = array ( " ADHERENT_BANK_USE_AUTO " , " yesno " , " " , " Insertion automatique des cotisation dans le compte banquaire " );
$this -> const [ 32 ] = array ( " ADHERENT_BANK_ACCOUNT " , " chaine " , " " , " ID du Compte banquaire utilise " );
$this -> const [ 33 ] = array ( " ADHERENT_BANK_CATEGORIE " , " chaine " , " " , " ID de la categorie banquaire des cotisations " );
$this -> const [ 34 ] = array ( " ADHERENT_ETIQUETTE_TYPE " , " chaine " , " L7163 " , " Type d etiquette (pour impression de planche d etiquette) " );
// Boites
//-------
$this -> boxes = array ();
// Permissions
//------------
$this -> rights = array ();
$this -> rights_class = 'adherent' ;
$r = 0 ;
// $this->rights[$r][0] Id permission (unique tous modules confondus)
// $this->rights[$r][1] Libell<6C> par d<> faut si traduction de cl<63> "PermissionXXX" non trouv<75> e (XXX = Id permission)
// $this->rights[$r][2] Non utilis<69>
// $this->rights[$r][3] 1=Permis par defaut, 0=Non permis par defaut
// $this->rights[$r][4] Niveau 1 pour nommer permission dans code
// $this->rights[$r][5] Niveau 2 pour nommer permission dans code
$r ++ ;
$this -> rights [ $r ][ 0 ] = 71 ;
$this -> rights [ $r ][ 1 ] = 'Lire les fiche adherents' ;
$this -> rights [ $r ][ 2 ] = 'r' ;
$this -> rights [ $r ][ 3 ] = 1 ;
$this -> rights [ $r ][ 4 ] = 'lire' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 72 ;
$this -> rights [ $r ][ 1 ] = 'Cr<43> er/modifier les adherents' ;
$this -> rights [ $r ][ 2 ] = 'w' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'creer' ;
2003-09-15 16:03:49 +02:00
2005-09-04 20:58:06 +02:00
$r ++ ;
$this -> rights [ $r ][ 0 ] = 74 ;
$this -> rights [ $r ][ 1 ] = 'Supprimer les adherents' ;
$this -> rights [ $r ][ 2 ] = 'd' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'supprimer' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 76 ;
$this -> rights [ $r ][ 1 ] = 'Exporter les adh<64> rents' ;
$this -> rights [ $r ][ 2 ] = 'r' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'export' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 75 ;
2006-06-25 22:46:32 +02:00
$this -> rights [ $r ][ 1 ] = 'Configurer les types et attributs des adherents' ;
2005-09-04 20:58:06 +02:00
$this -> rights [ $r ][ 2 ] = 'w' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'configurer' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 78 ;
$this -> rights [ $r ][ 1 ] = 'Lire les cotisations' ;
$this -> rights [ $r ][ 2 ] = 'r' ;
$this -> rights [ $r ][ 3 ] = 1 ;
$this -> rights [ $r ][ 4 ] = 'cotisation' ;
$this -> rights [ $r ][ 5 ] = 'lire' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 79 ;
2007-06-01 23:27:51 +02:00
$this -> rights [ $r ][ 1 ] = 'Cr<43> er/modifier/supprimer les cotisations' ;
2005-09-04 20:58:06 +02:00
$this -> rights [ $r ][ 2 ] = 'w' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'cotisation' ;
$this -> rights [ $r ][ 5 ] = 'creer' ;
// Exports
//--------
$r = 0 ;
// $this->export_code[$r] Code unique identifiant l'export (tous modules confondus)
// $this->export_label[$r] Libell<6C> par d<> faut si traduction de cl<63> "ExportXXX" non trouv<75> e (XXX = Code)
// $this->export_fields_sql[$r] Liste des champs exportables en codif sql
// $this->export_fields_name[$r] Liste des champs exportables en codif traduction
// $this->export_sql[$r] Requete sql qui offre les donn<6E> es <20> l'export
// $this->export_permission[$r] Liste des codes permissions requis pour faire l'export
$r ++ ;
2006-01-22 19:31:56 +01:00
$this -> export_code [ $r ] = $this -> id . '_' . $r ;
2007-05-21 03:49:37 +02:00
$this -> export_label [ $r ] = 'Adh<64> rents et adh<64> sions' ;
$this -> export_fields_array [ $r ] = array ( 'a.nom' => " Lastname " , 'a.prenom' => " Firstname " , 'a.login' => " Login " , 'a.morphy' => 'MorPhy' , 'a.adresse' => " Address " , 'a.cp' => " Zip " , 'a.ville' => " Town " , 'a.pays' => " Country " , 'a.phone' => " PhonePro " , 'a.phone_perso' => " PhonePerso " , 'a.phone_mobile' => " PhoneMobile " , 'a.email' => " Email " , 'a.naiss' => " Birthday " , 'a.statut' => " Status " , 'a.photo' => " Photo " , 'a.note' => " Note " , 'a.datec' => 'DateCreation' , 'a.datevalid' => 'DateValidation' , 'a.tms' => 'DateLastModification' , 'a.datefin' => 'DateEndSubscription' , 'ta.rowid' => 'MemberTypeId' , 'ta.libelle' => 'MemberTypeLabel' , 'c.dateadh' => 'DateSubscription' , 'c.cotisation' => 'Amount' );
$this -> export_entities_array [ $r ] = array ( 'a.nom' => " member " , 'a.prenom' => " member " , 'a.login' => " member " , 'a.morphy' => 'member' , 'a.adresse' => " member " , 'a.cp' => " member " , 'a.ville' => " member " , 'a.pays' => " member " , 'a.phone' => " member " , 'a.phone_perso' => " member " , 'a.phone_mobile' => " member " , 'a.email' => " member " , 'a.naiss' => " member " , 'a.statut' => " member " , 'a.photo' => " member " , 'a.note' => " member " , 'a.datec' => 'member' , 'a.datevalid' => 'member' , 'a.tms' => 'member' , 'a.datefin' => 'member' , 'ta.rowid' => 'member_type' , 'ta.libelle' => 'member_type' , 'c.dateadh' => 'subscription' , 'c.cotisation' => 'subscription' );
$this -> export_alias_array [ $r ] = array ( 'a.nom' => " lastname " , 'a.prenom' => " firstname " , 'a.login' => " login " , 'a.morphy' => 'morphy' , 'a.adresse' => " address " , 'a.cp' => " zip " , 'a.ville' => " town " , 'a.pays' => " country " , 'a.phone' => " phone " , 'a.phone_perso' => " phone_perso " , 'a.phone_mobile' => " phone_mobile " , 'a.email' => " email " , 'a.naiss' => " birthday " , 'a.statut' => " status " , 'a.photo' => 'photo' , 'a.note' => 'note' , 'a.datec' => 'datec' , 'a.datevalid' => 'datevalid' , 'a.tms' => 'datem' , 'a.datefin' => 'dateend' , 'ta.rowid' => 'type_id' , 'ta.libelle' => 'type_label' , 'c.dateadh' => 'date_subscription' , 'c.cotisation' => 'amount_subscription' );
// On compl<70> te avec champs options
$sql = 'SELECT name, label FROM ' . MAIN_DB_PREFIX . 'adherent_options_label' ;
$resql = $this -> db -> query ( $sql );
while ( $obj = $this -> db -> fetch_object ( $resql ))
{
$fieldname = 'ao.' . $obj -> name ;
$fieldlabel = ucfirst ( $obj -> label );
$this -> export_fields_array [ $r ][ $fieldname ] = $fieldlabel ;
$this -> export_entities_array [ $r ][ $fieldname ] = 'member' ;
$this -> export_alias_array [ $r ][ $fieldname ] = 'opt_' . $obj -> name ;
}
// Fin complement
$this -> export_sql [ $r ] = " select distinct " ;
2006-01-22 17:14:33 +01:00
$i = 0 ;
foreach ( $this -> export_alias_array [ $r ] as $key => $value )
{
if ( $i > 0 ) $this -> export_sql [ $r ] .= ', ' ;
else $i ++ ;
$this -> export_sql [ $r ] .= $key . ' as ' . $value ;
}
2007-05-21 03:49:37 +02:00
$this -> export_sql [ $r ] .= ' from (' . MAIN_DB_PREFIX . 'adherent as a, ' . MAIN_DB_PREFIX . 'adherent_type as ta)' ;
$this -> export_sql [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'adherent_options as ao ON a.rowid = ao.adhid' ;
$this -> export_sql [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'cotisation as c ON c.fk_adherent = a.rowid' ;
$this -> export_sql [ $r ] .= ' WHERE a.fk_adherent_type = ta.rowid' ;
2005-09-04 20:58:06 +02:00
$this -> export_permission [ $r ] = array ( array ( " adherent " , " export " ));
}
2004-11-23 21:04:19 +01:00
2005-09-04 20:58:06 +02:00
/**
* \brief Fonction appel<EFBFBD> e lors de l ' activation du module . Ins<EFBFBD> re en base les constantes , boites , permissions du module .
* D<EFBFBD> finit <EFBFBD> galement les r<EFBFBD> pertoires de donn<EFBFBD> es <EFBFBD> cr<EFBFBD> er pour ce module .
*/
function init ()
{
global $conf ;
// Permissions
$this -> remove ();
// Dir
$this -> dirs [ 0 ] = $conf -> adherent -> dir_output ;
$this -> dirs [ 1 ] = $conf -> adherent -> dir_output . " /photos " ;
$this -> dirs [ 2 ] = $conf -> adherent -> dir_export ;
$sql = array ();
return $this -> _init ( $sql );
}
/**
* \brief Fonction appel<EFBFBD> e lors de la d<EFBFBD> sactivation d ' un module .
* Supprime de la base les constantes , boites et permissions du module .
*/
function remove ()
{
2005-01-14 19:46:23 +01:00
$sql = array ();
2005-09-04 20:58:06 +02:00
2003-09-15 16:03:49 +02:00
return $this -> _remove ( $sql );
2005-09-04 20:58:06 +02:00
}
2003-09-15 16:03:49 +02:00
}
?>