engelsystem/includes/model/Message_model.php

71 lines
1.6 KiB
PHP
Raw Normal View History

2014-01-07 15:50:16 +01:00
<?php
use Engelsystem\Database\DB;
/**
* Returns Message id array
2017-01-03 03:22:48 +01:00
*
* @return array
2014-01-07 15:50:16 +01:00
*/
2017-01-02 03:57:23 +01:00
function Message_ids()
{
return DB::select('SELECT `id` FROM `Messages`');
2014-01-07 15:50:16 +01:00
}
/**
* Returns message by id.
*
2017-01-03 03:22:48 +01:00
* @param int $message_id message ID
* @return array|null
2014-01-07 15:50:16 +01:00
*/
2017-01-02 03:57:23 +01:00
function Message($message_id)
{
$message_source = DB::select('SELECT * FROM `Messages` WHERE `id`=? LIMIT 1', [$message_id]);
if (empty($message_source)) {
return null;
2017-01-02 03:57:23 +01:00
}
return array_shift($message_source);
2014-01-07 15:50:16 +01:00
}
/**
* TODO: use validation functions, return new message id
* TODO: global $user con not be used in model!
* send message
*
2017-01-03 03:22:48 +01:00
* @param int $receiver_user_id User ID of Reciever
* @param string $text Text of Message
* @return bool
2014-01-07 15:50:16 +01:00
*/
2017-01-02 03:57:23 +01:00
function Message_send($receiver_user_id, $text)
{
global $user;
2017-01-02 15:43:36 +01:00
2017-01-02 03:57:23 +01:00
$text = preg_replace("/([^\p{L}\p{P}\p{Z}\p{N}\n]{1,})/ui", '', strip_tags($text));
2017-01-03 14:12:17 +01:00
$receiver_user_id = preg_replace('/([^0-9]{1,})/ui', '', strip_tags($receiver_user_id));
2017-01-02 15:43:36 +01:00
if (
2017-01-03 14:12:17 +01:00
($text != '' && is_numeric($receiver_user_id))
&& count(DB::select('
SELECT `UID`
2017-01-02 15:43:36 +01:00
FROM `User`
WHERE `UID` = ?
AND NOT `UID` = ?
2017-01-02 15:43:36 +01:00
LIMIT 1
', [$receiver_user_id, $user['UID']])) > 0
2017-01-02 15:43:36 +01:00
) {
return DB::insert('
INSERT INTO `Messages` (`Datum`, `SUID`, `RUID`, `Text`)
VALUES(?, ?, ?, ?)
',
[
time(),
$user['UID'],
$receiver_user_id,
$text
]
);
2017-01-02 03:57:23 +01:00
}
2017-01-02 15:43:36 +01:00
2017-01-02 03:57:23 +01:00
return false;
2014-01-07 15:50:16 +01:00
}