raspisms/controllers/publics/Discussion.php

291 lines
10 KiB
PHP
Raw Normal View History

2019-10-29 14:57:13 +01:00
<?php
/*
2019-11-10 17:48:54 +01:00
* This file is part of RaspiSMS.
*
2019-11-10 17:48:54 +01:00
* (c) Pierre-Lin Bonnemaison <plebwebsas@gmail.com>
*
2019-11-10 17:48:54 +01:00
* This source file is subject to the GPL-3.0 license that is bundled
* with this source code in the file LICENSE.
*/
2019-10-29 14:57:13 +01:00
namespace controllers\publics;
2019-10-29 18:36:25 +01:00
/**
* Page des discussions.
2019-10-29 18:36:25 +01:00
*/
class Discussion extends \descartes\Controller
{
private $internal_sended;
private $internal_scheduled;
private $internal_received;
private $internal_contact;
2019-10-29 18:36:25 +01:00
/**
* Cette fonction est appelée avant toute les autres :
* Elle vérifie que l'utilisateur est bien connecté.
*
2019-10-29 18:36:25 +01:00
* @return void;
*/
public function __construct()
2019-10-29 18:36:25 +01:00
{
$bdd = \descartes\Model::_connect(DATABASE_HOST, DATABASE_NAME, DATABASE_USER, DATABASE_PASSWORD);
$this->internal_sended = new \controllers\internals\Sended($bdd);
$this->internal_scheduled = new \controllers\internals\Scheduled($bdd);
$this->internal_received = new \controllers\internals\Received($bdd);
$this->internal_contact = new \controllers\internals\Contact($bdd);
\controllers\internals\Tool::verifyconnect();
2019-10-29 18:36:25 +01:00
}
/**
* Cette fonction retourne toutes les discussions, sous forme d'un tableau permettant l'administration de ces contacts.
2019-10-29 18:36:25 +01:00
*/
public function list()
{
$discussions = $this->internal_received->get_discussions_for_user($_SESSION['user']['id']);
2019-10-29 18:36:25 +01:00
foreach ($discussions as $key => $discussion)
{
if (!$contact = $this->internal_contact->get_by_number_and_user($_SESSION['user']['id'], $discussion['number']))
{
2019-10-29 18:36:25 +01:00
continue;
}
$discussions[$key]['contact'] = $contact['name'];
}
$this->render('discussion/list', [
2019-10-29 18:36:25 +01:00
'discussions' => $discussions,
]);
2019-10-29 18:36:25 +01:00
}
2019-10-29 18:36:25 +01:00
/**
* Cette fonction permet d'afficher la discussion avec un numero.
*
2019-10-29 18:36:25 +01:00
* @param string $number : La numéro de téléphone avec lequel on discute
*/
public function show($number)
{
$contact = $this->internal_contact->get_by_number_and_user($_SESSION['user']['id'], $number);
2019-10-29 14:57:13 +01:00
$last_sended = $this->internal_sended->get_last_for_destination_and_user($_SESSION['user']['id'], $number);
$last_received = $this->internal_received->get_last_for_origin_and_user($_SESSION['user']['id'], $number);
$response_number = ($last_received['destination'] ?? $last_sended['origin'] ?? false);
$this->render('discussion/show', [
2019-10-29 18:36:25 +01:00
'number' => $number,
'contact' => $contact,
'response_number' => $response_number,
]);
2019-10-29 18:36:25 +01:00
}
2019-10-29 14:57:13 +01:00
2019-10-29 18:36:25 +01:00
/**
* Cette fonction récupère l'ensemble des messages pour un numéro, recçus, envoyés, en cours.
*
* @param string $number : Le numéro cible
2019-10-29 18:36:25 +01:00
* @param string $transaction_id : Le numéro unique de la transaction ajax (sert à vérifier si la requete doit être prise en compte)
*/
public function get_messages($number, $transaction_id)
{
$now = new \DateTime();
$now = $now->format('Y-m-d H:i:s');
2019-10-29 14:57:13 +01:00
$id_user = $_SESSION['user']['id'];
$sendeds = $this->internal_sended->gets_by_destination_and_user($id_user, $number);
$receiveds = $this->internal_received->gets_by_origin_and_user($id_user, $number);
$scheduleds = $this->internal_scheduled->gets_before_date_for_number_and_user($id_user, $now, $number);
2019-10-29 18:36:25 +01:00
$messages = [];
foreach ($sendeds as $sended)
{
$messages[] = [
2019-10-29 18:36:25 +01:00
'date' => htmlspecialchars($sended['at']),
'text' => htmlspecialchars($sended['text']),
2019-10-29 18:36:25 +01:00
'type' => 'sended',
'status' => $sended['status'],
];
2019-10-29 18:36:25 +01:00
}
foreach ($receiveds as $received)
{
2020-01-17 18:19:25 +01:00
if ('read' !== $received['status'])
2019-12-02 01:55:06 +01:00
{
$this->internal_received->mark_as_read_for_user($id_user, $received['id']);
}
$messages[] = [
2019-10-29 18:36:25 +01:00
'date' => htmlspecialchars($received['at']),
'text' => htmlspecialchars($received['text']),
2019-10-29 18:36:25 +01:00
'type' => 'received',
'md5' => md5($received['at'] . $received['text']),
];
2019-10-29 18:36:25 +01:00
}
foreach ($scheduleds as $scheduled)
{
$messages[] = [
2019-10-29 18:36:25 +01:00
'date' => htmlspecialchars($scheduled['at']),
'text' => htmlspecialchars($scheduled['text']),
2019-10-29 18:36:25 +01:00
'type' => 'inprogress',
];
2019-10-29 18:36:25 +01:00
}
//On va trier le tableau des messages
usort($messages, function ($a, $b)
{
return strtotime($a['date']) - strtotime($b['date']);
2019-10-29 18:36:25 +01:00
});
//On récupère uniquement les 25 derniers messages sur l'ensemble
$messages = \array_slice($messages, -25);
2019-10-29 18:36:25 +01:00
echo json_encode(['transaction_id' => $transaction_id, 'messages' => $messages]);
2019-10-29 18:36:25 +01:00
return true;
}
/**
* Cette fonction permet d'envoyer facilement un sms à un numéro donné.
*
2020-01-17 18:19:25 +01:00
* @param string $csrf : Le jeton csrf
* @param string $_POST['text'] : Le contenu du Sms
* @param string $_POST['destination'] : Number to send sms to
2020-01-17 18:19:25 +01:00
* @param string $_POST['origin'] : Number to send sms with
*
* @return string : json string Le statut de l'envoi
2019-10-29 18:36:25 +01:00
*/
public function send($csrf)
{
2019-10-29 14:57:13 +01:00
$return = ['success' => true, 'message' => ''];
2019-10-29 18:36:25 +01:00
//On vérifie que le jeton csrf est bon
if (!$this->verify_csrf($csrf))
{
2019-10-29 18:36:25 +01:00
$return['success'] = false;
$return['message'] = 'Jeton CSRF invalide';
echo json_encode($return);
2019-10-29 18:36:25 +01:00
return false;
}
$now = new \DateTime();
$now = $now->format('Y-m-d H:i:s');
2019-11-12 17:37:20 +01:00
$id_user = $_SESSION['user']['id'];
$at = $now;
$text = $_POST['text'] ?? '';
$destination = $_POST['destination'] ?? false;
$origin = $_POST['origin'] ?? false;
2019-10-29 14:57:13 +01:00
if (!$destination)
{
2019-10-29 18:36:25 +01:00
$return['success'] = false;
2019-10-29 14:57:13 +01:00
$return['message'] = 'Vous devez renseigner un numéro valide';
2019-10-29 18:36:25 +01:00
echo json_encode($return);
2019-10-29 18:36:25 +01:00
return false;
}
if (!$origin)
{
$origin = null;
}
//Destinations must be an array of number
$destinations = [$destination];
if (!$this->internal_scheduled->create($id_user, $at, $text, $origin, false, $destinations))
{
2019-10-29 18:36:25 +01:00
$return['success'] = false;
$return['message'] = 'Impossible de créer le Sms';
2019-10-29 18:36:25 +01:00
echo json_encode($return);
2019-10-29 18:36:25 +01:00
return false;
2019-10-29 14:57:13 +01:00
}
2019-10-29 18:36:25 +01:00
echo json_encode($return);
2019-10-29 18:36:25 +01:00
return true;
}
/**
* Cette fonction retourne les id des sms qui sont envoyés.
*
* @return string : json string Tableau des ids des sms qui sont envoyés
2019-10-29 18:36:25 +01:00
*/
public function checksendeds()
{
$_SESSION['discussion_wait_progress'] = isset($_SESSION['discussion_wait_progress']) ? $_SESSION['discussion_wait_progress'] : [];
2019-10-29 14:57:13 +01:00
2019-11-14 22:33:00 +01:00
$scheduleds = $this->internal_scheduled->gets_in_for_user($_SESSION['user']['id'], $_SESSION['discussion_wait_progress']);
2019-10-29 14:57:13 +01:00
2019-10-29 18:36:25 +01:00
//On va chercher à chaque fois si on a trouvé le sms. Si ce n'est pas le cas c'est qu'il a été envoyé
$sendeds = [];
foreach ($_SESSION['discussion_wait_progress'] as $key => $id_scheduled)
{
2019-10-29 18:36:25 +01:00
$found = false;
foreach ($scheduleds as $scheduled)
{
if ($id_scheduled === $scheduled['id'])
{
2019-10-29 18:36:25 +01:00
$found = true;
}
}
if (!$found)
{
2019-10-29 18:36:25 +01:00
unset($_SESSION['discussion_wait_progress'][$key]);
$sendeds[] = $id_scheduled;
2019-10-29 18:36:25 +01:00
}
}
echo json_encode($sendeds);
2019-10-29 18:36:25 +01:00
return true;
}
/**
* Cette fonction retourne les messages reçus pour un numéro après la date $_SESSION['discussion_last_checkreceiveds'].
*
2019-10-29 18:36:25 +01:00
* @param string $number : Le numéro de téléphone pour lequel on veux les messages
*
* @return string : json string Un tableau avec les messages
2019-10-29 18:36:25 +01:00
*/
public function checkreceiveds($number)
{
$now = new \DateTime();
$now = $now->format('Y-m-d H:i');
2019-10-29 18:36:25 +01:00
$_SESSION['discussion_last_checkreceiveds'] = isset($_SESSION['discussion_last_checkreceiveds']) ? $_SESSION['discussion_last_checkreceiveds'] : $now;
$receiveds = $this->internal_received->get_since_for_number_by_date($_SESSION['discussion_last_checkreceiveds'], $number);
2019-10-29 18:36:25 +01:00
//On va gérer le cas des messages en double en stockant ceux déjà reçus et en eliminant les autres
$_SESSION['discussion_already_receiveds'] = isset($_SESSION['discussion_already_receiveds']) ? $_SESSION['discussion_already_receiveds'] : [];
foreach ($receiveds as $key => $received)
{
2019-10-29 18:36:25 +01:00
//Sms jamais recu
if (false === array_search($received['id'], $_SESSION['discussion_already_receiveds'], true))
{
2019-10-29 18:36:25 +01:00
$_SESSION['discussion_already_receiveds'][] = $received['id'];
2019-10-29 18:36:25 +01:00
continue;
}
//Sms déjà reçu => on le supprime des resultats
unset($receiveds[$key]);
}
//On met à jour la date de dernière verif
$_SESSION['discussion_last_checkreceiveds'] = $now;
2019-10-29 18:36:25 +01:00
echo json_encode($receiveds);
}
}