39require_once DOL_DOCUMENT_ROOT.
'/core/class/commonobject.class.php';
40require_once DOL_DOCUMENT_ROOT.
'/core/lib/date.lib.php';
41require_once DOL_DOCUMENT_ROOT.
'/categories/class/categorie.class.php';
42require_once DOL_DOCUMENT_ROOT.
'/core/class/commonpeople.class.php';
55 public $element =
'member';
60 public $table_element =
'adherent';
65 public $picto =
'member';
85 public $pass_indatabase;
90 public $pass_indatabase_crypted;
106 public $civility_code;
140 public $socialnetworks;
160 public $phone_mobile;
186 public $default_lang;
235 public $need_subscription;
258 public $first_subscription_date;
263 public $first_subscription_date_start;
268 public $first_subscription_date_end;
273 public $first_subscription_amount;
278 public $last_subscription_date;
283 public $last_subscription_date_start;
288 public $last_subscription_date_end;
293 public $last_subscription_amount;
298 public $subscriptions = array();
310 public $partnerships = array();
360 'rowid' => array(
'type' =>
'integer',
'label' =>
'TechnicalID',
'enabled' => 1,
'visible' => -1,
'notnull' => 1,
'position' => 10),
361 'ref' => array(
'type' =>
'varchar(30)',
'label' =>
'Ref',
'default' =>
'1',
'enabled' => 1,
'visible' => 1,
'notnull' => 1,
'position' => 12,
'index' => 1),
362 'entity' => array(
'type' =>
'integer',
'label' =>
'Entity',
'default' =>
'1',
'enabled' => 1,
'visible' => 3,
'notnull' => 1,
'position' => 15,
'index' => 1),
363 'ref_ext' => array(
'type' =>
'varchar(128)',
'label' =>
'RefExt',
'enabled' => 1,
'visible' => 0,
'position' => 20),
364 'civility' => array(
'type' =>
'varchar(6)',
'label' =>
'Civility',
'enabled' => 1,
'visible' => -1,
'position' => 25),
365 'lastname' => array(
'type' =>
'varchar(50)',
'label' =>
'Lastname',
'enabled' => 1,
'visible' => 1,
'position' => 30,
'showoncombobox' => 1),
366 'firstname' => array(
'type' =>
'varchar(50)',
'label' =>
'Firstname',
'enabled' => 1,
'visible' => 1,
'position' => 35,
'showoncombobox' => 1),
367 'login' => array(
'type' =>
'varchar(50)',
'label' =>
'Login',
'enabled' => 1,
'visible' => 1,
'position' => 40),
368 'pass' => array(
'type' =>
'varchar(50)',
'label' =>
'Pass',
'enabled' => 1,
'visible' => 3,
'position' => 45),
369 'pass_crypted' => array(
'type' =>
'varchar(128)',
'label' =>
'Pass crypted',
'enabled' => 1,
'visible' => 3,
'position' => 50),
370 'morphy' => array(
'type' =>
'varchar(3)',
'label' =>
'MemberNature',
'enabled' => 1,
'visible' => 1,
'notnull' => 1,
'position' => 55),
371 'fk_adherent_type' => array(
'type' =>
'integer',
'label' =>
'MemberType',
'enabled' => 1,
'visible' => 1,
'notnull' => 1,
'position' => 60),
372 'societe' => array(
'type' =>
'varchar(128)',
'label' =>
'Societe',
'enabled' => 1,
'visible' => 1,
'position' => 65,
'showoncombobox' => 2),
373 'fk_soc' => array(
'type' =>
'integer:Societe:societe/class/societe.class.php',
'label' =>
'ThirdParty',
'enabled' => 1,
'visible' => 1,
'position' => 70),
374 'address' => array(
'type' =>
'text',
'label' =>
'Address',
'enabled' => 1,
'visible' => -1,
'position' => 75),
375 'zip' => array(
'type' =>
'varchar(10)',
'label' =>
'Zip',
'enabled' => 1,
'visible' => -1,
'position' => 80),
376 'town' => array(
'type' =>
'varchar(50)',
'label' =>
'Town',
'enabled' => 1,
'visible' => -1,
'position' => 85),
377 'state_id' => array(
'type' =>
'integer',
'label' =>
'State',
'enabled' => 1,
'visible' => -1,
'position' => 90),
378 'country' => array(
'type' =>
'integer:Ccountry:core/class/ccountry.class.php',
'label' =>
'Country',
'enabled' => 1,
'visible' => 1,
'position' => 95),
379 'phone' => array(
'type' =>
'varchar(30)',
'label' =>
'Phone',
'enabled' => 1,
'visible' => -1,
'position' => 115),
380 'phone_perso' => array(
'type' =>
'varchar(30)',
'label' =>
'Phone perso',
'enabled' => 1,
'visible' => -1,
'position' => 120),
381 'phone_mobile' => array(
'type' =>
'varchar(30)',
'label' =>
'Phone mobile',
'enabled' => 1,
'visible' => -1,
'position' => 125),
382 'email' => array(
'type' =>
'varchar(255)',
'label' =>
'Email',
'enabled' => 1,
'visible' => 1,
'position' => 126),
383 'url' => array(
'type' =>
'varchar(255)',
'label' =>
'Url',
'enabled' => 1,
'visible' => -1,
'position' => 127),
384 'socialnetworks' => array(
'type' =>
'text',
'label' =>
'Socialnetworks',
'enabled' => 1,
'visible' => 3,
'position' => 128),
385 'birth' => array(
'type' =>
'date',
'label' =>
'DateOfBirth',
'enabled' => 1,
'visible' => -1,
'position' => 130),
386 'gender' => array(
'type' =>
'varchar(10)',
'label' =>
'Gender',
'enabled' => 1,
'visible' => -1,
'position' => 132),
387 'photo' => array(
'type' =>
'varchar(255)',
'label' =>
'Photo',
'enabled' => 1,
'visible' => -1,
'position' => 135),
388 'public' => array(
'type' =>
'smallint(6)',
'label' =>
'Public',
'enabled' => 1,
'visible' => 3,
'notnull' => 1,
'position' => 145),
389 'datefin' => array(
'type' =>
'datetime',
'label' =>
'DateEnd',
'enabled' => 1,
'visible' => 1,
'position' => 150),
390 'default_lang' => array(
'type' =>
'varchar(6)',
'label' =>
'Default lang',
'enabled' => 1,
'visible' => -1,
'position' => 153),
391 'note_public' => array(
'type' =>
'text',
'label' =>
'NotePublic',
'enabled' => 1,
'visible' => 0,
'position' => 155),
392 'note_private' => array(
'type' =>
'text',
'label' =>
'NotePrivate',
'enabled' => 1,
'visible' => 0,
'position' => 160),
393 'datevalid' => array(
'type' =>
'datetime',
'label' =>
'DateValidation',
'enabled' => 1,
'visible' => -1,
'position' => 165),
394 'datec' => array(
'type' =>
'datetime',
'label' =>
'DateCreation',
'enabled' => 1,
'visible' => -1,
'position' => 170),
395 'tms' => array(
'type' =>
'timestamp',
'label' =>
'DateModification',
'enabled' => 1,
'visible' => -1,
'notnull' => 1,
'position' => 175),
396 'fk_user_author' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserCreation',
'enabled' => 1,
'visible' => 3,
'position' => 180),
397 'fk_user_mod' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserModification',
'enabled' => 1,
'visible' => 3,
'position' => 185),
398 'fk_user_valid' => array(
'type' =>
'integer:User:user/class/user.class.php',
'label' =>
'UserValidation',
'enabled' => 1,
'visible' => 3,
'position' => 190),
399 'canvas' => array(
'type' =>
'varchar(32)',
'label' =>
'Canvas',
'enabled' => 1,
'visible' => 0,
'position' => 195),
400 'model_pdf' => array(
'type' =>
'varchar(255)',
'label' =>
'Model pdf',
'enabled' => 1,
'visible' => 0,
'position' => 800),
401 'import_key' => array(
'type' =>
'varchar(14)',
'label' =>
'ImportId',
'enabled' => 1,
'visible' => -2,
'position' => 805),
402 'statut' => array(
'type' =>
'smallint(6)',
'label' =>
'Statut',
'enabled' => 1,
'visible' => 1,
'notnull' => 1,
'position' => 1000,
'arrayofkeyval' => array(-1 =>
'Draft', 1 =>
'Validated', 0 =>
'MemberStatusResiliatedShort', -2 =>
'MemberStatusExcludedShort'))
435 $this->ismultientitymanaged = 1;
436 $this->isextrafieldmanaged = 1;
438 $this->array_options = array();
440 $this->fields[
'ref_ext'][
'visible'] =
getDolGlobalInt(
'MAIN_LIST_SHOW_REF_EXT');
463 public function send_an_email($text, $subject, $filename_list = array(), $mimetype_list = array(), $mimefilename_list = array(), $addr_cc =
"", $addr_bcc =
"", $deliveryreceipt = 0, $msgishtml = -1, $errors_to =
'', $moreinheader =
'')
466 dol_syslog(
'Warning using deprecated Adherent::send_an_email', LOG_WARNING);
468 return $this->
sendEmail($text, $subject, $filename_list, $mimetype_list, $mimefilename_list, $addr_cc, $addr_bcc, $deliveryreceipt, $msgishtml, $errors_to, $moreinheader);
488 public function sendEmail($text, $subject, $filename_list = array(), $mimetype_list = array(), $mimefilename_list = array(), $addr_cc =
"", $addr_bcc =
"", $deliveryreceipt = 0, $msgishtml = -1, $errors_to =
'', $moreinheader =
'')
490 global
$conf, $langs;
493 if ($msgishtml == -1) {
500 dol_syslog(
'sendEmail msgishtml='.$msgishtml);
511 $trackid =
'mem'.$this->id;
514 include_once DOL_DOCUMENT_ROOT.
'/core/class/CMailFile.class.php';
515 $mailfile =
new CMailFile($subjecttosend, (
string) $this->
email, $from, $texttosend, $filename_list, $mimetype_list, $mimefilename_list, $addr_cc, $addr_bcc, $deliveryreceipt, $msgishtml,
'',
'', $trackid, $moreinheader);
516 if ($mailfile->sendfile()) {
519 $this->error = $langs->trans(
"ErrorFailedToSendMail", $from, (
string) $this->email).
'. '.$mailfile->error;
536 $photo = isset($this->photo) ? $this->photo :
'';
537 $login = isset($this->login) ? $this->login :
'';
538 $type = isset($this->
type) ? $this->
type :
'';
539 $pass = isset($this->pass) ? $this->pass :
'';
547 if ($this->civility_id) {
548 $infos .= $langs->transnoentities(
"UserTitle").
": ".$this->
getCivilityLabel().
"\n";
550 $infos .= $langs->transnoentities(
"Id").
": ".$this->
id.
"\n";
551 $infos .= $langs->transnoentities(
"Ref").
": ".$this->
ref.
"\n";
552 $infos .= $langs->transnoentities(
"Lastname").
": ".$this->lastname.
"\n";
553 $infos .= $langs->transnoentities(
"Firstname").
": ".$this->firstname.
"\n";
554 $infos .= $langs->transnoentities(
"Company").
": ".$this->company.
"\n";
555 $infos .= $langs->transnoentities(
"Address").
": ".$this->
address.
"\n";
556 $infos .= $langs->transnoentities(
"Zip").
": ".$this->zip.
"\n";
557 $infos .= $langs->transnoentities(
"Town").
": ".$this->town.
"\n";
558 $infos .= $langs->transnoentities(
"Country").
": ".$this->country.
"\n";
559 $infos .= $langs->transnoentities(
"EMail").
": ".$this->
email.
"\n";
560 $infos .= $langs->transnoentities(
"PhonePro").
": ".$this->phone.
"\n";
561 $infos .= $langs->transnoentities(
"PhonePerso").
": ".$this->phone_perso.
"\n";
562 $infos .= $langs->transnoentities(
"PhoneMobile").
": ".$this->phone_mobile.
"\n";
564 $infos .= $langs->transnoentities(
"Login").
": ".$login.
"\n";
565 $infos .= $langs->transnoentities(
"Password").
": ".$pass.
"\n";
567 $infos .= $langs->transnoentities(
"Birthday").
": ".$birthday.
"\n";
568 $infos .= $langs->transnoentities(
"Photo").
": ".$photo.
"\n";
569 $infos .= $langs->transnoentities(
"Public").
": ".
yn($this->
public);
572 $substitutionarray = array(
573 '__ID__' => $this->
id,
574 '__REF__' => $this->
ref,
575 '__MEMBER_ID__' => $this->
id,
577 '__FIRSTNAME__' => $msgishtml ?
dol_htmlentitiesbr($this->firstname) : ($this->firstname ? $this->firstname :
''),
578 '__LASTNAME__' => $msgishtml ?
dol_htmlentitiesbr($this->lastname) : ($this->lastname ? $this->lastname :
''),
580 '__COMPANY__' => $msgishtml ?
dol_htmlentitiesbr((
string) $this->company) : ($this->company ? $this->company :
''),
582 '__ZIP__' => $msgishtml ?
dol_htmlentitiesbr((
string) $this->zip) : ($this->zip ? $this->zip :
''),
583 '__TOWN__' => $msgishtml ?
dol_htmlentitiesbr((
string) $this->town) : ($this->town ? $this->town :
''),
584 '__COUNTRY__' => $msgishtml ?
dol_htmlentitiesbr($this->country) : ($this->country ? $this->country :
''),
586 '__BIRTH__' => $msgishtml ?
dol_htmlentitiesbr($birthday) : ($birthday ? $birthday :
''),
590 '__PHONE__' => $msgishtml ?
dol_htmlentitiesbr($this->phone) : ($this->phone ? $this->phone :
''),
591 '__PHONEPRO__' => $msgishtml ?
dol_htmlentitiesbr($this->phone_perso) : ($this->phone_perso ? $this->phone_perso :
''),
592 '__PHONEMOBILE__' => $msgishtml ?
dol_htmlentitiesbr($this->phone_mobile) : ($this->phone_mobile ? $this->phone_mobile :
''),
616 $morphy = $this->morphy;
620 $labeltoshowm = $langs->trans(
"Moral");
621 $labeltoshowp = $langs->trans(
"Physical");
622 if ($morphy ==
'phy') {
623 $labeltoshow = $labeltoshowp;
624 if ($addbadge == 2) {
630 $s .=
'<span class="member-individual-back paddingleftimp paddingrightimp" title="'.$langs->trans(
"Physical").
'">'.$labeltoshow.
'</span>';
632 if ($morphy ==
'mor') {
633 $labeltoshow = $labeltoshowm;
634 if ($addbadge == 2) {
640 $s .=
'<span class="member-company-back paddingleftimp paddingrightimp" title="'.$langs->trans(
"Moral").
'">'.$labeltoshow.
'</span>';
643 if ($morphy ==
'phy') {
644 $s = $langs->trans(
"Physical");
645 } elseif ($morphy ==
'mor') {
646 $s = $langs->trans(
"Moral");
660 public function create($user, $notrigger = 0)
662 global
$conf, $langs, $mysoc;
669 if (isset($this->import_key)) {
670 $this->import_key = trim($this->import_key);
675 $langs->load(
"errors");
676 $this->error = $langs->trans(
"ErrorBadEMail", (
string) $this->email);
683 if (empty($this->login)) {
684 $this->error = $langs->trans(
"ErrorWrongValueForParameterX",
"Login");
695 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.
"adherent";
696 $sql .=
" (ref, datec, login, fk_user_author, fk_user_mod, fk_user_valid, morphy, fk_adherent_type, entity, import_key, ip)";
699 $sql .=
", '".$this->db->idate($this->datec).
"'";
700 $sql .=
", ".($this->login ?
"'".$this->db->escape($this->login).
"'" :
"null");
701 $sql .=
", ".($user->id > 0 ? $user->id :
"null");
702 $sql .=
", null, null, '".$this->db->escape($this->morphy).
"'";
703 $sql .=
", ".((int) $this->
typeid);
704 $sql .=
", ".((int) $this->entity);
705 $sql .=
", ".(!empty($this->import_key) ?
"'".$this->db->escape($this->import_key).
"'" :
"null");
706 $sql .=
", ".(!empty($this->ip) ?
"'".$this->db->escape($this->ip).
"'" :
"null");
709 dol_syslog(get_class($this).
"::create", LOG_DEBUG);
710 $result = $this->db->query($sql);
712 $id = $this->db->last_insert_id(MAIN_DB_PREFIX.
"adherent");
717 $this->
ref = (string) $id;
722 require_once $modfile;
724 $modCodeMember =
new $modname();
725 '@phan-var-force ModeleNumRefMembers $modCodeMember';
727 $this->
ref = $modCodeMember->getNextValue($mysoc, $this);
735 $result = $this->
update($user, 1, 1, 0, 0,
'add');
737 $this->db->rollback();
742 if ($this->user_id) {
744 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"user SET";
745 $sql .=
" fk_member = ".((int) $this->
id);
746 $sql .=
" WHERE rowid = ".((int) $this->user_id);
747 dol_syslog(get_class($this).
"::create", LOG_DEBUG);
748 $resql = $this->db->query($sql);
750 $this->error =
'Failed to update user to make link with member';
751 $this->db->rollback();
765 if (count($this->errors)) {
766 dol_syslog(get_class($this).
"::create ".implode(
',', $this->errors), LOG_ERR);
767 $this->db->rollback();
774 $this->error =
'Failed to get last insert id';
775 dol_syslog(get_class($this).
"::create ".$this->error, LOG_ERR);
776 $this->db->rollback();
780 $this->error = $this->db->error();
781 $this->db->rollback();
798 public function update($user, $notrigger = 0, $nosyncuser = 0, $nosyncuserpass = 0, $nosyncthirdparty = 0, $action =
'update')
800 global $langs, $hookmanager;
802 require_once DOL_DOCUMENT_ROOT.
'/core/lib/functions2.lib.php';
804 if (empty($this->country_id) && !empty($this->country_code)) {
805 $country_id =
getCountry($this->country_code,
'3');
806 $this->country_id = is_int($country_id) ? $country_id : 0;
812 dol_syslog(get_class($this).
"::update notrigger=".$notrigger.
", nosyncuser=".$nosyncuser.
", nosyncuserpass=".$nosyncuserpass.
" nosyncthirdparty=".$nosyncthirdparty.
", email=".$this->email);
815 $this->lastname = trim($this->lastname) ? trim($this->lastname) : trim($this->lastname);
816 $this->firstname = trim($this->firstname) ? trim($this->firstname) : trim($this->firstname);
817 $this->gender = trim($this->gender);
825 $this->url = $this->url ?
clean_url($this->url, 0) :
'';
829 $langs->load(
"errors");
830 $this->error = $langs->trans(
"ErrorBadEMail", (
string) $this->email);
836 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"adherent SET";
837 $sql .=
" ref = '".$this->db->escape($this->
ref).
"'";
838 $sql .=
", civility = ".($this->civility_id ?
"'".$this->db->escape($this->civility_id).
"'" :
"null");
839 $sql .=
", firstname = ".($this->firstname ?
"'".$this->db->escape($this->firstname).
"'" :
"null");
840 $sql .=
", lastname = ".($this->lastname ?
"'".$this->db->escape($this->lastname).
"'" :
"null");
841 $sql .=
", gender = ".($this->gender != -1 ?
"'".$this->db->escape($this->gender).
"'" :
"null");
842 $sql .=
", login = ".($this->login ?
"'".$this->db->escape($this->login).
"'" :
"null");
843 $sql .=
", societe = ".($this->company ?
"'".$this->db->escape($this->company).
"'" : ($this->societe ?
"'".$this->db->escape($this->societe).
"'" :
"null"));
845 $sql .=
", fk_soc = ".($this->socid > 0 ? (int) $this->socid :
"null");
847 $sql .=
", address = ".($this->address ?
"'".$this->db->escape($this->
address).
"'" :
"null");
848 $sql .=
", zip = ".($this->zip ?
"'".$this->db->escape($this->zip).
"'" :
"null");
849 $sql .=
", town = ".($this->town ?
"'".$this->db->escape($this->town).
"'" :
"null");
850 $sql .=
", country = ".($this->country_id > 0 ? (int) $this->country_id :
"null");
851 $sql .=
", state_id = ".($this->state_id > 0 ? (int) $this->state_id :
"null");
852 $sql .=
", email = '".$this->db->escape((
string) $this->email).
"'";
853 $sql .=
", url = ".(!empty($this->url) ?
"'".$this->db->escape($this->url).
"'" :
"null");
854 $sql .=
", socialnetworks = ".($this->socialnetworks ?
"'".$this->db->escape(json_encode($this->socialnetworks)).
"'" :
"null");
855 $sql .=
", phone = ".($this->phone ?
"'".$this->db->escape($this->phone).
"'" :
"null");
856 $sql .=
", phone_perso = ".($this->phone_perso ?
"'".$this->db->escape($this->phone_perso).
"'" :
"null");
857 $sql .=
", phone_mobile = ".($this->phone_mobile ?
"'".$this->db->escape($this->phone_mobile).
"'" :
"null");
858 $sql .=
", note_private = ".($this->note_private ?
"'".$this->db->escape($this->note_private).
"'" :
"null");
859 $sql .=
", note_public = ".($this->note_public ?
"'".$this->db->escape($this->note_public).
"'" :
"null");
860 $sql .=
", photo = ".($this->photo ?
"'".$this->db->escape($this->photo).
"'" :
"null");
861 $sql .=
", public = ".(int) $this->
public;
862 $sql .=
", statut = ".(int) $this->statut;
863 $sql .=
", default_lang = ".(!empty($this->default_lang) ?
"'".$this->db->escape($this->default_lang).
"'" :
"null");
864 $sql .=
", fk_adherent_type = ".(int) $this->
typeid;
865 $sql .=
", morphy = '".$this->db->escape($this->morphy).
"'";
866 $sql .=
", birth = ".($this->birth ?
"'".$this->db->idate($this->birth).
"'" :
"null");
868 if ($this->datefin) {
869 $sql .=
", datefin = '".$this->db->idate($this->datefin).
"'";
871 if ($this->datevalid) {
872 $sql .=
", datevalid = '".$this->db->idate($this->datevalid).
"'";
874 $sql .=
", fk_user_mod = ".($user->id > 0 ? $user->id :
'null');
875 $sql .=
" WHERE rowid = ".((int) $this->
id);
878 '@phan-var-force Adherent $oldcopy';
879 if (!empty($this->oldcopy) && $this->
typeid != $this->oldcopy->typeid) {
880 $sql2 =
"SELECT libelle as label";
881 $sql2 .=
" FROM ".MAIN_DB_PREFIX.
"adherent_type";
882 $sql2 .=
" WHERE rowid = ".((int) $this->
typeid);
883 $resql2 = $this->db->query($sql2);
885 while ($obj = $this->db->fetch_object($resql2)) {
886 $this->
type = $obj->label;
891 dol_syslog(get_class($this).
"::update update member", LOG_DEBUG);
892 $resql = $this->db->query($sql);
894 unset($this->country_code);
895 unset($this->country);
896 unset($this->state_code);
899 $nbrowsaffected += $this->db->affected_rows($resql);
912 if (!$error && $this->pass) {
913 dol_syslog(get_class($this).
"::update update password");
914 if ($this->pass != $this->pass_indatabase && $this->pass != $this->pass_indatabase_crypted) {
918 $result = $this->
setPassword($user, $this->pass, $isencrypted, $notrigger, $nosyncuserpass);
919 if (!$nbrowsaffected) {
927 dol_syslog(get_class($this).
"::update update link to user");
928 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"user SET fk_member = NULL WHERE fk_member = ".((int) $this->
id);
929 dol_syslog(get_class($this).
"::update", LOG_DEBUG);
930 $resql = $this->db->query($sql);
932 $this->error = $this->db->error();
933 $this->db->rollback();
937 if ($this->user_id > 0) {
938 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"user SET fk_member = ".((int) $this->
id).
" WHERE rowid = ".((int) $this->user_id);
939 dol_syslog(get_class($this).
"::update", LOG_DEBUG);
940 $resql = $this->db->query($sql);
942 $this->error = $this->db->error();
943 $this->db->rollback();
949 if (!$error && $nbrowsaffected) {
951 if (!$error && $this->user_id > 0 && !$nosyncuser) {
952 require_once DOL_DOCUMENT_ROOT.
'/user/class/user.class.php';
954 dol_syslog(get_class($this).
"::update update linked user");
956 $luser =
new User($this->db);
957 $result = $luser->fetch($this->user_id);
962 $luser->login = $this->login;
965 $luser->ref = $this->ref;
966 $luser->civility_id = $this->civility_id;
967 $luser->firstname = $this->firstname;
968 $luser->lastname = $this->lastname;
969 $luser->gender = $this->gender;
970 $luser->pass = isset($this->pass) ? $this->pass :
'';
973 $luser->birth = $this->birth;
975 $luser->address = $this->address;
976 $luser->zip = $this->zip;
977 $luser->town = $this->town;
978 $luser->country_id = $this->country_id;
979 $luser->state_id = $this->state_id;
981 $luser->email = $this->email;
982 $luser->socialnetworks = $this->socialnetworks;
983 $luser->office_phone = $this->phone;
984 $luser->user_mobile = $this->phone_mobile;
986 $luser->lang = $this->default_lang;
988 $luser->fk_member = $this->id;
990 $result = $luser->update($user, 0, 1, 1);
992 $this->error = $luser->error;
993 dol_syslog(get_class($this).
"::update ".$this->error, LOG_ERR);
997 $this->error = $luser->error;
1003 if (!$error && $this->fk_soc > 0 && !$nosyncthirdparty) {
1004 require_once DOL_DOCUMENT_ROOT.
'/societe/class/societe.class.php';
1006 dol_syslog(get_class($this).
"::update update linked thirdparty");
1010 $lthirdparty =
new Societe($this->db);
1011 $result = $lthirdparty->fetch($this->fk_soc);
1014 $lthirdparty->address = $this->address;
1015 $lthirdparty->zip = $this->zip;
1016 $lthirdparty->town = $this->town;
1017 $lthirdparty->email = $this->email;
1018 $lthirdparty->socialnetworks = $this->socialnetworks;
1019 $lthirdparty->phone = $this->phone;
1020 $lthirdparty->state_id = $this->state_id;
1021 $lthirdparty->country_id = $this->country_id;
1023 $lthirdparty->default_lang = $this->default_lang;
1025 $result = $lthirdparty->update($this->fk_soc, $user, 0, 1, 1,
'update');
1028 $this->error = $lthirdparty->error;
1029 $this->errors = $lthirdparty->errors;
1030 dol_syslog(get_class($this).
"::update ".$this->error, LOG_ERR);
1033 } elseif ($result < 0) {
1034 $this->error = $lthirdparty->error;
1040 if (!$error && !$notrigger) {
1050 $this->db->commit();
1051 return $nbrowsaffected;
1053 $this->db->rollback();
1057 $this->db->rollback();
1058 $this->error = $this->db->lasterror();
1078 $sql =
"SELECT rowid, datec as dateop, dateadh as datedeb, datef as datefin";
1079 $sql .=
" FROM ".MAIN_DB_PREFIX.
"subscription";
1080 $sql .=
" WHERE fk_adherent = ".((int) $this->
id);
1081 $sql .=
" ORDER by dateadh DESC";
1083 dol_syslog(get_class($this).
"::update_end_date", LOG_DEBUG);
1084 $resql = $this->db->query($sql);
1086 $obj = $this->db->fetch_object($resql);
1087 $dateop = $this->db->jdate($obj->dateop);
1088 $datedeb = $this->db->jdate($obj->datedeb);
1089 $datefin = $this->db->jdate($obj->datefin);
1091 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"adherent SET";
1092 $sql .=
" datefin=".($datefin !=
'' ?
"'".$this->db->idate($datefin).
"'" :
"null");
1093 $sql .=
" WHERE rowid = ".((int) $this->
id);
1095 dol_syslog(get_class($this).
"::update_end_date", LOG_DEBUG);
1096 $resql = $this->db->query($sql);
1098 $this->last_subscription_date = $dateop;
1099 $this->last_subscription_date_start = $datedeb;
1100 $this->last_subscription_date_end = $datefin;
1101 $this->datefin = $datefin;
1102 $this->db->commit();
1105 $this->db->rollback();
1109 $this->error = $this->db->lasterror();
1110 $this->db->rollback();
1122 public function delete($user, $notrigger = 0)
1133 if (!$error && !$notrigger) {
1143 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"categorie_member WHERE fk_member = ".((int) $rowid);
1144 dol_syslog(get_class($this).
"::delete", LOG_DEBUG);
1145 $resql = $this->db->query($sql);
1148 $this->error .= $this->db->lasterror();
1154 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"subscription WHERE fk_adherent = ".((int) $rowid);
1155 dol_syslog(get_class($this).
"::delete", LOG_DEBUG);
1156 $resql = $this->db->query($sql);
1159 $this->error .= $this->db->lasterror();
1169 $this->error .= $this->db->lasterror();
1180 dol_syslog(get_class($this).
"::delete erreur ".$errorflag.
" ".$this->error, LOG_ERR);
1186 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"adherent WHERE rowid = ".((int) $rowid);
1187 dol_syslog(get_class($this).
"::delete", LOG_DEBUG);
1188 $resql = $this->db->query($sql);
1191 $this->error .= $this->db->lasterror();
1197 $this->db->commit();
1200 $this->db->rollback();
1216 public function setPassword($user, $password =
'', $isencrypted = 0, $notrigger = 0, $nosyncuser = 0)
1218 global
$conf, $langs;
1222 dol_syslog(get_class($this).
"::setPassword user=".$user->id.
" password=".preg_replace(
'/./i',
'*', $password).
" isencrypted=".$isencrypted);
1226 require_once DOL_DOCUMENT_ROOT.
'/core/lib/security2.lib.php';
1231 $password_crypted =
dol_hash($password);
1233 $password_indatabase =
'';
1234 if (!$isencrypted) {
1235 $password_indatabase = $password;
1241 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"adherent";
1242 $sql .=
" SET pass_crypted = '".$this->db->escape($password_crypted).
"'";
1244 $sql .=
", pass = null";
1246 $sql .=
", pass = '".$this->db->escape($password_indatabase).
"'";
1248 $sql .=
" WHERE rowid = ".((int) $this->
id);
1251 dol_syslog(get_class($this).
"::setPassword", LOG_DEBUG);
1252 $result = $this->db->query($sql);
1254 $nbaffectedrows = $this->db->affected_rows($result);
1256 if ($nbaffectedrows) {
1257 $this->pass = $password;
1258 $this->pass_indatabase = $password_indatabase;
1259 $this->pass_indatabase_crypted = $password_crypted;
1261 if ($this->user_id && !$nosyncuser) {
1262 require_once DOL_DOCUMENT_ROOT.
'/user/class/user.class.php';
1266 $luser =
new User($this->db);
1267 $result = $luser->fetch($this->user_id);
1270 $result = $luser->setPassword($user, $this->pass, 0, 0, 1);
1271 if (is_int($result) && $result < 0) {
1272 $this->error = $luser->error;
1273 dol_syslog(get_class($this).
"::setPassword ".$this->error, LOG_ERR);
1277 $this->error = $luser->error;
1282 if (!$error && !$notrigger) {
1284 $result = $this->
call_trigger(
'MEMBER_NEW_PASSWORD', $user);
1287 $this->db->rollback();
1293 $this->db->commit();
1296 $this->db->rollback();
1300 $this->db->rollback();
1315 global
$conf, $langs;
1320 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"user SET fk_member = NULL WHERE fk_member = ".((int) $this->
id);
1321 dol_syslog(get_class($this).
"::setUserId", LOG_DEBUG);
1322 $resql = $this->db->query($sql);
1324 $this->error = $this->db->error();
1325 $this->db->rollback();
1331 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"user SET fk_member = ".((int) $this->
id);
1332 $sql .=
" WHERE rowid = ".((int) $userid);
1333 dol_syslog(get_class($this).
"::setUserId", LOG_DEBUG);
1334 $resql = $this->db->query($sql);
1336 $this->error = $this->db->error();
1337 $this->db->rollback();
1342 $this->db->commit();
1356 global
$conf, $langs;
1361 if ($thirdpartyid > 0) {
1362 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"adherent SET fk_soc = null";
1363 $sql .=
" WHERE fk_soc = ".((int) $thirdpartyid);
1364 $sql .=
" AND entity = ".$conf->entity;
1365 dol_syslog(get_class($this).
"::setThirdPartyId", LOG_DEBUG);
1366 $resql = $this->db->query($sql);
1370 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"adherent SET fk_soc = ".($thirdpartyid > 0 ? (int) $thirdpartyid :
'null');
1371 $sql .=
" WHERE rowid = ".((int) $this->
id);
1373 dol_syslog(get_class($this).
"::setThirdPartyId", LOG_DEBUG);
1374 $resql = $this->db->query($sql);
1376 $this->db->commit();
1379 $this->error = $this->db->error();
1380 $this->db->rollback();
1398 $sql =
"SELECT rowid FROM ".MAIN_DB_PREFIX.
"adherent";
1399 $sql .=
" WHERE login='".$this->db->escape($login).
"'";
1400 $sql .=
" AND entity = ".$conf->entity;
1402 $resql = $this->db->query($sql);
1404 if ($this->db->num_rows($resql)) {
1405 $obj = $this->db->fetch_object($resql);
1406 $this->
fetch($obj->rowid);
1426 $sql =
"SELECT rowid FROM ".MAIN_DB_PREFIX.
"adherent";
1427 $sql .=
" WHERE firstname='".$this->db->escape($firstname).
"'";
1428 $sql .=
" AND lastname='".$this->db->escape($lastname).
"'";
1429 $sql .=
" AND entity = ".$conf->entity;
1431 $resql = $this->db->query($sql);
1433 if ($this->db->num_rows($resql)) {
1434 $obj = $this->db->fetch_object($resql);
1435 $this->
fetch($obj->rowid);
1453 public function fetch($rowid, $ref =
'', $fk_soc = 0, $ref_ext =
'', $fetch_optionals =
true, $fetch_subscriptions =
true)
1457 $sql =
"SELECT d.rowid, d.ref, d.ref_ext, d.civility as civility_code, d.gender, d.firstname, d.lastname,";
1458 $sql .=
" d.societe as company, d.fk_soc, d.statut, d.public, d.address, d.zip, d.town, d.note_private,";
1459 $sql .=
" d.note_public,";
1460 $sql .=
" d.email, d.url, d.socialnetworks, d.phone, d.phone_perso, d.phone_mobile, d.login, d.pass, d.pass_crypted,";
1461 $sql .=
" d.photo, d.fk_adherent_type, d.morphy, d.entity,";
1462 $sql .=
" d.datec as datec,";
1463 $sql .=
" d.tms as datem,";
1464 $sql .=
" d.datefin as datefin, d.default_lang,";
1465 $sql .=
" d.birth as birthday,";
1466 $sql .=
" d.datevalid as datev,";
1467 $sql .=
" d.country,";
1468 $sql .=
" d.state_id,";
1469 $sql .=
" d.model_pdf,";
1470 $sql .=
" c.rowid as country_id, c.code as country_code, c.label as country,";
1471 $sql .=
" dep.nom as state, dep.code_departement as state_code,";
1472 $sql .=
" t.libelle as type, t.subscription as subscription,";
1473 $sql .=
" u.rowid as user_id, u.login as user_login";
1474 $sql .=
" FROM ".MAIN_DB_PREFIX.
"adherent_type as t, ".MAIN_DB_PREFIX.
"adherent as d";
1475 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_country as c ON d.country = c.rowid";
1476 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_departements as dep ON d.state_id = dep.rowid";
1477 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"user as u ON d.rowid = u.fk_member";
1478 $sql .=
" WHERE d.fk_adherent_type = t.rowid";
1480 $sql .=
" AND d.rowid=".((int) $rowid);
1481 } elseif ($ref || $fk_soc) {
1482 $sql .=
" AND d.entity IN (".getEntity(
'adherent').
")";
1484 $sql .=
" AND d.ref='".$this->db->escape($ref).
"'";
1485 } elseif ($fk_soc > 0) {
1486 $sql .=
" AND d.fk_soc=".((int) $fk_soc);
1488 } elseif ($ref_ext) {
1489 $sql .=
" AND d.ref_ext='".$this->db->escape($ref_ext).
"'";
1492 dol_syslog(get_class($this).
"::fetch", LOG_DEBUG);
1493 $resql = $this->db->query($sql);
1495 if ($this->db->num_rows($resql)) {
1496 $obj = $this->db->fetch_object($resql);
1498 $this->entity = $obj->entity;
1499 $this->
id = $obj->rowid;
1500 $this->
ref = $obj->ref;
1501 $this->ref_ext = $obj->ref_ext;
1503 $this->civility_id = $obj->civility_code;
1504 $this->civility_code = $obj->civility_code;
1505 $this->civility = $obj->civility_code ? ($langs->trans(
"Civility".$obj->civility_code) !=
"Civility".$obj->civility_code ? $langs->trans(
"Civility".$obj->civility_code) : $obj->civility_code) :
'';
1507 $this->firstname = $obj->firstname;
1508 $this->lastname = $obj->lastname;
1509 $this->gender = $obj->gender;
1510 $this->login = $obj->login;
1511 $this->societe = $obj->company;
1512 $this->company = $obj->company;
1513 $this->socid = $obj->fk_soc;
1514 $this->fk_soc = $obj->fk_soc;
1515 $this->
address = $obj->address;
1516 $this->zip = $obj->zip;
1517 $this->town = $obj->town;
1519 $this->pass = $obj->pass;
1520 $this->pass_indatabase = $obj->pass;
1521 $this->pass_indatabase_crypted = $obj->pass_crypted;
1523 $this->state_id = $obj->state_id;
1524 $this->state_code = $obj->state_id ? $obj->state_code :
'';
1525 $this->state = $obj->state_id ? $obj->state :
'';
1527 $this->country_id = $obj->country_id;
1528 $this->country_code = $obj->country_code;
1529 if ($langs->trans(
"Country".$obj->country_code) !=
"Country".$obj->country_code) {
1530 $this->country = $langs->transnoentitiesnoconv(
"Country".$obj->country_code);
1532 $this->country = $obj->country;
1535 $this->phone = $obj->phone;
1536 $this->phone_perso = $obj->phone_perso;
1537 $this->phone_mobile = $obj->phone_mobile;
1538 $this->email = $obj->email;
1539 $this->url = $obj->url;
1541 $this->socialnetworks = ($obj->socialnetworks ? (array) json_decode($obj->socialnetworks,
true) : array());
1543 $this->photo = $obj->photo;
1544 $this->statut = $obj->statut;
1545 $this->
status = $obj->statut;
1546 $this->
public = $obj->public;
1548 $this->datec = $this->db->jdate($obj->datec);
1549 $this->date_creation = $this->db->jdate($obj->datec);
1550 $this->datem = $this->db->jdate($obj->datem);
1551 $this->date_modification = $this->db->jdate($obj->datem);
1552 $this->datefin = $this->db->jdate($obj->datefin);
1553 $this->datevalid = $this->db->jdate($obj->datev);
1554 $this->date_validation = $this->db->jdate($obj->datev);
1555 $this->birth = $this->db->jdate($obj->birthday);
1557 $this->default_lang = $obj->default_lang;
1559 $this->note_private = $obj->note_private;
1560 $this->note_public = $obj->note_public;
1561 $this->morphy = $obj->morphy;
1563 $this->
typeid = $obj->fk_adherent_type;
1564 $this->
type = $obj->type;
1565 $this->need_subscription = $obj->subscription;
1567 $this->user_id = $obj->user_id;
1568 $this->user_login = $obj->user_login;
1570 $this->model_pdf = $obj->model_pdf;
1574 if ($fetch_optionals) {
1579 if ($fetch_subscriptions) {
1588 $this->error = $this->db->lasterror();
1608 require_once DOL_DOCUMENT_ROOT.
'/adherents/class/subscription.class.php';
1610 $sql =
"SELECT c.rowid, c.fk_adherent, c.fk_type, c.subscription, c.note as note_public, c.fk_bank,";
1611 $sql .=
" c.tms as datem,";
1612 $sql .=
" c.datec as datec,";
1613 $sql .=
" c.dateadh as dateh,";
1614 $sql .=
" c.datef as datef";
1615 $sql .=
" FROM ".MAIN_DB_PREFIX.
"subscription as c";
1616 $sql .=
" WHERE c.fk_adherent = ".((int) $this->
id);
1617 $sql .=
" ORDER BY c.dateadh";
1618 dol_syslog(get_class($this).
"::fetch_subscriptions", LOG_DEBUG);
1620 $resql = $this->db->query($sql);
1622 $this->subscriptions = array();
1625 while ($obj = $this->db->fetch_object($resql)) {
1627 $this->first_subscription_date = $this->db->jdate($obj->datec);
1628 $this->first_subscription_date_start = $this->db->jdate($obj->dateh);
1629 $this->first_subscription_date_end = $this->db->jdate($obj->datef);
1630 $this->first_subscription_amount = $obj->subscription;
1632 $this->last_subscription_date = $this->db->jdate($obj->datec);
1633 $this->last_subscription_date_start = $this->db->jdate($obj->dateh);
1634 $this->last_subscription_date_end = $this->db->jdate($obj->datef);
1635 $this->last_subscription_amount = $obj->subscription;
1638 $subscription->id = $obj->rowid;
1639 $subscription->fk_adherent = $obj->fk_adherent;
1640 $subscription->fk_type = $obj->fk_type;
1641 $subscription->amount = $obj->subscription;
1642 $subscription->note = $obj->note_public;
1643 $subscription->note_public = $obj->note_public;
1644 $subscription->fk_bank = $obj->fk_bank;
1645 $subscription->datem = $this->db->jdate($obj->datem);
1646 $subscription->datec = $this->db->jdate($obj->datec);
1647 $subscription->dateh = $this->db->jdate($obj->dateh);
1648 $subscription->datef = $this->db->jdate($obj->datef);
1650 $this->subscriptions[] = $subscription;
1656 $this->error = $this->db->error().
' sql='.$sql;
1672 require_once DOL_DOCUMENT_ROOT.
'/partnership/class/partnership.class.php';
1675 $this->partnerships[] = array();
1696 public function subscription($date, $amount, $accountid = 0, $operation =
'', $label =
'', $num_chq =
'', $emetteur_nom =
'', $emetteur_banque =
'', $datesubend = 0, $fk_type =
null)
1700 require_once DOL_DOCUMENT_ROOT.
'/adherents/class/subscription.class.php';
1712 $datefin = $datesubend;
1721 $subscription->fk_adherent = $this->id;
1722 $subscription->dateh = $date;
1723 $subscription->datef = $datefin;
1724 $subscription->amount = $amount;
1725 $subscription->note = $label;
1726 $subscription->note_public = $label;
1727 $subscription->fk_type = $fk_type;
1729 if (empty($subscription->user_creation_id)) {
1730 $subscription->user_creation_id = $user->id;
1733 $rowid = $subscription->create($user);
1740 $this->last_subscription_date =
dol_now();
1741 $this->last_subscription_date_start = $date;
1742 $this->last_subscription_date_end = $datefin;
1743 $this->last_subscription_amount = $amount;
1747 $this->db->commit();
1750 $this->db->rollback();
1755 $this->db->rollback();
1780 public function subscriptionComplementaryActions($subscriptionid, $option, $accountid, $datesubscription, $paymentdate, $operation, $label, $amount, $num_chq, $emetteur_nom =
'', $emetteur_banque =
'', $autocreatethirdparty = 0, $ext_payment_id =
'', $ext_payment_site =
'')
1782 global
$conf, $langs, $user, $mysoc;
1786 $this->invoice =
null;
1788 dol_syslog(
"subscriptionComplementaryActions subscriptionid=".$subscriptionid.
" option=".$option.
" accountid=".$accountid.
" datesubscription=".$datesubscription.
" paymentdate=".
1789 $paymentdate.
" label=".$label.
" amount=".$amount.
" num_chq=".$num_chq.
" autocreatethirdparty=".$autocreatethirdparty);
1792 if ($option ==
'bankdirect' && $accountid) {
1793 require_once DOL_DOCUMENT_ROOT.
'/compta/bank/class/account.class.php';
1795 $acct =
new Account($this->db);
1796 $result = $acct->fetch($accountid);
1798 $dateop = $paymentdate;
1800 $insertid = $acct->addline($dateop, $operation, $label, $amount, $num_chq, 0, $user, $emetteur_nom, $emetteur_banque);
1801 if ($insertid > 0) {
1802 $inserturlid = $acct->add_url_line($insertid, $this->
id, DOL_URL_ROOT.
'/adherents/card.php?rowid=', $this->getFullName($langs),
'member');
1803 if ($inserturlid > 0) {
1805 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"subscription SET fk_bank=".((int) $insertid);
1806 $sql .=
" WHERE rowid=".((int) $subscriptionid);
1808 dol_syslog(
"subscription::subscription", LOG_DEBUG);
1809 $resql = $this->db->query($sql);
1812 $this->error = $this->db->lasterror();
1813 $this->errors[] = $this->error;
1826 if (($option ==
'bankviainvoice' && $accountid) || $option ==
'invoiceonly') {
1827 require_once DOL_DOCUMENT_ROOT.
'/compta/facture/class/facture.class.php';
1828 require_once DOL_DOCUMENT_ROOT.
'/compta/facture/class/paymentterm.class.php';
1830 $invoice =
new Facture($this->db);
1831 $customer =
new Societe($this->db);
1834 if (!($this->fk_soc > 0)) {
1835 if ($autocreatethirdparty) {
1840 if ($this->morphy ==
'mor') {
1841 $companyname = $this->company;
1842 if (!empty($fullname)) {
1843 $companyalias = $fullname;
1846 $companyname = $fullname;
1847 if (!empty($this->company)) {
1848 $companyalias = $this->company;
1852 $result = $customer->create_from_member($this, (
string) $companyname, $companyalias);
1854 $this->error = $customer->error;
1855 $this->errors = $customer->errors;
1858 $this->fk_soc = $result;
1861 $langs->load(
"errors");
1862 $this->error = $langs->trans(
"ErrorMemberNotLinkedToAThirpartyLinkOrCreateFirst");
1863 $this->errors[] = $this->error;
1869 $result = $customer->fetch($this->fk_soc);
1871 $this->error = $customer->error;
1872 $this->errors = $customer->errors;
1880 $invoice->cond_reglement_id = $customer->cond_reglement_id;
1881 if (empty($invoice->cond_reglement_id)) {
1883 $invoice->cond_reglement_id = $paymenttermstatic->getDefaultId();
1884 if (empty($invoice->cond_reglement_id)) {
1886 $this->error =
'ErrorNoPaymentTermRECEPFound';
1887 $this->errors[] = $this->error;
1890 $invoice->socid = $this->fk_soc;
1892 if (!empty($customer->fk_account)) {
1893 $invoice->fk_account = $customer->fk_account;
1899 if (!empty($customer->mode_reglement_id)) {
1900 $invoice->mode_reglement_id = $customer->mode_reglement_id;
1906 $invoice->linked_objects[
'subscription'] = $subscriptionid;
1908 $invoice->linked_objects = array_merge($invoice->linked_objects,
GETPOST(
'other_linked_objects',
'array:int'));
1911 $result = $invoice->create($user);
1913 $this->error = $invoice->error;
1914 $this->errors = $invoice->errors;
1917 $this->invoice = $invoice;
1923 $idprodsubscription = 0;
1924 if (
getDolGlobalString(
'ADHERENT_PRODUCT_ID_FOR_SUBSCRIPTIONS') && (isModEnabled(
"product") || isModEnabled(
"service"))) {
1929 if (
getDolGlobalString(
'ADHERENT_VAT_FOR_SUBSCRIPTIONS') ==
'defaultforfoundationcountry') {
1934 $result = $invoice->addline($label, 0, 1, $vattouse, 0, 0, $idprodsubscription, 0, $datesubscription,
'', 0, 0, 0,
'TTC', $amount, 1);
1936 $this->error = $invoice->error;
1937 $this->errors = $invoice->errors;
1944 $result = $invoice->validate($user);
1946 $this->error = $invoice->error;
1947 $this->errors = $invoice->errors;
1957 if (!$error && $option ==
'bankviainvoice' && $accountid) {
1958 require_once DOL_DOCUMENT_ROOT.
'/compta/paiement/class/paiement.class.php';
1959 require_once DOL_DOCUMENT_ROOT.
'/compta/bank/class/account.class.php';
1960 require_once DOL_DOCUMENT_ROOT.
'/core/lib/functions.lib.php';
1963 $amounts[$invoice->id] = (float)
price2num($amount);
1965 $paiement =
new Paiement($this->db);
1966 $paiement->datepaye = $paymentdate;
1967 $paiement->amounts = $amounts;
1968 $paiement->paiementcode = $operation;
1969 $paiement->paiementid =
dol_getIdFromCode($this->db, $operation,
'c_paiement',
'code',
'id', 1);
1970 $paiement->num_payment = $num_chq;
1971 $paiement->note_public = $label;
1972 $paiement->ext_payment_id = $ext_payment_id;
1973 $paiement->ext_payment_site = $ext_payment_site;
1977 $paiement_id = $paiement->create($user);
1978 if (!($paiement_id > 0)) {
1979 $this->error = $paiement->error;
1980 $this->errors = $paiement->errors;
1987 $bank_line_id = $paiement->addPaymentToBank($user,
'payment',
'(SubscriptionPayment)', $accountid, $emetteur_nom, $emetteur_banque);
1988 if (!($bank_line_id > 0)) {
1989 $this->error = $paiement->error;
1990 $this->errors = $paiement->errors;
1995 if (!$error && !empty($bank_line_id)) {
1997 $sql =
'UPDATE '.MAIN_DB_PREFIX.
'subscription SET fk_bank='.((int) $bank_line_id);
1998 $sql .=
' WHERE rowid='.((int) $subscriptionid);
2000 $result = $this->db->query($sql);
2008 $invoice->setPaid($user);
2014 $outputlangs = $langs;
2016 $lang_id =
GETPOST(
'lang_id');
2017 if (
getDolGlobalInt(
'MAIN_MULTILANGS') && empty($newlang) && !empty($lang_id)) {
2018 $newlang = $lang_id;
2021 $newlang = $customer->default_lang;
2023 if (!empty($newlang)) {
2025 $outputlangs->setDefaultLang($newlang);
2030 $invoice->fetch($invoice->id);
2031 $invoice->generateDocument($invoice->model_pdf, $outputlangs);
2051 global $langs,
$conf;
2057 if ($this->statut == self::STATUS_VALIDATED) {
2058 dol_syslog(get_class($this).
"::validate statut of member does not allow this", LOG_WARNING);
2064 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"adherent SET";
2065 $sql .=
" statut = ".self::STATUS_VALIDATED;
2066 $sql .=
", datevalid = '".$this->db->idate($now).
"'";
2067 $sql .=
", fk_user_valid = ".((int) $user->id);
2068 $sql .=
" WHERE rowid = ".((int) $this->
id);
2070 dol_syslog(get_class($this).
"::validate", LOG_DEBUG);
2071 $result = $this->db->query($sql);
2076 $result = $this->
call_trigger(
'MEMBER_VALIDATE', $user);
2079 $this->db->rollback();
2084 $this->datevalid = $now;
2086 $this->db->commit();
2089 $this->error = $this->db->error();
2090 $this->db->rollback();
2104 global $langs,
$conf;
2109 if ($this->statut == self::STATUS_RESILIATED) {
2110 dol_syslog(get_class($this).
"::resiliate statut of member does not allow this", LOG_WARNING);
2116 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"adherent SET";
2117 $sql .=
" statut = ".((int) self::STATUS_RESILIATED);
2118 $sql .=
", fk_user_valid = ".((int) $user->id);
2119 $sql .=
" WHERE rowid = ".((int) $this->
id);
2121 $result = $this->db->query($sql);
2126 $result = $this->
call_trigger(
'MEMBER_RESILIATE', $user);
2129 $this->db->rollback();
2134 $this->db->commit();
2137 $this->error = $this->db->error();
2138 $this->db->rollback();
2157 if ($this->statut == self::STATUS_EXCLUDED) {
2158 dol_syslog(get_class($this).
"::resiliate statut of member does not allow this", LOG_WARNING);
2164 $sql =
"UPDATE ".MAIN_DB_PREFIX.
"adherent SET";
2165 $sql .=
" statut = ".((int) self::STATUS_EXCLUDED);
2166 $sql .=
", fk_user_valid = ".((int) $user->id);
2167 $sql .=
" WHERE rowid = ".((int) $this->
id);
2169 $result = $this->db->query($sql);
2174 $result = $this->
call_trigger(
'MEMBER_EXCLUDE', $user);
2177 $this->db->rollback();
2182 $this->db->commit();
2185 $this->error = $this->db->error();
2186 $this->db->rollback();
2202 include_once DOL_DOCUMENT_ROOT.
'/mailmanspip/class/mailmanspip.class.php';
2209 $result = $mailmanspip->add_to_mailman($this);
2212 if (!empty($mailmanspip->error)) {
2213 $this->errors[] = $mailmanspip->error;
2217 foreach ($mailmanspip->mladded_ko as $tmplist => $tmpemail) {
2218 $langs->load(
"errors");
2219 $this->errors[] = $langs->trans(
"ErrorFailedToAddToMailmanList", $tmpemail, $tmplist);
2221 foreach ($mailmanspip->mladded_ok as $tmplist => $tmpemail) {
2222 $langs->load(
"mailmanspip");
2223 $this->mesgs[] = $langs->trans(
"SuccessToAddToMailmanList", $tmpemail, $tmplist);
2229 $result = $mailmanspip->add_to_spip($this);
2231 $this->errors[] = $mailmanspip->error;
2252 global
$conf, $langs;
2254 include_once DOL_DOCUMENT_ROOT.
'/mailmanspip/class/mailmanspip.class.php';
2261 $result = $mailmanspip->del_to_mailman($this);
2263 if (!empty($mailmanspip->error)) {
2264 $this->errors[] = $mailmanspip->error;
2269 foreach ($mailmanspip->mlremoved_ko as $tmplist => $tmpemail) {
2270 $langs->load(
"errors");
2271 $this->errors[] = $langs->trans(
"ErrorFailedToRemoveToMailmanList", $tmpemail, $tmplist);
2273 foreach ($mailmanspip->mlremoved_ok as $tmplist => $tmpemail) {
2274 $langs->load(
"mailmanspip");
2275 $this->mesgs[] = $langs->trans(
"SuccessToRemoveToMailmanList", $tmpemail, $tmplist);
2280 $result = $mailmanspip->del_to_spip($this);
2282 $this->errors[] = $mailmanspip->error;
2303 $langs->load(
"dict");
2305 $code = (empty($this->civility_id) ?
'' : $this->civility_id);
2309 return $langs->getLabelFromKey($this->db,
"Civility".$code,
"c_civility",
"code",
"label", $code);
2322 $langs->loadLangs([
'members',
'companies']);
2323 $nofetch = !empty($params[
'nofetch']);
2328 $langs->load(
"users");
2329 return [
'optimize' => $langs->trans(
"ShowUser")];
2331 if (!empty($this->photo)) {
2332 $photo =
'<div class="photointooltip floatright">';
2333 $photo .=
Form::showphoto(
'memberphoto', $this, 80, 0, 0,
'photoref photowithmargin photologintooltip',
'small', 0, 1);
2335 $datas[
'photo'] = $photo;
2338 $datas[
'divopen'] =
'<div class="centpercent">';
2339 $datas[
'picto'] =
img_picto(
'', $this->picto).
' <u class="paddingrightonly">'.$langs->trans(
"Member").
'</u> '.$this->
getLibStatut(4);
2340 if (!empty($this->morphy)) {
2341 $datas[
'picto'] .=
' ' . $this->
getmorphylib(
'', 1);
2343 if (!empty($this->
ref)) {
2344 $datas[
'ref'] =
'<br><b>'.$langs->trans(
'Ref').
':</b> '.$this->ref;
2346 if (!empty($this->login)) {
2347 $datas[
'login'] =
'<br><b>'.$langs->trans(
'Login').
':</b> '.$this->login;
2349 if (!empty($this->firstname) || !empty($this->lastname)) {
2350 $datas[
'name'] =
'<br><b>'.$langs->trans(
'Name').
':</b> '.$this->
getFullName($langs);
2352 if (!empty($this->company)) {
2353 $datas[
'company'] =
'<br><b>'.$langs->trans(
'Company').
':</b> '.$this->company;
2355 if (!empty($this->email)) {
2356 $datas[
'email'] =
'<br><b>'.$langs->trans(
"EMail").
':</b> '.$this->email;
2358 $datas[
'address'] =
'<br><b>'.$langs->trans(
"Address").
':</b> '.
dol_format_address($this, 1,
' ', $langs);
2360 if (isModEnabled(
'category') && !$nofetch) {
2361 require_once DOL_DOCUMENT_ROOT .
'/categories/class/categorie.class.php';
2362 $form =
new Form($this->db);
2363 $datas[
'categories'] =
'<br>' . $form->showCategories($this->
id, Categorie::TYPE_MEMBER, 1);
2365 $datas[
'divclose'] =
'</div>';
2383 public function getNomUrl($withpictoimg = 0, $maxlen = 0, $option =
'card', $mode =
'', $morecss =
'', $save_lastsearch_value = -1, $notooltip = 0, $addlinktonotes = 0)
2385 global
$conf, $langs, $hookmanager;
2394 $classfortooltip =
'classfortooltip';
2398 'objecttype' => $this->element,
2399 'option' => $option,
2403 $classfortooltip =
'classforajaxtooltip';
2404 $dataparams =
' data-params="'.dol_escape_htmltag(json_encode($params)).
'"';
2410 $url = DOL_URL_ROOT.
'/adherents/card.php?rowid='.((int) $this->
id);
2411 if ($option ==
'subscription') {
2412 $url = DOL_URL_ROOT.
'/adherents/subscription.php?rowid='.((int) $this->
id);
2415 if ($option !=
'nolink') {
2417 $add_save_lastsearch_values = ($save_lastsearch_value == 1 ? 1 : 0);
2418 if ($save_lastsearch_value == -1 && isset($_SERVER[
"PHP_SELF"]) && preg_match(
'/list\.php/', $_SERVER[
"PHP_SELF"])) {
2419 $add_save_lastsearch_values = 1;
2421 if ($add_save_lastsearch_values) {
2422 $url .=
'&save_lastsearch_values=1';
2426 $linkstart .=
'<a href="'.$url.
'"';
2428 if (empty($notooltip)) {
2430 $langs->load(
"users");
2431 $label = $langs->trans(
"ShowUser");
2432 $linkclose .=
' alt="'.dolPrintHTMLForAttribute($label).
'"';
2434 $linkclose .= ($label ?
' title="'.dolPrintHTMLForAttribute($label).
'"' :
' title="tocomplete"');
2435 $linkclose .= $dataparams.
' class="'.$classfortooltip.($morecss ?
' '.$morecss :
'').
'"';
2438 $linkstart .= $linkclose.
'>';
2441 $result .= $linkstart;
2443 if ($withpictoimg) {
2444 $paddafterimage =
'';
2445 if (abs($withpictoimg) == 1 || abs($withpictoimg) == 4) {
2446 $morecss .=
' paddingrightonly';
2449 if ($withpictoimg > 0) {
2450 $picto =
'<span class="nopadding'.($morecss ?
' userimg'.$morecss :
'').
'">'.
img_object(
'',
'user', $paddafterimage.
' '.($notooltip ?
'' : $dataparams), 0, 0, $notooltip ? 0 : 1).
'</span>';
2453 $picto =
'<span class="nopadding'.($morecss ?
' userimg'.$morecss :
'').
'"'.($paddafterimage ?
' '.$paddafterimage :
'').
'>';
2454 $picto .=
Form::showphoto(
'memberphoto', $this, 0, 0, 0,
'userphoto'.(($withpictoimg == -3 || $withpictoimg == -4) ?
'small' :
''),
'mini', 0, 1);
2455 $picto .=
'</span>';
2459 if (($withpictoimg > -2 && $withpictoimg != 2) || $withpictoimg == -4) {
2461 $result .=
'<span class="nopadding valignmiddle'.((!isset($this->statut) || $this->statut) ?
'' :
' strikefordisabled').
2462 ($morecss ?
' usertext'.$morecss :
'').
'">';
2464 if ($mode ==
'login') {
2465 $result .=
dol_trunc(isset($this->login) ? $this->login :
'', $maxlen);
2466 } elseif ($mode ==
'ref') {
2467 $result .= $this->ref;
2469 $result .= $this->
getFullName($langs, 0, ($mode ==
'firstname' ? 2 : ($mode ==
'lastname' ? 4 : -1)), $maxlen);
2472 $result .=
'</span>';
2476 $result .= $linkend;
2478 if ($addlinktonotes) {
2479 if ($this->note_private) {
2480 $notetoshow = $langs->trans(
"ViewPrivateNote").
':<br>'.
dol_string_nohtmltag($this->note_private, 1);
2481 $result .=
' <span class="note inline-block">';
2482 $result .=
'<a href="'.DOL_URL_ROOT.
'/adherents/note.php?id='.$this->
id.
'" class="classfortooltip" title="'.
dol_escape_htmltag($notetoshow).
'">';
2485 $result .=
'</span>';
2489 $hookmanager->initHooks(array($this->element .
'dao'));
2490 $parameters = array(
'id' => $this->
id,
'getnomurl' => &$result);
2491 $reshook = $hookmanager->executeHooks(
'getNomUrl', $parameters, $this, $action);
2493 $result = $hookmanager->resPrint;
2495 $result .= $hookmanager->resPrint;
2508 return $this->
LibStatut($this->
status, $this->need_subscription, $this->datefin, $mode);
2521 public function LibStatut($status, $need_subscription, $date_end_subscription, $mode = 0)
2525 $langs->load(
"members");
2529 $labelStatusShort =
'';
2531 if ($status == self::STATUS_DRAFT) {
2532 $statusType =
'status0';
2533 $labelStatus = $langs->trans(
"MemberStatusDraft");
2534 $labelStatusShort = $langs->trans(
"MemberStatusDraftShort");
2535 } elseif ($status >= self::STATUS_VALIDATED) {
2536 if ($need_subscription === 0) {
2537 $statusType =
'status4';
2538 $labelStatus = $langs->trans(
"Validated").
' - '.$langs->trans(
"MemberStatusNoSubscription");
2539 $labelStatusShort = $langs->trans(
"MemberStatusNoSubscriptionShort");
2540 } elseif (!$date_end_subscription) {
2541 $statusType =
'status1';
2542 $labelStatus = $langs->trans(
"Validated").
' - '.$langs->trans(
"WaitingSubscription");
2543 $labelStatusShort = $langs->trans(
"WaitingSubscriptionShort");
2544 } elseif ($date_end_subscription <
dol_now()) {
2545 $statusType =
'status2';
2546 $labelStatus = $langs->trans(
"Validated").
' - '.$langs->trans(
"MemberStatusActiveLate");
2547 $labelStatusShort = $langs->trans(
"MemberStatusActiveLateShort");
2549 $statusType =
'status4';
2550 $labelStatus = $langs->trans(
"Validated").
' - '.$langs->trans(
"MemberStatusPaid");
2551 $labelStatusShort = $langs->trans(
"MemberStatusPaidShort");
2553 } elseif ($status == self::STATUS_RESILIATED) {
2554 $statusType =
'status6';
2555 $labelStatus = $langs->transnoentitiesnoconv(
"MemberStatusResiliated");
2556 $labelStatusShort = $langs->transnoentitiesnoconv(
"MemberStatusResiliatedShort");
2557 } elseif ($status == self::STATUS_EXCLUDED) {
2558 $statusType =
'status10';
2559 $labelStatus = $langs->transnoentitiesnoconv(
"MemberStatusExcluded");
2560 $labelStatusShort = $langs->transnoentitiesnoconv(
"MemberStatusExcludedShort");
2563 return dolGetStatus($labelStatus, $labelStatusShort,
'', $statusType, $mode);
2576 $this->nb = array();
2578 $sql =
"SELECT count(a.rowid) as nb";
2579 $sql .=
" FROM ".MAIN_DB_PREFIX.
"adherent as a";
2580 $sql .=
" WHERE a.statut > 0";
2581 $sql .=
" AND a.entity IN (".getEntity(
'adherent').
")";
2583 $resql = $this->db->query($sql);
2585 while ($obj = $this->db->fetch_object($resql)) {
2586 $this->nb[
"members"] = $obj->nb;
2588 $this->db->free($resql);
2592 $this->error = $this->db->error();
2608 global
$conf, $langs;
2616 $sql =
"SELECT a.rowid, a.datefin, a.statut";
2617 $sql .=
" FROM ".MAIN_DB_PREFIX.
"adherent as a";
2618 $sql .=
", ".MAIN_DB_PREFIX.
"adherent_type as t";
2619 $sql .=
" WHERE a.fk_adherent_type = t.rowid";
2620 if ($mode ==
'expired') {
2621 $sql .=
" AND a.statut = ".self::STATUS_VALIDATED;
2622 $sql .=
" AND a.entity IN (".getEntity(
'adherent').
")";
2623 $sql .=
" AND ((a.datefin IS NULL or a.datefin < '".$this->db->idate($now).
"') AND t.subscription = '1')";
2624 } elseif ($mode ==
'shift') {
2625 $sql .=
" AND a.statut = ".self::STATUS_DRAFT;
2626 $sql .=
" AND a.entity IN (".getEntity(
'adherent').
")";
2629 $resql = $this->db->query($sql);
2631 $langs->load(
"members");
2638 if ($mode ==
'expired') {
2639 $warning_delay =
$conf->adherent->subscription->warning_delay / 60 / 60 / 24;
2640 $label = $langs->trans(
"MembersWithSubscriptionToReceive");
2641 $labelShort = $langs->trans(
"MembersWithSubscriptionToReceiveShort");
2642 $url = DOL_URL_ROOT.
'/adherents/list.php?mainmenu=members&statut='.self::STATUS_VALIDATED.
'&filter=outofdate';
2643 } elseif ($mode ==
'shift') {
2644 $warning_delay =
$conf->adherent->subscription->warning_delay / 60 / 60 / 24;
2645 $url = DOL_URL_ROOT.
'/adherents/list.php?mainmenu=members&statut='.
self::STATUS_DRAFT;
2646 $label = $langs->trans(
"MembersListToValid");
2647 $labelShort = $langs->trans(
"ToValidate");
2651 $response->warning_delay = $warning_delay;
2652 $response->label = $label;
2653 $response->labelShort = $labelShort;
2654 $response->url = $url;
2657 $adherentstatic =
new Adherent($this->db);
2659 while ($obj = $this->db->fetch_object($resql)) {
2660 $response->nbtodo++;
2662 $adherentstatic->datefin = $this->db->jdate($obj->datefin);
2663 $adherentstatic->statut = $obj->statut;
2664 $adherentstatic->status = $obj->statut;
2666 if ($adherentstatic->hasDelay()) {
2667 $response->nbtodolate++;
2674 $this->error = $this->db->error();
2691 public function generateDocument($modele, $outputlangs, $hidedetails = 0, $hidedesc = 0, $hideref = 0, $moreparams =
null)
2693 global
$conf, $langs;
2695 $langs->load(
"orders");
2698 $modele =
'standard';
2700 if ($this->model_pdf) {
2701 $modele = $this->model_pdf;
2707 $modelpath =
"core/modules/member/doc/";
2709 return $this->
commonGenerateDocument($modelpath, $modele, $outputlangs, $hidedetails, $hidedesc, $hideref, $moreparams);
2722 global $user, $langs;
2727 $this->
ref =
'ABC001';
2729 $this->specimen = 1;
2730 $this->civility_id =
'MR';
2731 $this->lastname =
'DOLIBARR';
2732 $this->firstname =
'SPECIMEN';
2733 $this->gender =
'man';
2734 $this->login =
'dolibspec';
2735 $this->pass =
'dolibspec';
2736 $this->company =
'Societe ABC';
2737 $this->
address =
'61 jump street';
2738 $this->zip =
'75000';
2739 $this->town =
'Paris';
2740 $this->country_id = 1;
2741 $this->country_code =
'FR';
2742 $this->country =
'France';
2743 $this->morphy =
'mor';
2744 $this->email =
'specimen@specimen.com';
2745 $this->socialnetworks = array(
2746 'skype' =>
'skypepseudo',
2747 'twitter' =>
'twitterpseudo',
2748 'facebook' =>
'facebookpseudo',
2749 'linkedin' =>
'linkedinpseudo',
2751 $this->phone =
'0999999999';
2752 $this->phone_perso =
'0999999998';
2753 $this->phone_mobile =
'0999999997';
2754 $this->note_public =
'This is a public note';
2755 $this->note_private =
'This is a private note';
2756 $this->birth = $now;
2762 $this->datefin = $now;
2763 $this->datevalid = $now;
2764 $this->default_lang =
'';
2767 $this->
type =
'Type adherent';
2768 $this->need_subscription = 0;
2770 $this->first_subscription_date = $now;
2771 $this->first_subscription_date_start = $this->first_subscription_date;
2772 $this->first_subscription_date_end =
dol_time_plus_duree($this->first_subscription_date_start, 1,
'y');
2773 $this->first_subscription_amount = 10;
2775 $this->last_subscription_date = $this->first_subscription_date;
2776 $this->last_subscription_date_start = $this->first_subscription_date;
2777 $this->last_subscription_date_end =
dol_time_plus_duree($this->last_subscription_date_start, 1,
'y');
2778 $this->last_subscription_amount = 10;
2822 global
$conf, $langs;
2826 $keymodified =
false;
2834 if ($this->morphy ==
'mor' && (empty($this->fullname) || $this->fullname == $this->company)) {
2835 $this->fullname = $this->company;
2836 $this->lastname = $this->company;
2841 'LDAP_MEMBER_FIELD_FULLNAME' =>
'fullname',
2842 'LDAP_MEMBER_FIELD_NAME' =>
'lastname',
2843 'LDAP_MEMBER_FIELD_LOGIN' =>
'login',
2844 'LDAP_MEMBER_FIELD_LOGIN_SAMBA' =>
'login',
2845 'LDAP_MEMBER_FIELD_MAIL' =>
'email'
2849 foreach ($ldapkey as $constname => $varname) {
2855 if (!empty($this->oldcopy) && $this->$varname != $this->oldcopy->$varname) {
2856 $keymodified =
true;
2882 foreach ($socialnetworks as $key => $value) {
2883 if ($this->socialnetworks[$value[
'label']] &&
getDolGlobalString(
'LDAP_MEMBER_FIELD_'.strtoupper($value[
'label']))) {
2884 $info[
getDolGlobalString(
'LDAP_MEMBER_FIELD_'.strtoupper($value[
'label']))] = $this->socialnetworks[$value[
'label']];
2911 if ($this->datefin &&
getDolGlobalString(
'LDAP_FIELD_MEMBER_END_LASTSUBSCRIPTION')) {
2916 if (!empty($this->pass)) {
2929 if ($this->pass_indatabase_crypted &&
getDolGlobalString(
'LDAP_MEMBER_FIELD_PASSWORD_CRYPTED')) {
2935 } elseif (!empty($this->pass_indatabase)) {
2947 if ($this->first_subscription_date &&
getDolGlobalString(
'LDAP_FIELD_MEMBER_FIRSTSUBSCRIPTION_DATE')) {
2950 if (isset($this->first_subscription_amount) &&
getDolGlobalString(
'LDAP_FIELD_MEMBER_FIRSTSUBSCRIPTION_AMOUNT')) {
2951 $info[
getDolGlobalString(
'LDAP_FIELD_MEMBER_FIRSTSUBSCRIPTION_AMOUNT')] = $this->first_subscription_amount;
2953 if ($this->last_subscription_date &&
getDolGlobalString(
'LDAP_FIELD_MEMBER_LASTSUBSCRIPTION_DATE')) {
2956 if (isset($this->last_subscription_amount) &&
getDolGlobalString(
'LDAP_FIELD_MEMBER_LASTSUBSCRIPTION_AMOUNT')) {
2957 $info[
getDolGlobalString(
'LDAP_FIELD_MEMBER_LASTSUBSCRIPTION_AMOUNT')] = $this->last_subscription_amount;
2972 $sql =
'SELECT a.rowid, a.datec as datec,';
2973 $sql .=
' a.datevalid as datev,';
2974 $sql .=
' a.tms as datem,';
2975 $sql .=
' a.fk_user_author, a.fk_user_valid, a.fk_user_mod';
2976 $sql .=
' FROM '.MAIN_DB_PREFIX.
'adherent as a';
2977 $sql .=
' WHERE a.rowid = '.((int) $id);
2979 dol_syslog(get_class($this).
"::info", LOG_DEBUG);
2980 $result = $this->db->query($sql);
2982 if ($this->db->num_rows($result)) {
2983 $obj = $this->db->fetch_object($result);
2985 $this->
id = $obj->rowid;
2987 $this->user_creation_id = $obj->fk_user_author;
2988 $this->user_validation_id = $obj->fk_user_valid;
2989 $this->user_modification_id = $obj->fk_user_mod;
2990 $this->date_creation = $this->db->jdate($obj->datec);
2991 $this->date_validation = $this->db->jdate($obj->datev);
2992 $this->date_modification = $this->db->jdate($obj->datem);
2995 $this->db->free($result);
3008 $sql =
"SELECT count(mc.email) as nb";
3009 $sql .=
" FROM ".MAIN_DB_PREFIX.
"mailing_cibles as mc";
3010 $sql .=
" WHERE mc.email = '".$this->db->escape($this->email).
"'";
3011 $sql .=
" AND mc.statut NOT IN (-1,0)";
3013 $resql = $this->db->query($sql);
3015 $obj = $this->db->fetch_object($resql);
3018 $this->db->free($resql);
3021 $this->error = $this->db->error();
3038 require_once DOL_DOCUMENT_ROOT.
'/categories/class/categorie.class.php';
3039 return parent::setCategoriesCommon($categories, Categorie::TYPE_MEMBER);
3052 $tables = array(
'adherent');
3067 if ($this->statut != self::STATUS_VALIDATED) {
3070 if (!$this->datefin) {
3076 return $this->datefin < ($now -
$conf->adherent->subscription->warning_delay);
3090 global
$conf, $langs, $mysoc, $user;
3096 $blockingerrormsg =
'';
3098 if (!isModEnabled(
'member')) {
3099 $langs->load(
"agenda");
3100 $this->output = $langs->trans(
'ModuleNotEnabled', $langs->transnoentitiesnoconv(
"Adherent"));
3104 $langs->load(
"agenda");
3105 $this->output = $langs->trans(
'EventRemindersByEmailNotEnabled', $langs->transnoentitiesnoconv(
"Adherent"));
3113 $listofmembersok = array();
3114 $listofmembersko = array();
3116 $arraydaysbeforeend = explode(
';', $daysbeforeendlist);
3117 foreach ($arraydaysbeforeend as $daysbeforeend) {
3118 dol_syslog(__METHOD__.
' - Process delta = '.$daysbeforeend, LOG_DEBUG);
3120 if (!is_numeric($daysbeforeend)) {
3121 $blockingerrormsg =
"Value for delta is not a numeric value";
3127 $datetosearchfor =
dol_time_plus_duree(
dol_mktime(0, 0, 0, $tmp[
'mon'], $tmp[
'mday'], $tmp[
'year'],
'tzserver'), (
int) $daysbeforeend,
'd');
3128 $datetosearchforend =
dol_time_plus_duree(
dol_mktime(23, 59, 59, $tmp[
'mon'], $tmp[
'mday'], $tmp[
'year'],
'tzserver'), (
int) $daysbeforeend,
'd');
3130 $sql =
'SELECT rowid FROM '.MAIN_DB_PREFIX.
'adherent';
3131 $sql .=
" WHERE entity = ".((int)
$conf->entity);
3132 $sql .=
" AND statut = 1";
3133 $sql .=
" AND datefin >= '".$this->db->idate($datetosearchfor).
"'";
3134 $sql .=
" AND datefin <= '".$this->db->idate($datetosearchforend).
"'";
3135 if ((
int) $fk_adherent_type > 0) {
3136 $sql .=
" AND fk_adherent_type = ".((int) $fk_adherent_type);
3140 $resql = $this->db->query($sql);
3142 $num_rows = $this->db->num_rows($resql);
3144 include_once DOL_DOCUMENT_ROOT.
'/core/class/html.formmail.class.php';
3145 $adherent =
new Adherent($this->db);
3146 $formmail =
new FormMail($this->db);
3149 while ($i < $num_rows) {
3150 $obj = $this->db->fetch_object($resql);
3152 $adherent->fetch($obj->rowid,
'', 0,
'',
true,
true);
3154 if (empty($adherent->email)) {
3156 $listofmembersko[$adherent->id] = $adherent->id;
3158 $thirdpartyres = $adherent->fetch_thirdparty();
3159 if ($thirdpartyres === -1) {
3160 $languagecodeformember = $mysoc->default_lang;
3163 $languagefromcountrycode =
getLanguageCodeFromCountryCode($adherent->country_code ? $adherent->country_code : $adherent->thirdparty->country_code);
3164 $languagecodeformember = (empty($adherent->thirdparty->default_lang) ? ($languagefromcountrycode ? $languagefromcountrycode : $mysoc->default_lang) : $adherent->thirdparty->default_lang);
3169 $outputlangs->setDefaultLang($languagecodeformember);
3170 $outputlangs->loadLangs(array(
"main",
"members"));
3171 dol_syslog(
"sendReminderForExpiredSubscription Language for member id ".$adherent->id.
" set to ".$outputlangs->defaultlang.
" mysoc->default_lang=".$mysoc->default_lang);
3173 $arraydefaultmessage =
null;
3176 if (!empty($labeltouse)) {
3177 $arraydefaultmessage = $formmail->getEMailTemplate($this->db,
'member', $user, $outputlangs, 0, 1, $labeltouse);
3180 if (!empty($labeltouse) && is_object($arraydefaultmessage) && $arraydefaultmessage->id > 0) {
3181 $substitutionarray = getCommonSubstitutionArray($outputlangs, 0,
null, $adherent);
3185 $subject =
make_substitutions($arraydefaultmessage->topic, $substitutionarray, $outputlangs);
3186 $msg =
make_substitutions($arraydefaultmessage->content, $substitutionarray, $outputlangs);
3188 $to = $adherent->email;
3191 $trackid =
'mem'.$adherent->id;
3192 $moreinheader =
'X-Dolibarr-Info: sendReminderForExpiredSubscription'.
"\r\n";
3194 include_once DOL_DOCUMENT_ROOT.
'/core/class/CMailFile.class.php';
3195 $cmail =
new CMailFile($subject, $to, $from, $msg, array(), array(), array(), $cc,
'', 0, 1,
'',
'', $trackid, $moreinheader);
3196 $result = $cmail->sendfile();
3199 $this->error .= $cmail->error.
' ';
3200 if (!is_null($cmail->errors)) {
3201 $this->errors += $cmail->errors;
3204 $listofmembersko[$adherent->id] = $adherent->id;
3207 $listofmembersok[$adherent->id] = $adherent->id;
3213 $actioncode =
'EMAIL';
3214 $extraparams = array();
3224 $actionmsg =
dol_concatdesc($actionmsg, $langs->transnoentities(
'MailTopic').
": ".$subject);
3225 $actionmsg =
dol_concatdesc($actionmsg, $langs->transnoentities(
'TextUsedInTheMessageBody').
":");
3229 require_once DOL_DOCUMENT_ROOT.
'/comm/action/class/actioncomm.class.php';
3234 $actioncomm->type_code =
'AC_OTH_AUTO';
3235 $actioncomm->code =
'AC_'.$actioncode;
3236 $actioncomm->label = $actionmsg2;
3237 $actioncomm->note_private = $actionmsg;
3238 $actioncomm->fk_project = 0;
3239 $actioncomm->datep = $now;
3240 $actioncomm->datef = $now;
3241 $actioncomm->percentage = -1;
3242 $actioncomm->socid = $adherent->thirdparty->id;
3243 $actioncomm->contact_id = 0;
3244 $actioncomm->authorid = $user->id;
3245 $actioncomm->userownerid = $user->id;
3247 $actioncomm->email_msgid = $cmail->msgid;
3248 $actioncomm->email_from = $from;
3249 $actioncomm->email_sender =
'';
3250 $actioncomm->email_to = $to;
3251 $actioncomm->email_tocc = $sendtocc;
3252 $actioncomm->email_tobcc = $sendtobcc;
3253 $actioncomm->email_subject = $subject;
3254 $actioncomm->errors_to =
'';
3256 $actioncomm->fk_element = $adherent->id;
3257 $actioncomm->elementid = $adherent->id;
3258 $actioncomm->elementtype = $adherent->element;
3260 $actioncomm->extraparams = $extraparams;
3262 $actioncomm->create($user);
3268 $this->error .=
"Can't find email template with label=".$labeltouse.
", to use for the reminding email ";
3271 $listofmembersko[$adherent->id] = $adherent->id;
3280 $this->error = $this->db->lasterror();
3285 if ($blockingerrormsg) {
3286 $this->error = $blockingerrormsg;
3289 $this->output =
'Found '.($nbok + $nbko).
' members to send reminder to.';
3290 $this->output .=
' Send email successfully to '.$nbok.
' members';
3291 if (is_array($listofmembersok)) {
3294 foreach ($listofmembersok as $idmember) {
3296 $listofids .=
', ...';
3299 if (empty($listofids)) {
3304 $listofids .= $idmember;
3311 $this->output .= ($listofids ?
' ids='.$listofids :
'');
3314 $this->output .=
' - Canceled for '.$nbko.
' member (no email or email sending error)';
3315 if (is_array($listofmembersko)) {
3318 foreach ($listofmembersko as $idmember) {
3320 $listofids .=
', ...';
3323 if (empty($listofids)) {
3328 $listofids .= $idmember;
3334 $this->output .= ($listofids ?
' ids='.$listofids :
'');
3351 $selected = (empty($arraydata[
'selected']) ? 0 : $arraydata[
'selected']);
3353 $return =
'<div class="box-flex-item box-flex-grow-zero">';
3354 $return .=
'<div class="info-box info-box-sm">';
3355 $return .=
'<span class="info-box-icon bg-infobox-action">';
3356 if (property_exists($this,
'photo') || !empty($this->photo)) {
3357 $return .=
Form::showphoto(
'memberphoto', $this, 0, 60, 0,
'photokanban photowithmargin photologintooltip',
'small', 0, 1);
3361 $return .=
'</span>';
3362 $return .=
'<div class="info-box-content">';
3363 $return .=
'<span class="info-box-ref inline-block tdoverflowmax150 valignmiddle">'.(method_exists($this,
'getNomUrl') ? $this->
getNomUrl() : $this->ref).
'</span>';
3364 if ($selected >= 0) {
3365 $return .=
'<input id="cb'.$this->id.
'" class="flat checkforselect fright" type="checkbox" name="toselect[]" value="'.$this->
id.
'"'.($selected ?
' checked="checked"' :
'').
'>';
3367 $return .=
'<br><span class="info-box-label paddingright">'.$this->getmorphylib(
'', 2).
'</span>';
3368 $return .=
'<span class="info-box-label opacitymedium">'.$this->type.
'</span>';
3370 if (method_exists($this,
'getLibStatut')) {
3371 $return .=
'<br><div class="info-box-status paddingtop">';
3372 $return .= $this->
LibStatut($this->
status, $this->need_subscription, $this->datefin, 5);
3373 $return .=
'</div>';
3375 $return .=
'</div>';
3376 $return .=
'</div>';
3377 $return .=
'</div>';
Class to manage bank accounts.
Class to manage agenda events (actions)
Class to manage members of a foundation.
setThirdPartyId($thirdpartyid)
Set link to a third party.
hasDelay()
Return if a member is late (subscription late) or not.
exclude($user)
Functiun to exclude (set adherent.status to -2) a member TODO A private note should be added to know ...
add_to_abo()
Function to add member into external tools mailing-list, spip, etc.
loadStateBoard()
Load indicators this->nb in state board.
_load_ldap_dn($info, $mode=0)
Retourne chaine DN complete dans l'annuaire LDAP pour l'objet.
update($user, $notrigger=0, $nosyncuser=0, $nosyncuserpass=0, $nosyncthirdparty=0, $action='update')
Update a member in database (standard information and password)
setCategories($categories)
Sets object to supplied categories.
getTooltipContentArray($params)
getTooltipContentArray
getNbOfEMailings()
Return number of mass Emailing received by this member with its email.
update_end_date($user)
Update denormalized last subscription date.
static replaceThirdparty($db, $origin_id, $dest_id)
Function used to replace a thirdparty id with another one.
makeSubstitution($text)
Make substitution of tags into text with value of current object.
const STATUS_EXCLUDED
Excluded.
LibStatut($status, $need_subscription, $date_end_subscription, $mode=0)
Renvoi le libelle d'un statut donne.
fetch_name($firstname, $lastname)
Method to load member from its name.
initAsSpecimen()
Initialise an instance with random values.
fetch($rowid, $ref='', $fk_soc=0, $ref_ext='', $fetch_optionals=true, $fetch_subscriptions=true)
Load member from database.
del_to_abo()
Function to delete a member from external tools like mailing-list, spip, etc.
resiliate($user)
Fonction qui resilie un adherent.
getCivilityLabel()
Return civility label of a member.
getmorphylib($morphy='', $addbadge=0)
Return translated label by the nature of a adherent (physical or moral)
sendEmail($text, $subject, $filename_list=array(), $mimetype_list=array(), $mimefilename_list=array(), $addr_cc="", $addr_bcc="", $deliveryreceipt=0, $msgishtml=-1, $errors_to='', $moreinheader='')
Function sending an email to the current member with the text supplied in parameter.
fetchPartnerships($mode)
Function to get partnerships array.
load_board($user, $mode)
Load indicators for dashboard (this->nbtodo and this->nbtodolate)
setPassword($user, $password='', $isencrypted=0, $notrigger=0, $nosyncuser=0)
Change password of a user.
$fields
'type' field format: 'integer', 'integer:ObjectClass:PathToClass[:AddCreateButtonOrNot[:Filter[:Sortf...
getKanbanView($option='', $arraydata=null)
Return clickable link of object (with eventually picto)
const STATUS_DRAFT
Draft status.
const STATUS_RESILIATED
Resiliated (membership end and was not renew)
sendReminderForExpiredSubscription($daysbeforeendlist='10', $fk_adherent_type=0)
Send reminders by emails before subscription end CAN BE A CRON TASK.
fetch_login($login)
Method to load member from its login.
_load_ldap_info()
Initialise tableau info (tableau des attributes LDAP)
getLibStatut($mode=0)
Retourne le libelle du statut d'un adherent (brouillon, valide, resilie, exclu)
info($id)
Load type info information in the member object.
__construct($db)
Constructor.
subscription($date, $amount, $accountid=0, $operation='', $label='', $num_chq='', $emetteur_nom='', $emetteur_banque='', $datesubend=0, $fk_type=null)
Insert subscription into database and eventually add links to banks, mailman, etc....
send_an_email($text, $subject, $filename_list=array(), $mimetype_list=array(), $mimefilename_list=array(), $addr_cc="", $addr_bcc="", $deliveryreceipt=0, $msgishtml=-1, $errors_to='', $moreinheader='')
Function sending an email to the current member with the text supplied in parameter.
getNomUrl($withpictoimg=0, $maxlen=0, $option='card', $mode='', $morecss='', $save_lastsearch_value=-1, $notooltip=0, $addlinktonotes=0)
Return clickable name (with picto eventually)
generateDocument($modele, $outputlangs, $hidedetails=0, $hidedesc=0, $hideref=0, $moreparams=null)
Create a document onto disk according to template module.
subscriptionComplementaryActions($subscriptionid, $option, $accountid, $datesubscription, $paymentdate, $operation, $label, $amount, $num_chq, $emetteur_nom='', $emetteur_banque='', $autocreatethirdparty=0, $ext_payment_id='', $ext_payment_site='')
Do complementary actions after subscription recording.
setUserId($userid)
Set link to a user.
const STATUS_VALIDATED
Validated status.
fetch_subscriptions()
Function to get member subscriptions data: subscriptions, first_subscription_date,...
validate($user)
Function that validate a member.
Class to send emails (with attachments or not) Usage: $mailfile = new CMailFile($subject,...
static getValidAddress($address, $format, $encode=0, $maxnumberofemail=0)
Return a formatted address string for SMTP protocol.
Parent class of all other business classes (invoices, contracts, proposals, orders,...
fetch_optionals($rowid=null, $optionsArray=null)
Function to get extra fields of an object into $this->array_options This method is in most cases call...
commonGenerateDocument($modelspath, $modele, $outputlangs, $hidedetails, $hidedesc, $hideref, $moreparams=null)
Common function for all objects extending CommonObject for generating documents.
setErrorsFromObject($object)
setErrorsFromObject
deleteExtraFields()
Delete all extra fields values for the current object.
static commonReplaceThirdparty(DoliDB $dbs, $origin_id, $dest_id, array $tables, $ignoreerrors=0)
Function used to replace a thirdparty id with another one.
insertExtraFields($trigger='', $userused=null)
Add/Update all extra fields values for the current object.
call_trigger($triggerName, $user)
Call trigger based on this instance.
Class to manage invoices.
const TYPE_STANDARD
Standard invoice.
Class to manage mailman and spip.
Class to manage payments of customer invoices.
Class to manage payment terms records in dictionary.
Class to manage third parties objects (customers, suppliers, prospects...)
Class to manage subscriptions of foundation members.
Class to manage translations.
Class to manage Dolibarr users.
print $langs trans("Ref").' m titre as m m statut as status
Or an array listing all the potential status of the object: array: int of the status => translated la...
getFullName($langs, $option=0, $nameorder=-1, $maxlen=0)
Return full name (civility+' '+name+' '+lastname)
setUpperOrLowerCase()
Set to upper or ucwords/lower if needed.
getCountry($searchkey, $withcode='', $dbtouse=null, $outputlangs=null, $entconv=1, $searchlabel='')
Return country label, code or id from an id, code or label.
dol_time_plus_duree($time, $duration_value, $duration_unit, $ruleforendofmonth=0)
Add a delay to a date.
print $script_file $mode $langs defaultlang(is_numeric($duration_value) ? " delay=". $duration_value :"").(is_numeric($duration_value2) ? " after cd cd cd description as p label as s rowid as s nom as s email
Sender: Who sends the email ("Sender" has sent emails on behalf of "From").
clean_url($url, $http=1)
Clean an url string.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm='auto', $check=1)
Return a timestamp date built from detailed information (by default a local PHP server timestamp) Rep...
dol_getIdFromCode($db, $key, $tablename, $fieldkey='code', $fieldid='id', $entityfilter=0, $filters='', $useCache=true)
Return an id or code from a code or id.
getLanguageCodeFromCountryCode($countrycode)
Return default language from country code.
setEntity($currentobject)
Set entity id to use when to create an object.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2, $allowothertags=array())
Show picto whatever it's its name (generic function)
dol_format_address($object, $withcountry=0, $sep="\n", $outputlangs=null, $mode=0, $extralangcode='')
Return a formatted address (part address/zip/town/state) according to country rules.
dol_string_nohtmltag($stringtoclean, $removelinefeed=1, $pagecodeto='UTF-8', $strip_tags=0, $removedoublespaces=1)
Clean a string from all HTML tags and entities.
price2num($amount, $rounding='', $option=0)
Function that return a number with universal decimal format (decimal separator is '.
img_object($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $allowothertags=array())
Show a picto called object_picto (generic function)
dol_strlen($string, $stringencoding='UTF-8')
Make a strlen call.
GETPOSTISARRAY($paramname, $method=0)
Return true if the parameter $paramname is submit from a POST OR GET as an array.
dol_now($mode='auto')
Return date for now.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
dol_concatdesc($text1, $text2, $forxml=false, $invert=false)
Concat 2 descriptions with a new line between them (second operand after first one with appropriate n...
dolGetFirstLetters($s, $nbofchar=1)
Return first letters of a strings.
dol_strtoupper($string, $encoding="UTF-8")
Convert a string to upper.
yn($yesno, $format=1, $color=0)
Return yes or no in current language.
complete_substitutions_array(&$substitutionarray, $outputlangs, $object=null, $parameters=null, $callfunc="completesubstitutionarray")
Complete the $substitutionarray with more entries coming from external module that had set the "subst...
dolGetStatus($statusLabel='', $statusLabelShort='', $html='', $statusType='status0', $displayMode=0, $url='', $params=array())
Output the badge of a status.
make_substitutions($text, $substitutionarray, $outputlangs=null, $converttextinhtmlifnecessary=0)
Make substitution into a text string, replacing keys with vals from $substitutionarray (oldval=>newva...
getArrayOfSocialNetworks()
Get array of social network dictionary.
dol_textishtml($msg, $option=0)
Return if a text is a html content.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_buildpath($path, $type=0, $returnemptyifnotfound=0)
Return path of url or filesystem.
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
dol_trunc($string, $size=40, $trunc='right', $stringencoding='UTF-8', $nodot=0, $display=0)
Truncate a string to a particular length adding '…' if string larger than length.
dol_htmlentitiesbr($stringtoencode, $nl2brmode=0, $pagecodefrom='UTF-8', $removelasteolbr=1)
This function is called to encode a string into a HTML string but differs from htmlentities because a...
isValidEmail($address, $acceptsupervisorkey=0, $acceptuserkey=0)
Return true if email syntax is ok.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
get_default_tva(Societe $thirdparty_seller, Societe $thirdparty_buyer, $idprod=0, $idprodfournprice=0)
Function that return vat rate of a product line (according to seller, buyer and product vat rate) VAT...
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
dol_getdate($timestamp, $fast=false, $forcetimezone='')
Return an array with locale date info.
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags='', $escapeonlyhtmltags=0, $cleanalsojavascript=0)
Returns text escaped for inclusion in HTML alt or title or value tags, or into values of HTML input f...
div refaddress div address
global $conf
The following vars must be defined: $type2label $form $conf, $lang, The following vars may also be de...
if(preg_match('/(crypted|dolcrypt):/i', $dolibarr_main_db_pass)||!empty($dolibarr_main_db_encrypted_pass)) $conf db type
getRandomPassword($generic=false, $replaceambiguouschars=null, $length=32)
Return a generated password using default module.
dol_hash($chain, $type='0', $nosalt=0, $mode=0)
Returns a hash (non reversible encryption) of a string.
dolGetLdapPasswordHash($password, $type='md5')
Returns a specific ldap hash of a password.