Compare commits

...

2 commits

2 changed files with 103 additions and 29 deletions

60
loader.php Normal file
View file

@ -0,0 +1,60 @@
<?php
include_once 'config/config.php';
include_once "vendor/notorm/NotORM.php";
//exit('Commentami, lanciami e ricommentami.');
function getToken($length = 12){
return uniqId();
//PHP7
//return bin2hex(random_bytes($length));
}
$pdo = new PDO("mysql:host=".$db_host.";dbname=".$db_dbname,
$db_user,
$db_pass
);
function getMyDateFormatted($datestr){
$date = null;
if(empty($datestr)){
$date = new DateTime();
} else {
$date = new DateTime($datestr);
}
return $date->format('Y-m-d');
}
$db = new NotORM($pdo);
$db->debug = true;
$today = getMyDateFormatted("");
$last = getMyDateFormatted($rollday);
//Inserisco la mailing list e ottengo l'id
$ret = $db->roll()->insert(array(
"ml" => $ml,
"startroll" => $today,
"endroll" => $last
));
$file = fopen($filename, "r");
while(!feof($file)){
$line = fgets($file);
$sanitized_mail = filter_var($line, FILTER_SANITIZE_EMAIL);
if($sanitized_mail !== "") {
$token = getToken();
//Inserisco le mail dei membri della mailing list
$db->$db_table()->insert(array(
"id" => $ret['id'],
"token" => $token,
"email" => $sanitized_mail
));
}
}
fclose($file);

View file

@ -3,13 +3,7 @@ require_once 'vendor/phpmailer/phpmailer/PHPMailerAutoload.php';
include_once 'config/config.php'; include_once 'config/config.php';
include_once "vendor/notorm/NotORM.php"; include_once "vendor/notorm/NotORM.php";
exit('Commentami, lanciami e ricommentami.'); //exit('Commentami, lanciami e ricommentami.');
function getToken($length = 12){
return uniqId();
//PHP7
//return bin2hex(random_bytes($length));
}
function generateLink($url, $token, $ml, $email){ function generateLink($url, $token, $ml, $email){
$link = $url."/mlMemberRoller/stayin.php?"; $link = $url."/mlMemberRoller/stayin.php?";
@ -44,31 +38,51 @@ $mail->isHTML(false); // Set email format to HTML
$mail->setFrom($sender, $senderName); $mail->setFrom($sender, $senderName);
$mail->Subject = $subject; $mail->Subject = $subject;
//$db->debug = true; $db->debug = true;
$file = fopen($filename, "r"); //cerco la ml che ha lo end date.
while(!feof($file)){ //prendo l'id
$line = fgets($file); //prendo tutte le email con quel id che hanno renewed = 0
$sanitized_mail = filter_var($line, FILTER_SANITIZE_EMAIL); //ciclo
if($sanitized_mail !== "") { function getMyDateFormatted($datestr){
$mail->addAddress($sanitized_mail); $date = null;
$token = getToken(); if(empty($datestr)){
$link = generateLink($mlrollmember_url, $token, $ml, $sanitized_mail); $date = new DateTime();
$mail->Body = $def_body.$link; } else {
$date = new DateTime($datestr);
}
return $date->format('Y-m-d');
}
$db->$db_table()->insert(array( $last = getMyDateFormatted($rollday);
"token" => $token, $rolls = $db->roll()->where(array(
"ml" => $ml, "ml" => $ml,
"email" => $sanitized_mail "endroll" => $last
)); ));
if(!$mail->send()) {
echo 'Message could not be sent.'."\n"; foreach($rolls as $roll) {
echo 'Mailer Error: ' . $mail->ErrorInfo."\n"; $members = $db->$db_table()->where(array(
} else { "id" => $roll['id'],
echo 'Message has been sent'."\n"; "renewed" => 0
));
foreach($members as $member) {
$sanitized_mail = filter_var($member['email'], FILTER_SANITIZE_EMAIL);
if($sanitized_mail !== "") {
$mail->addAddress($sanitized_mail);
$token = $member['token'];
$link = generateLink($mlrollmember_url, $token, $ml, $sanitized_mail);
$mail->Body = $def_body.$link;
if(!$mail->send()) {
echo 'Message could not be sent.'."\n";
echo 'Mailer Error: ' . $mail->ErrorInfo."\n";
} else {
echo 'Message has been sent'."\n";
}
} }
} }
} }
fclose($file);