295 lines
9.3 KiB
PHP
Executable File
295 lines
9.3 KiB
PHP
Executable File
<?php
|
|
/*
|
|
* OpenSTAManager: il software gestionale open source per l'assistenza tecnica e la fatturazione
|
|
* Copyright (C) DevCode s.r.l.
|
|
*
|
|
* 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 3 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, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
use Modules\Anagrafiche\Anagrafica;
|
|
use Modules\Anagrafiche\Referente;
|
|
use Modules\Anagrafiche\Sede;
|
|
use Modules\Emails\Template;
|
|
use Modules\ListeNewsletter\Lista;
|
|
use Modules\Newsletter\Newsletter;
|
|
use Notifications\EmailNotification;
|
|
use PHPMailer\PHPMailer\Exception;
|
|
|
|
include_once __DIR__.'/../../core.php';
|
|
|
|
switch (filter('op')) {
|
|
case 'add':
|
|
$template = Template::find(post('id_template'));
|
|
$newsletter = Newsletter::build($user, $template, filter('name'));
|
|
$id_record = $newsletter->id;
|
|
|
|
flash()->info(tr('Nuova campagna newsletter creata!'));
|
|
|
|
break;
|
|
|
|
case 'update':
|
|
$newsletter->name = filter('name');
|
|
$newsletter->state = filter('state');
|
|
$newsletter->completed_at = filter('completed_at');
|
|
|
|
$newsletter->subject = filter('subject');
|
|
$newsletter->content = $_POST['content']; // post('content', true);
|
|
|
|
$newsletter->save();
|
|
|
|
flash()->info(tr('Campagna newsletter salvata!'));
|
|
|
|
if ($newsletter['state'] === 'OK') {
|
|
$newsletter->completed_at = $newsletter->updated_at;
|
|
}
|
|
|
|
$newsletter->save();
|
|
|
|
break;
|
|
|
|
case 'delete':
|
|
$newsletter->delete();
|
|
|
|
flash()->info(tr('Campagna newsletter rimossa!'));
|
|
|
|
break;
|
|
|
|
case 'send':
|
|
$newsletter = Newsletter::find($id_record);
|
|
|
|
$destinatari = $newsletter->destinatari();
|
|
$count = $destinatari->count();
|
|
for ($i = 0; $i < $count; ++$i) {
|
|
$destinatario = $destinatari->skip($i)->first();
|
|
|
|
if (empty($destinatario->id_email)) {
|
|
$mail = $newsletter->inviaDestinatario($destinatario);
|
|
|
|
// Aggiornamento riferimento per la newsletter
|
|
if (!empty($mail)) {
|
|
$destinatario->id_email = $mail->id;
|
|
$destinatario->save();
|
|
}
|
|
}
|
|
}
|
|
|
|
// Aggiornamento stato newsletter
|
|
$newsletter->state = 'WAIT';
|
|
$newsletter->save();
|
|
|
|
flash()->info(tr('Campagna newsletter in invio!'));
|
|
|
|
break;
|
|
|
|
case 'send-line':
|
|
$receiver_id = post('id');
|
|
$receiver_type = post('type');
|
|
$test = post('test');
|
|
|
|
// Individuazione destinatario interessato
|
|
$newsletter = Newsletter::find($id_record);
|
|
$destinatario = $newsletter->destinatari()
|
|
->where('record_type', '=', $receiver_type)
|
|
->where('record_id', '=', $receiver_id)
|
|
->first();
|
|
|
|
// Generazione email e tentativo di invio
|
|
$inviata = false;
|
|
if (!empty($destinatario)) {
|
|
if ($test) {
|
|
$mail = $newsletter->inviaDestinatario($destinatario, true);
|
|
|
|
try {
|
|
$email = EmailNotification::build($mail, true);
|
|
$email->send();
|
|
|
|
$inviata = true;
|
|
} catch (Exception) {
|
|
// $mail->delete();
|
|
}
|
|
} else {
|
|
$mail = $newsletter->inviaDestinatario($destinatario);
|
|
|
|
// Aggiornamento riferimento per la newsletter
|
|
if (!empty($mail)) {
|
|
$destinatario->id_email = $mail->id;
|
|
$destinatario->save();
|
|
$inviata = true;
|
|
}
|
|
}
|
|
}
|
|
|
|
echo json_encode([
|
|
'result' => $inviata,
|
|
]);
|
|
|
|
break;
|
|
|
|
case 'block':
|
|
$mails = $newsletter->emails;
|
|
|
|
foreach ($mails as $mail) {
|
|
if (!empty($mail->sent_at)) {
|
|
continue;
|
|
}
|
|
|
|
// Rimozione riferimento email dalla newsletter
|
|
$database->update('em_newsletter_receiver', [
|
|
'id_email' => $null,
|
|
], [
|
|
'id_email' => $mail->id,
|
|
'id_newsletter' => $newsletter->id,
|
|
]);
|
|
|
|
// Rimozione email
|
|
$mail->delete();
|
|
}
|
|
|
|
// Aggiornamento stato newsletter
|
|
$newsletter->state = 'DEV';
|
|
$newsletter->save();
|
|
|
|
flash()->info(tr('Coda della campagna newsletter svuotata!'));
|
|
|
|
break;
|
|
|
|
case 'add_receivers':
|
|
// Selezione manuale
|
|
$id_receivers = post('receivers');
|
|
foreach ($id_receivers as $id_receiver) {
|
|
[$tipo, $id] = explode('_', (string) $id_receiver);
|
|
if ($tipo == 'anagrafica') {
|
|
$type = Anagrafica::class;
|
|
} elseif ($tipo == 'sede') {
|
|
$type = Sede::class;
|
|
} else {
|
|
$type = Referente::class;
|
|
}
|
|
|
|
// Dati di registrazione
|
|
$data = [
|
|
'record_type' => $type,
|
|
'record_id' => $id,
|
|
'id_newsletter' => $newsletter->id,
|
|
];
|
|
|
|
// Aggiornamento destinatari
|
|
$registrato = $database->select('em_newsletter_receiver', '*', [], $data);
|
|
if (empty($registrato)) {
|
|
$database->insert('em_newsletter_receiver', $data);
|
|
}
|
|
}
|
|
|
|
// Selezione da lista newsletter
|
|
$id_list = post('id_list');
|
|
if (!empty($id_list)) {
|
|
// Aggiornamento della lista
|
|
$lista = Lista::find($id_list);
|
|
$query = $lista->query;
|
|
if (check_query($query)) {
|
|
$lista->query = html_entity_decode($query);
|
|
}
|
|
$lista->save();
|
|
|
|
// Rimozione preventiva dei record duplicati dalla newsletter
|
|
$database->query('DELETE em_newsletter_receiver.* FROM em_newsletter_receiver
|
|
INNER JOIN em_list_receiver ON em_list_receiver.record_type = em_newsletter_receiver.record_type AND em_list_receiver.record_id = em_newsletter_receiver.record_id
|
|
WHERE em_newsletter_receiver.id_newsletter = '.prepare($newsletter->id).' AND em_list_receiver.id_list = '.prepare($id_list));
|
|
|
|
// Copia dei record della lista newsletter
|
|
$database->query('INSERT INTO em_newsletter_receiver (id_newsletter, record_type, record_id) SELECT '.prepare($newsletter->id).', record_type, record_id FROM em_list_receiver WHERE id_list = '.prepare($id_list));
|
|
}
|
|
|
|
/*
|
|
// Controllo indirizzo e-mail presente
|
|
$destinatari = $newsletter->destinatari();
|
|
foreach ($destinatari as $destinatario) {
|
|
$anagrafica = $destinatario instanceof Anagrafica ? $destinatario : $destinatario->anagrafica;
|
|
|
|
if (!empty($destinatario->email)) {
|
|
$check = Validate::isValidEmail($destinatario->email);
|
|
|
|
if (empty($check['valid-format'])) {
|
|
$errors[] = $destinatario->email;
|
|
}
|
|
} else {
|
|
$descrizione = $anagrafica->ragione_sociale;
|
|
|
|
if ($destinatario instanceof Sede) {
|
|
$descrizione .= ' ['.$destinatario->nomesede.']';
|
|
} elseif ($destinatario instanceof Referente) {
|
|
$descrizione .= ' ['.$destinatario->nome.']';
|
|
}
|
|
|
|
$errors[] = tr('Indirizzo e-mail mancante per "_NOME_"', [
|
|
'_NOME_' => $descrizione,
|
|
]);
|
|
}
|
|
}
|
|
|
|
if (!empty($errors)) {
|
|
$message = '<ul>';
|
|
foreach ($errors as $error) {
|
|
$message .= '<li>'.$error.'</li>';
|
|
}
|
|
$message .= '</ul>';
|
|
}*/
|
|
|
|
if (!empty($message)) {
|
|
flash()->warning(tr('Attenzione questi indirizzi e-mail non sembrano essere validi: _EMAIL_ ', [
|
|
'_EMAIL_' => $message,
|
|
]));
|
|
} else {
|
|
flash()->info(tr('Nuovi destinatari aggiunti correttamente alla newsletter!'));
|
|
}
|
|
|
|
break;
|
|
|
|
case 'remove_receiver':
|
|
$receiver_id = post('id');
|
|
$receiver_type = post('type');
|
|
|
|
$database->delete('em_newsletter_receiver', [
|
|
'record_type' => $receiver_type,
|
|
'record_id' => $receiver_id,
|
|
'id_newsletter' => $newsletter->id,
|
|
]);
|
|
|
|
flash()->info(tr('Destinatario rimosso dalla newsletter!'));
|
|
|
|
break;
|
|
|
|
case 'remove_all_receivers':
|
|
$database->delete('em_newsletter_receiver', [
|
|
'id_newsletter' => $newsletter->id,
|
|
]);
|
|
|
|
flash()->info(tr('Tutti i destinatari sono stati rimossi dalla newsletter!'));
|
|
|
|
break;
|
|
|
|
// Duplica newsletter
|
|
case 'copy':
|
|
$new = $newsletter->replicate();
|
|
$new->state = 'DEV';
|
|
$new->completed_at = null;
|
|
$new->save();
|
|
|
|
$id_record = $new->id;
|
|
|
|
flash()->info(tr('Newsletter duplicata correttamente!'));
|
|
|
|
break;
|
|
}
|