Fix use of old db

This commit is contained in:
osaajani 2019-11-04 18:23:11 +01:00
parent 628527c70f
commit 46ebd39c04
6 changed files with 54 additions and 48 deletions

View File

@ -14,14 +14,34 @@ namespace controllers\internals;
class Console extends \descartes\InternalController class Console extends \descartes\InternalController
{ {
private $model_command;
private $model_database;
private $model_sended;
private $model_smsstop;
private $model_received;
private $model_user;
private $internal_event;
public function __construct(\PDO $bdd)
{
$this->model_command = new \models\Command($bdd);
$this->model_database = new \models\DataBase($bdd);
$this->model_sended = new \models\Sended($bdd);
$this->model_smsstop = new \models\SmsStop($bdd);
$this->model_received = new \models\Received($bdd);
$this->model_user = new \models\User($bdd);
$this->internal_event = new \controllers\internals\Event($bdd);
}
/** /**
* Cette fonction envoie tous les Sms programmés qui doivent l'être. * Cette fonction envoie tous les Sms programmés qui doivent l'être.
*/ */
public function sendScheduled() public function sendScheduled()
{ {
//On créé l'objet de base de données //On créé l'objet de base de données
global $db;
for ($i = 0; $i < 30; ++$i) for ($i = 0; $i < 30; ++$i)
{ {
$now = new \DateTime(); $now = new \DateTime();
@ -29,7 +49,7 @@ class Console extends \descartes\InternalController
echo "Début de l'envoi des Sms programmés\n"; echo "Début de l'envoi des Sms programmés\n";
$scheduleds = $db->getScheduledNotInProgressBefore($now); $scheduleds = $this->model_database->getScheduledNotInProgressBefore($now);
$ids_scheduleds = []; $ids_scheduleds = [];
@ -41,7 +61,7 @@ class Console extends \descartes\InternalController
echo \count($ids_scheduleds)." Sms à envoyer ont été trouvés et ajoutés à la liste des Sms en cours d'envoi.\n"; echo \count($ids_scheduleds)." Sms à envoyer ont été trouvés et ajoutés à la liste des Sms en cours d'envoi.\n";
$db->updateProgressScheduledIn($ids_scheduleds, true); $this->model_database->updateProgressScheduledIn($ids_scheduleds, true);
//Pour chaque Sms à envoyer //Pour chaque Sms à envoyer
foreach ($scheduleds as $scheduled) foreach ($scheduleds as $scheduled)
@ -54,32 +74,32 @@ class Console extends \descartes\InternalController
$numbers = []; $numbers = [];
//On récupère les numéros pour le Sms et on les ajoute //On récupère les numéros pour le Sms et on les ajoute
$target_numbers = $db->getNumbersForScheduled($id_scheduled); $target_numbers = $this->model_database->getNumbersForScheduled($id_scheduled);
foreach ($target_numbers as $target_number) foreach ($target_numbers as $target_number)
{ {
$numbers[] = $target_number['number']; $numbers[] = $target_number['number'];
} }
//On récupère les contacts, et on ajoute les numéros //On récupère les contacts, et on ajoute les numéros
$contacts = $db->getContactForScheduled($id_scheduled); $contacts = $this->model_database->getContactForScheduled($id_scheduled);
foreach ($contacts as $contact) foreach ($contacts as $contact)
{ {
$numbers[] = $contact['number']; $numbers[] = $contact['number'];
} }
//On récupère les groups //On récupère les groups
$groups = $db->getGroupForScheduled($id_scheduled); $groups = $this->model_database->getGroupForScheduled($id_scheduled);
foreach ($groups as $group) foreach ($groups as $group)
{ {
//On récupère les contacts du group et on les ajoute aux numéros //On récupère les contacts du group et on les ajoute aux numéros
$contacts = $db->getContactForGroup($group['id']); $contacts = $this->model_database->getContactForGroup($group['id']);
foreach ($contacts as $contact) foreach ($contacts as $contact)
{ {
$numbers[] = $contact['number']; $numbers[] = $contact['number'];
} }
} }
$smsStops = $db->getFromTableWhere('smsstop'); $smsStops = $this->model_smsstop->_select('smsstop');
foreach ($numbers as $number) foreach ($numbers as $number)
{ {
@ -106,13 +126,11 @@ class Console extends \descartes\InternalController
$now = $now->format('Y-m-d H:i:s'); $now = $now->format('Y-m-d H:i:s');
//On peut maintenant ajouter le Sms //On peut maintenant ajouter le Sms
if (!$db->insertIntoTable('sendeds', ['at' => $now, 'target' => $number, 'content' => $scheduled['content'], 'before_delivered' => ceil(mb_strlen($scheduled['content']) / 160)])) if (!$id_sended = $this->model_sended->insert(['at' => $now, 'target' => $number, 'content' => $scheduled['content'], 'before_delivered' => ceil(mb_strlen($scheduled['content']) / 160)]))
{ {
echo 'Impossible d\'inserer le sms pour le numero '.$number."\n"; echo 'Impossible d\'inserer le sms pour le numero '.$number."\n";
} }
$id_sended = $db->lastId();
//Commande qui envoie le Sms //Commande qui envoie le Sms
$commande_send_sms = 'gammu-smsd-inject TEXT '.escapeshellarg($number).' -report -len '.mb_strlen($text_sms).' -text '.$text_sms; $commande_send_sms = 'gammu-smsd-inject TEXT '.escapeshellarg($number).' -report -len '.mb_strlen($text_sms).' -text '.$text_sms;
@ -131,7 +149,7 @@ class Console extends \descartes\InternalController
echo "Tous les Sms sont en cours d'envoi.\n"; echo "Tous les Sms sont en cours d'envoi.\n";
//Tous les Sms ont été envoyés. //Tous les Sms ont été envoyés.
$db->deleteScheduledIn($ids_scheduleds); $this->model_database->deleteScheduledIn($ids_scheduleds);
//On dors 2 secondes //On dors 2 secondes
sleep(2); sleep(2);
@ -144,8 +162,6 @@ class Console extends \descartes\InternalController
public function parseReceivedSms() public function parseReceivedSms()
{ {
//On créer l'objet de base de données //On créer l'objet de base de données
global $db;
for ($i = 0; $i < 30; ++$i) for ($i = 0; $i < 30; ++$i)
{ {
foreach (scandir(PWD_RECEIVEDS) as $dir) foreach (scandir(PWD_RECEIVEDS) as $dir)
@ -197,7 +213,7 @@ class Console extends \descartes\InternalController
{ {
echo 'STOP Sms detected '.$number."\n"; echo 'STOP Sms detected '.$number."\n";
error_log('STOP Sms detected '.$number); error_log('STOP Sms detected '.$number);
$db->insertIntoTable('smsstop', ['number' => $number]); $this->model_smsstop->insert(['number' => $number]);
continue; continue;
} }
@ -213,7 +229,7 @@ class Console extends \descartes\InternalController
$interval = new \DateInterval('PT12H'); $interval = new \DateInterval('PT12H');
$sinceDate = $now->sub($interval)->format('Y-m-d H:i:s'); $sinceDate = $now->sub($interval)->format('Y-m-d H:i:s');
if (!$sendeds = $db->getFromTableWhere('sendeds', ['target' => $number, 'delivered' => false, 'failed' => false, '>at' => $sinceDate], 'at', false, 1)) if (!$sendeds = $this->model_sended->_select('sendeds', ['target' => $number, 'delivered' => false, 'failed' => false, '>at' => $sinceDate], 'at', false, 1))
{ {
continue; continue;
} }
@ -223,8 +239,8 @@ class Console extends \descartes\InternalController
//On gère les echecs //On gère les echecs
if ('Failed' === trim($text)) if ('Failed' === trim($text))
{ {
$db->updateTableWhere('sendeds', ['before_delivered' => 0, 'failed' => true], ['id' => $sended['id']]); $this->model_sended->update($sended['id'], ['before_delivered' => 0, 'failed' => true]);
echo 'Sended Sms id '.$sended['id']." pass to failed status\n"; echo 'Sended Sms id ' . $sended['id'] . " pass to failed status\n";
continue; continue;
} }
@ -232,15 +248,15 @@ class Console extends \descartes\InternalController
//On gère le cas des messages de plus de 160 caractères, lesquels impliquent plusieurs accusés //On gère le cas des messages de plus de 160 caractères, lesquels impliquent plusieurs accusés
if ($sended['before_delivered'] > 1) if ($sended['before_delivered'] > 1)
{ {
$db->updateTableWhere('sendeds', ['before_delivered' => $sended['before_delivered'] - 1], ['id' => $sended['id']]); $this->model_database->update($sended['id'], ['before_delivered' => $sended['before_delivered'] - 1]);
echo 'Sended Sms id '.$sended['id']." before_delivered decrement\n"; echo 'Sended Sms id ' . $sended['id'] . " before_delivered decrement\n";
continue; continue;
} }
//Si tout est bon, que nous avons assez d'accusés, nous validons ! //Si tout est bon, que nous avons assez d'accusés, nous validons !
$db->updateTableWhere('sendeds', ['before_delivered' => 0, 'delivered' => true], ['id' => $sended['id']]); $this->model_database->update($sended['id'], ['before_delivered' => 0, 'delivered' => true]);
echo 'Sended Sms id '.$sended['id']." to delivered status\n"; echo 'Sended Sms id ' . $sended['id'] . " to delivered status\n";
continue; continue;
} }
@ -262,13 +278,13 @@ class Console extends \descartes\InternalController
if (\array_key_exists('LOGIN', $flags) && \array_key_exists('PASSWORD', $flags)) if (\array_key_exists('LOGIN', $flags) && \array_key_exists('PASSWORD', $flags))
{ {
//Si on a bien un utilisateur avec les identifiants reçus //Si on a bien un utilisateur avec les identifiants reçus
$user = $db->getUserFromEmail($flags['LOGIN']); $user = $this->model_database->getUserFromEmail($flags['LOGIN']);
error_log('We found '.\count($user).' users'); error_log('We found '.\count($user).' users');
if ($user && $user['password'] === sha1($flags['PASSWORD'])) if ($user && $user['password'] === sha1($flags['PASSWORD']))
{ {
error_log('Password is valid'); error_log('Password is valid');
//On va passer en revue toutes les commandes, pour voir si on en trouve dans ce message //On va passer en revue toutes les commandes, pour voir si on en trouve dans ce message
$commands = $db->getFromTableWhere('commands'); $commands = $this->model_database->_select('commands');
error_log('We found '.\count($commands).' commands'); error_log('We found '.\count($commands).' commands');
foreach ($commands as $command) foreach ($commands as $command)
@ -299,7 +315,7 @@ class Console extends \descartes\InternalController
$send_by = $number; $send_by = $number;
$content = $text; $content = $text;
$is_command = \count($found_commands); $is_command = \count($found_commands);
if (!$db->insertIntoTable('receiveds', ['at' => $date, 'send_by' => $send_by, 'content' => $content, 'is_command' => $is_command])) if (!$this->model_received->insert(['at' => $date, 'send_by' => $send_by, 'content' => $content, 'is_command' => $is_command]))
{ {
echo "Erreur lors de l'enregistrement du Sms\n"; echo "Erreur lors de l'enregistrement du Sms\n";
error_log('Unable to process the Sms in file "'.$dir); error_log('Unable to process the Sms in file "'.$dir);
@ -307,7 +323,7 @@ class Console extends \descartes\InternalController
} }
//On insert le Sms dans le tableau des sms à envoyer par mail //On insert le Sms dans le tableau des sms à envoyer par mail
$db->insertIntoTable('transfers', ['id_received' => $db->lastId(), 'progress' => false]); $this->model_database->_insert('transfers', ['id_received' => $this->model_database->lastId(), 'progress' => false]);
//Chaque commande sera executée. //Chaque commande sera executée.
foreach ($found_commands as $command_name => $command) foreach ($found_commands as $command_name => $command)
@ -334,8 +350,8 @@ class Console extends \descartes\InternalController
return false; return false;
} }
global $db; global $this->model_database;
$transfers = $db->getFromTableWhere('transfers', ['progress' => false]); $transfers = $this->model_database->_select('transfers', ['progress' => false]);
$ids_transfers = []; $ids_transfers = [];
$ids_receiveds = []; $ids_receiveds = [];
@ -345,11 +361,11 @@ class Console extends \descartes\InternalController
$ids_receiveds[] = $transfer['id_received']; $ids_receiveds[] = $transfer['id_received'];
} }
$db->updateProgressTransfersIn($ids_transfers, true); $this->model_database->updateProgressTransfersIn($ids_transfers, true);
$receiveds = $db->getReceivedIn($ids_receiveds); $receiveds = $this->model_database->getReceivedIn($ids_receiveds);
$users = $db->getFromTableWhere('users', ['transfer' => true]); $users = $this->model_user->_select('users', ['transfer' => true]);
foreach ($users as $user) foreach ($users as $user)
{ {
@ -366,6 +382,6 @@ class Console extends \descartes\InternalController
} }
} }
$db->deleteTransfersIn($ids_transfers); $this->model_database->deleteTransfersIn($ids_transfers);
} }
} }

View File

@ -84,7 +84,6 @@ namespace controllers\publics;
*/ */
public function edit() public function edit()
{ {
global $db;
$ids = $_GET['ids'] ?? []; $ids = $_GET['ids'] ?? [];
$commands = $this->internal_command->gets($ids); $commands = $this->internal_command->gets($ids);

View File

@ -62,7 +62,6 @@ namespace controllers\publics;
$_SESSION['connect'] = true; $_SESSION['connect'] = true;
$_SESSION['user'] = $user; $_SESSION['user'] = $user;
$_SESSION['csrf'] = str_shuffle(uniqid().uniqid());
return $this->redirect(\descartes\Router::url('Dashboard', 'show')); return $this->redirect(\descartes\Router::url('Dashboard', 'show'));
} }
@ -88,9 +87,7 @@ namespace controllers\publics;
if (!$this->verify_csrf($csrf)) if (!$this->verify_csrf($csrf))
{ {
\modules\DescartesSessionMessages\internals\DescartesSessionMessages::push('danger', 'Jeton CSRF invalid !'); \modules\DescartesSessionMessages\internals\DescartesSessionMessages::push('danger', 'Jeton CSRF invalid !');
$this->redirect(\descartes\Router::url('Connect', 'forget_password')); return $this->redirect(\descartes\Router::url('Connect', 'forget_password'));
return false;
} }
$email = $_POST['email'] ?? false; $email = $_POST['email'] ?? false;
@ -99,9 +96,7 @@ namespace controllers\publics;
if (!$email || !$user) if (!$email || !$user)
{ {
\modules\DescartesSessionMessages\internals\DescartesSessionMessages::push('danger', 'Aucun utilisateur n\'existe pour cette adresse mail.'); \modules\DescartesSessionMessages\internals\DescartesSessionMessages::push('danger', 'Aucun utilisateur n\'existe pour cette adresse mail.');
$this->redirect(\descartes\Router::url('Connect', 'forget_password')); return $this->redirect(\descartes\Router::url('Connect', 'forget_password'));
return false;
} }
$Tokenista = new \Ingenerator\Tokenista(APP_SECRET); $Tokenista = new \Ingenerator\Tokenista(APP_SECRET);
@ -149,6 +144,6 @@ namespace controllers\publics;
{ {
session_unset(); session_unset();
session_destroy(); session_destroy();
$this->redirect(\descartes\Router::url('Connect', 'login')); return $this->redirect(\descartes\Router::url('Connect', 'login'));
} }
} }

View File

@ -61,7 +61,6 @@ namespace controllers\publics;
if (!$this->verify_csrf($csrf)) if (!$this->verify_csrf($csrf))
{ {
\modules\DescartesSessionMessages\internals\DescartesSessionMessages::push('danger', 'Jeton CSRF invalid !'); \modules\DescartesSessionMessages\internals\DescartesSessionMessages::push('danger', 'Jeton CSRF invalid !');
return $this->redirect(\descartes\Router::url('Contact', 'list')); return $this->redirect(\descartes\Router::url('Contact', 'list'));
} }
@ -91,7 +90,6 @@ namespace controllers\publics;
*/ */
public function edit() public function edit()
{ {
global $db;
$ids = $_GET['ids'] ?? []; $ids = $_GET['ids'] ?? [];
$contacts = $this->internal_contact->gets($ids); $contacts = $this->internal_contact->gets($ids);

View File

@ -53,9 +53,6 @@ namespace controllers\publics;
*/ */
public function show() public function show()
{ {
//Creation de l'object de base de données
global $db;
//Recupération des nombres des 4 panneaux d'accueil //Recupération des nombres des 4 panneaux d'accueil
$nb_contacts = $this->internal_contact->count(); $nb_contacts = $this->internal_contact->count();
$nb_groups = $this->internal_group->count(); $nb_groups = $this->internal_group->count();

View File

@ -1,7 +1,8 @@
Migrate to latest version of descartes. Remove all useless functions Migrate to latest version of descartes. Remove all useless functions
y Account.php (almost done need to do user after) y Account.php (almost done need to do user after)
y Command.php y Command.php
Connect.php y Connect.php
p Console.php
Contact.php Contact.php
Dashboard.php Dashboard.php
Discussion.php Discussion.php