80 global $conf, $langs, $user;
84 if ($managedfor !=
'member') {
89 $MAXPERCALL = (!
getDolGlobalString(
'PARTNERSHIP_MAX_EXPIRATION_CANCEL_PER_CALL') ? 25 : $conf->global->PARTNERSHIP_MAX_EXPIRATION_CANCEL_PER_CALL);
91 $langs->loadLangs(array(
"partnership",
"member"));
97 $partnershipsprocessed = array();
99 $gracedelay =
getDolGlobalString(
'PARTNERSHIP_NBDAYS_AFTER_MEMBER_EXPIRATION_BEFORE_CANCEL');
100 if ($gracedelay < 1) {
101 $this->error =
'BadValueForDelayBeforeCancelCheckSetup';
105 dol_syslog(get_class($this).
"::doCancelStatusOfMemberPartnership cancel expired partnerships with grace delay of ".$gracedelay);
112 $sql =
"SELECT p.rowid, p.fk_member, p.status";
113 $sql .=
", d.datefin, d.fk_adherent_type, dty.subscription";
114 $sql .=
" FROM ".MAIN_DB_PREFIX.
"partnership as p";
115 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"adherent as d on (d.rowid = p.fk_member)";
116 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"adherent_type as dty on (dty.rowid = d.fk_adherent_type)";
117 $sql .=
" WHERE fk_member > 0";
118 $sql .=
" AND (d.datefin < '".$this->db->idate($datetotest).
"' AND dty.subscription = 1)";
119 $sql .=
" AND p.status = ".((int) $partnership::STATUS_APPROVED);
120 $sql .= $this->db->order(
'd.rowid',
'ASC');
123 $numofexpiredmembers = 0;
124 $resql = $this->db->query($sql);
126 $numofexpiredmembers = $this->db->num_rows($resql);
128 $somethingdoneonpartnership = 0;
130 while ($ifetchpartner < $numofexpiredmembers) {
133 $obj = $this->db->fetch_object($resql);
135 if (!empty($partnershipsprocessed[$obj->rowid])) {
139 if ($somethingdoneonpartnership >= $MAXPERCALL) {
140 dol_syslog(
"We reach the limit of ".$MAXPERCALL.
" partnership processed, so we quit loop for this batch doCancelStatusOfMemberPartnership to avoid to reach email quota.", LOG_WARNING);
148 $expirationdate = $obj->datefin;
150 if ($expirationdate && $expirationdate < $now) {
151 $somethingdoneonpartnership++;
153 $result =
$object->cancel($user, 0);
159 if (is_array($this->errors)) {
160 $this->errors = array_merge($this->errors,
$object->errors);
162 $this->errors =
$object->errors;
169 $labeltemplate =
'('.getDolGlobalString(
'PARTNERSHIP_SENDMAIL_IF_AUTO_CANCEL',
'SendingEmailOnPartnershipCanceled').
')';
171 dol_syslog(
"Now we will send an email to member id=".
$object->fk_member.
" with label ".$labeltemplate);
174 include_once DOL_DOCUMENT_ROOT.
'/core/class/html.formmail.class.php';
175 include_once DOL_DOCUMENT_ROOT.
'/core/class/CMailFile.class.php';
176 $formmail =
new FormMail($this->db);
179 $outputlangs = $langs;
182 $newlang =
GETPOST(
'lang_id',
'aZ09');
184 if (!empty($newlang)) {
186 $outputlangs->setDefaultLang($newlang);
187 $outputlangs->loadLangs(array(
'main',
'member',
'partnership'));
190 $arraydefaultmessage = $formmail->getEMailTemplate($this->db,
'partnership_send', $user, $outputlangs, 0, 1, $labeltemplate);
192 $substitutionarray = getCommonSubstitutionArray($outputlangs, 0,
null,
$object);
195 $subject =
make_substitutions($arraydefaultmessage->topic, $substitutionarray, $outputlangs);
196 $msg =
make_substitutions($arraydefaultmessage->content, $substitutionarray, $outputlangs);
200 $fk_partner =
$object->fk_member;
202 $adherent =
new Adherent($this->db);
203 $adherent->fetch(
$object->fk_member);
204 $sendto = $adherent->email;
206 $trackid =
'par'.$object->id;
207 $sendcontext =
'standard';
209 $cmail =
new CMailFile($subject, $sendto, $from, $msg, array(), array(), array(),
'',
'', 0, 1,
'',
'', $trackid,
'', $sendcontext);
211 $result = $cmail->sendfile();
213 if (!$result || !empty($cmail->error) || !empty($cmail->errors)) {
214 $erroremail .= ($erroremail ?
', ' :
'').$cmail->error;
215 $this->errors[] = $cmail->error;
216 if (is_array($cmail->errors) && count($cmail->errors) > 0) {
217 $this->errors += $cmail->errors;
222 $actiontypecode =
'AC_OTH_AUTO';
223 $attachedfiles = array();
225 $object->actiontypecode = $actiontypecode;
226 $object->actionmsg = $arraydefaultmessage->topic.
"\n".$arraydefaultmessage->content;
227 $object->actionmsg2 = $langs->transnoentities(
"PartnershipSentByEMail",
$object->ref);
230 $object->actionmsg2 = $subject;
236 if (is_array($attachedfiles) && count($attachedfiles) > 0) {
237 $object->attachedfiles = $attachedfiles;
241 $object->email_subject = $subject;
243 $object->email_subject = $subject;
245 $triggersendname =
'PARTNERSHIP_SENTBYMAIL';
247 if (!empty($triggersendname)) {
248 $result =
$object->call_trigger($triggersendname, $user);
262 $this->error = $this->db->lasterror();
267 $this->output = $numofexpiredmembers.
' expired partnership members found'.
"\n";
269 $this->output .=
'. Got errors when sending some email : '.$erroremail;
272 $this->db->rollback();
273 $this->output =
"Rollback after error\n";
274 $this->output .= $numofexpiredmembers.
' expired partnership members found'.
"\n";
276 $this->output .=
'. Got errors when sending some email : '.$erroremail;
294 global $conf, $langs, $user;
299 if (empty($maxpercall)) {
300 $maxpercall =
getDolGlobalInt(
'PARTNERSHIP_MAX_WARNING_BACKLINK_PER_CALL', 10);
303 $langs->loadLangs(array(
"partnership",
"member"));
309 $partnershipsprocessed = array();
311 $websitenotfound =
'';
319 $fk_partner = ($managedfor ==
'member') ?
'fk_member' :
'fk_soc';
321 dol_syslog(get_class($this).
"::doWarningOfPartnershipIfDolibarrBacklinkNotfound Warning of partnership");
328 $sql =
"SELECT p.rowid, p.status, p.".$fk_partner;
329 $sql .=
", p.url_to_check, p.last_check_backlink";
330 $sql .=
', partner.url, partner.email';
331 $sql .=
" FROM ".MAIN_DB_PREFIX.
"partnership as p";
332 if ($managedfor ==
'member') {
333 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"adherent as partner on (partner.rowid = p.fk_member)";
335 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe as partner on (partner.rowid = p.fk_soc)";
337 $sql .=
" WHERE p.".$fk_partner.
" > 0";
338 $sql .=
" AND p.status = ".((int) $partnership::STATUS_APPROVED);
339 $sql .=
" AND (p.last_check_backlink IS NULL OR p.last_check_backlink <= '".$this->db->idate($now - 24 * 3600).
"')";
340 $sql .= $this->db->order(
'p.rowid',
'ASC');
343 $numofexpiredmembers = 0;
344 $resql = $this->db->query($sql);
346 $numofexpiredmembers = $this->db->num_rows($resql);
347 $somethingdoneonpartnership = 0;
349 while ($ifetchpartner < $numofexpiredmembers) {
352 $obj = $this->db->fetch_object($resql);
354 if (!empty($partnershipsprocessed[$obj->rowid])) {
358 if ($somethingdoneonpartnership >= $maxpercall) {
359 dol_syslog(
"We reach the limit of ".$maxpercall.
" partnership processed, so we quit loop for this batch doWarningOfPartnershipIfDolibarrBacklinkNotfound to avoid to reach email quota.", LOG_WARNING);
368 if ($managedfor ==
'member') {
369 $fk_partner =
$object->fk_member;
374 $website = (empty($obj->url_to_check) ? $obj->url : $obj->url_to_check);
376 if (empty($website)) {
377 $websitenotfound .= ($websitenotfound ?
', ' :
'').
'Website not found for id="'.$fk_partner.
'"'.
"\n";
382 if (!$backlinkfound) {
383 $tmpcount =
$object->count_last_url_check_error + 1;
385 $nbminbacklinkerrorforcancel = (int)
getDolGlobalString(
'PARTNERSHIP_MIN_BACKLINK_ERROR_FOR_CANCEL', 3);
386 $nbmaxbacklinkerrorforcancel = (int)
getDolGlobalString(
'PARTNERSHIP_MAX_BACKLINK_ERROR_FOR_CANCEL', (
int) $nbminbacklinkerrorforcancel + 2);
389 if ($nbminbacklinkerrorforcancel > 0) {
390 if ($tmpcount > $nbminbacklinkerrorforcancel && $tmpcount <= $nbmaxbacklinkerrorforcancel) {
391 if (!empty($obj->email)) {
392 $emailnotfound .= ($emailnotfound ?
', ' :
'').
'Email not found for id="'.$fk_partner.
'"'.
"\n";
395 $labeltemplate =
'('.getDolGlobalString(
'PARTNERSHIP_SENDMAIL_IF_NO_LINK',
'SendingEmailOnPartnershipWillSoonBeCanceled').
')';
397 dol_syslog(
"Now we will send an email to partner id=".$fk_partner.
" with label ".$labeltemplate);
400 include_once DOL_DOCUMENT_ROOT.
'/core/class/html.formmail.class.php';
401 include_once DOL_DOCUMENT_ROOT.
'/core/class/CMailFile.class.php';
402 $formmail =
new FormMail($this->db);
405 $outputlangs = $langs;
408 $newlang =
GETPOST(
'lang_id',
'aZ09');
410 if (!empty($newlang)) {
412 $outputlangs->setDefaultLang($newlang);
413 $outputlangs->loadLangs(array(
'main',
'member',
'partnership'));
416 $arraydefaultmessage = $formmail->getEMailTemplate($this->db,
'partnership_send', $user, $outputlangs, 0, 1, $labeltemplate);
418 $substitutionarray = getCommonSubstitutionArray($outputlangs, 0,
null,
$object);
421 $subject =
make_substitutions($arraydefaultmessage->topic, $substitutionarray, $outputlangs);
422 $msg =
make_substitutions($arraydefaultmessage->content, $substitutionarray, $outputlangs);
425 $sendto = $obj->email;
427 $trackid =
'par'.$object->id;
428 $sendcontext =
'standard';
430 $cmail =
new CMailFile($subject, $sendto, $from, $msg, array(), array(), array(),
'',
'', 0, 1,
'',
'', $trackid,
'', $sendcontext);
432 $result = $cmail->sendfile();
434 if (!$result || !empty($cmail->error) || !empty($cmail->errors)) {
435 $erroremail .= ($erroremail ?
', ' :
'').$cmail->error;
436 $this->errors[] = $cmail->error;
437 if (is_array($cmail->errors) && count($cmail->errors) > 0) {
438 $this->errors += $cmail->errors;
443 $actiontypecode =
'AC_OTH_AUTO';
444 $attachedfiles = array();
446 if ($managedfor !=
'member') {
449 $object->actiontypecode = $actiontypecode;
450 $object->actionmsg = $arraydefaultmessage->topic.
"\n".$arraydefaultmessage->content;
451 $object->actionmsg2 = $langs->transnoentities(
"PartnershipSentByEMail",
$object->ref);
454 $object->actionmsg2 = $subject;
460 if (is_array($attachedfiles) && count($attachedfiles) > 0) {
461 $object->attachedfiles = $attachedfiles;
465 $object->email_subject = $subject;
467 $object->email_subject = $subject;
469 $triggersendname =
'PARTNERSHIP_SENTBYMAIL';
471 if (!empty($triggersendname)) {
472 $result =
$object->call_trigger($triggersendname, $user);
481 } elseif ($tmpcount > $nbmaxbacklinkerrorforcancel) {
482 $object->status = $object::STATUS_CANCELED;
483 $object->reason_decline_or_cancel = $langs->trans(
'BacklinkNotFoundOnPartnerWebsite');
487 $object->count_last_url_check_error = $tmpcount;
489 $object->count_last_url_check_error = 0;
490 $object->reason_decline_or_cancel =
'';
495 $object->last_check_backlink = $now;
502 $this->error = $this->db->lasterror();
509 $this->db->rollback();
510 $this->output =
"Rollback after error\n";
512 $this->output .= $numofexpiredmembers.
' partnership checked'.
"\n";
514 $this->output .=
'. Got errors when sending some email : '.$erroremail.
"\n";
516 if ($emailnotfound) {
517 $this->output .=
'. Email not found for some partner : '.$emailnotfound.
"\n";
519 if ($websitenotfound) {
520 $this->output .=
'. Website not found for some partner : '.$websitenotfound.
"\n";
522 $this->output .=
"\nSQL used to find partnerships to scan: ".$sql;