. */ 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 = '