2019-12-04 03:04:45 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is part of RaspiSMS.
|
|
|
|
*
|
|
|
|
* (c) Pierre-Lin Bonnemaison <plebwebsas@gmail.com>
|
|
|
|
*
|
|
|
|
* This source file is subject to the GPL-3.0 license that is bundled
|
|
|
|
* with this source code in the file LICENSE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace models;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Cette classe gère les accès bdd pour les mediaes.
|
|
|
|
*/
|
|
|
|
class Media extends StandardModel
|
|
|
|
{
|
|
|
|
/**
|
2021-03-19 02:45:12 +01:00
|
|
|
* Return a media for a user and a scheduled.
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
2021-03-19 02:45:12 +01:00
|
|
|
* @param int $id_user : user id
|
|
|
|
* @param int $id_scheduled : scheduled id
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
2019-12-04 03:04:45 +01:00
|
|
|
* @return array
|
|
|
|
*/
|
2021-03-19 02:45:12 +01:00
|
|
|
public function gets_for_scheduled_and_user(int $id_user, int $id_scheduled)
|
2019-12-04 03:04:45 +01:00
|
|
|
{
|
2021-01-14 03:32:17 +01:00
|
|
|
$query = '
|
2021-03-19 02:45:12 +01:00
|
|
|
SELECT m.id as id, m.user_id as user_id, m.path as path
|
|
|
|
FROM `' . $this->get_table_name() . '` as m
|
|
|
|
INNER JOIN media_scheduled as ms
|
|
|
|
ON m.id = ms.id_media
|
|
|
|
WHERE m.id_user = :id_user
|
|
|
|
AND ms.id_scheduled = :id_scheduled
|
2019-12-04 03:04:45 +01:00
|
|
|
';
|
|
|
|
|
|
|
|
$params = [
|
|
|
|
'id_user' => $id_user,
|
2021-03-19 02:45:12 +01:00
|
|
|
'id_scheduled' => $id_scheduled,
|
2019-12-04 03:04:45 +01:00
|
|
|
];
|
|
|
|
|
2021-03-19 02:45:12 +01:00
|
|
|
return $this->_run_query($query, $params);
|
2019-12-04 03:04:45 +01:00
|
|
|
}
|
2021-03-19 02:45:12 +01:00
|
|
|
|
2019-12-04 03:04:45 +01:00
|
|
|
/**
|
2021-03-19 02:45:12 +01:00
|
|
|
* Return a media for a user and a sended.
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
2021-03-19 02:45:12 +01:00
|
|
|
* @param int $id_user : user id
|
|
|
|
* @param int $id_sended : sended id
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
2019-12-04 03:04:45 +01:00
|
|
|
* @return array
|
|
|
|
*/
|
2021-03-19 02:45:12 +01:00
|
|
|
public function gets_for_sended_and_user(int $id_user, int $id_sended)
|
2019-12-04 03:04:45 +01:00
|
|
|
{
|
2021-01-14 03:32:17 +01:00
|
|
|
$query = '
|
2021-03-19 02:45:12 +01:00
|
|
|
SELECT m.id as id, m.user_id as user_id, m.path as path
|
|
|
|
FROM `' . $this->get_table_name() . '` as m
|
|
|
|
INNER JOIN media_sended as ms
|
|
|
|
ON m.id = ms.id_media
|
|
|
|
WHERE m.id_user = :id_user
|
|
|
|
AND ms.id_sended = :id_sended
|
2019-12-04 03:04:45 +01:00
|
|
|
';
|
|
|
|
|
|
|
|
$params = [
|
|
|
|
'id_user' => $id_user,
|
2021-03-19 02:45:12 +01:00
|
|
|
'id_sended' => $id_sended,
|
2019-12-04 03:04:45 +01:00
|
|
|
];
|
|
|
|
|
2021-03-19 02:45:12 +01:00
|
|
|
return $this->_run_query($query, $params);
|
2019-12-04 03:04:45 +01:00
|
|
|
}
|
2021-03-19 02:45:12 +01:00
|
|
|
|
2019-12-04 03:04:45 +01:00
|
|
|
/**
|
2021-03-19 02:45:12 +01:00
|
|
|
* Return a media for a user and a received.
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
|
|
|
* @param int $id_user : user id
|
2021-03-19 02:45:12 +01:00
|
|
|
* @param int $id_received : received id
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
2019-12-04 03:04:45 +01:00
|
|
|
* @return array
|
|
|
|
*/
|
2021-03-19 02:45:12 +01:00
|
|
|
public function gets_for_received_and_user(int $id_user, int $id_received)
|
2019-12-04 03:04:45 +01:00
|
|
|
{
|
2021-01-14 03:32:17 +01:00
|
|
|
$query = '
|
2021-03-19 02:45:12 +01:00
|
|
|
SELECT m.id as id, m.user_id as user_id, m.path as path
|
|
|
|
FROM `' . $this->get_table_name() . '` as m
|
|
|
|
INNER JOIN media_received as mr
|
|
|
|
ON m.id = mr.id_media
|
|
|
|
WHERE m.id_user = :id_user
|
|
|
|
AND mr.id_received = :id_received
|
2019-12-04 03:04:45 +01:00
|
|
|
';
|
|
|
|
|
|
|
|
$params = [
|
|
|
|
'id_user' => $id_user,
|
2021-03-19 02:45:12 +01:00
|
|
|
'id_received' => $id_received,
|
2019-12-04 03:04:45 +01:00
|
|
|
];
|
|
|
|
|
2021-03-19 02:45:12 +01:00
|
|
|
return $this->_run_query($query, $params);
|
2019-12-04 03:04:45 +01:00
|
|
|
}
|
2021-03-19 02:45:12 +01:00
|
|
|
|
2019-12-04 03:04:45 +01:00
|
|
|
/**
|
2021-03-19 02:45:12 +01:00
|
|
|
* Link a media to a scheduled
|
|
|
|
*
|
|
|
|
* @param int $id_media : Media id
|
|
|
|
* @param int $id_scheduled : Scheduled id
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
2021-03-19 02:45:12 +01:00
|
|
|
* @return bool | int
|
2019-12-04 03:04:45 +01:00
|
|
|
*/
|
2021-03-19 02:45:12 +01:00
|
|
|
public function insert_media_scheduled (int $id_media, int $id_scheduled)
|
2019-12-04 03:04:45 +01:00
|
|
|
{
|
2021-03-19 02:45:12 +01:00
|
|
|
$entry = [
|
|
|
|
'id_media' => $id_media,
|
|
|
|
'id_scheduled' => $id_scheduled,
|
2019-12-04 03:04:45 +01:00
|
|
|
];
|
|
|
|
|
2021-03-19 02:45:12 +01:00
|
|
|
return $this->_insert('media_scheduled', $entry) ? $this->_last_id() : false;
|
2019-12-04 03:04:45 +01:00
|
|
|
}
|
2021-03-19 02:45:12 +01:00
|
|
|
|
2019-12-04 03:04:45 +01:00
|
|
|
/**
|
2021-03-19 02:45:12 +01:00
|
|
|
* Link a media to a received
|
|
|
|
*
|
|
|
|
* @param int $id_media : Media id
|
|
|
|
* @param int $id_received : Scheduled id
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
2021-03-19 02:45:12 +01:00
|
|
|
* @return bool | int
|
2019-12-04 03:04:45 +01:00
|
|
|
*/
|
2021-03-19 02:45:12 +01:00
|
|
|
public function insert_media_received (int $id_media, int $id_received)
|
2019-12-04 03:04:45 +01:00
|
|
|
{
|
2021-03-19 02:45:12 +01:00
|
|
|
$entry = [
|
|
|
|
'id_media' => $id_media,
|
|
|
|
'id_received' => $id_received,
|
|
|
|
];
|
2019-12-04 03:04:45 +01:00
|
|
|
|
2021-03-19 02:45:12 +01:00
|
|
|
return $this->_insert('media_received', $entry) ? $this->_last_id() : false;
|
2019-12-04 03:04:45 +01:00
|
|
|
}
|
2021-03-19 02:45:12 +01:00
|
|
|
|
2019-12-04 03:04:45 +01:00
|
|
|
/**
|
2021-03-19 02:45:12 +01:00
|
|
|
* Link a media to a sended
|
|
|
|
*
|
|
|
|
* @param int $id_media : Media id
|
|
|
|
* @param int $id_sended : Scheduled id
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
2021-03-19 02:45:12 +01:00
|
|
|
* @return bool | int
|
2019-12-04 03:04:45 +01:00
|
|
|
*/
|
2021-03-19 02:45:12 +01:00
|
|
|
public function insert_media_sended (int $id_media, int $id_sended)
|
2019-12-04 03:04:45 +01:00
|
|
|
{
|
2021-03-19 02:45:12 +01:00
|
|
|
$entry = [
|
|
|
|
'id_media' => $id_media,
|
|
|
|
'id_sended' => $id_sended,
|
|
|
|
];
|
2020-01-17 18:19:25 +01:00
|
|
|
|
2021-03-19 02:45:12 +01:00
|
|
|
return $this->_insert('media_sended', $entry) ? $this->_last_id() : false;
|
2019-12-04 03:04:45 +01:00
|
|
|
}
|
2021-03-19 02:45:12 +01:00
|
|
|
|
2019-12-04 03:04:45 +01:00
|
|
|
/**
|
2021-03-19 02:45:12 +01:00
|
|
|
* Unlink a media of a scheduled
|
|
|
|
*
|
|
|
|
* @param int $id_media : Media id
|
2019-12-04 03:04:45 +01:00
|
|
|
* @param int $id_scheduled : Scheduled id
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
2021-03-19 02:45:12 +01:00
|
|
|
* @return bool | int
|
2019-12-04 03:04:45 +01:00
|
|
|
*/
|
2021-03-19 02:45:12 +01:00
|
|
|
public function delete_media_scheduled (int $id_media, int $id_scheduled)
|
2019-12-04 03:04:45 +01:00
|
|
|
{
|
2021-03-19 02:45:12 +01:00
|
|
|
$where = [
|
|
|
|
'id_media' => $id_media,
|
|
|
|
'id_scheduled' => $id_scheduled,
|
|
|
|
];
|
2020-01-17 18:19:25 +01:00
|
|
|
|
2021-03-19 02:45:12 +01:00
|
|
|
return $this->_delete('media_scheduled', $where);
|
2019-12-04 03:04:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-03-19 02:45:12 +01:00
|
|
|
* Unlink a media of a received
|
|
|
|
*
|
|
|
|
* @param int $id_media : Media id
|
|
|
|
* @param int $id_received : Scheduled id
|
2019-12-04 03:04:45 +01:00
|
|
|
*
|
2021-03-19 02:45:12 +01:00
|
|
|
* @return bool | int
|
2019-12-04 03:04:45 +01:00
|
|
|
*/
|
2021-03-19 02:45:12 +01:00
|
|
|
public function delete_media_received (int $id_media, int $id_received)
|
2019-12-04 03:04:45 +01:00
|
|
|
{
|
2021-03-19 02:45:12 +01:00
|
|
|
$where = [
|
|
|
|
'id_media' => $id_media,
|
|
|
|
'id_received' => $id_received,
|
|
|
|
];
|
2019-12-04 03:04:45 +01:00
|
|
|
|
2021-03-19 02:45:12 +01:00
|
|
|
return $this->_delete('media_received', $where);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unlink a media of a sended
|
|
|
|
*
|
|
|
|
* @param int $id_media : Media id
|
|
|
|
* @param int $id_sended : Scheduled id
|
|
|
|
*
|
|
|
|
* @return bool | int
|
|
|
|
*/
|
|
|
|
public function delete_media_sended (int $id_media, int $id_sended)
|
|
|
|
{
|
|
|
|
$where = [
|
|
|
|
'id_media' => $id_media,
|
|
|
|
'id_sended' => $id_sended,
|
|
|
|
];
|
2019-12-04 03:04:45 +01:00
|
|
|
|
2021-03-19 02:45:12 +01:00
|
|
|
return $this->_delete('media_sended', $where);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unlink all medias of a scheduled
|
|
|
|
*
|
|
|
|
* @param int $id_scheduled : Scheduled id
|
|
|
|
*
|
|
|
|
* @return bool | int
|
|
|
|
*/
|
|
|
|
public function delete_all_for_scheduled (int $id_scheduled)
|
|
|
|
{
|
|
|
|
$where = [
|
|
|
|
'id_scheduled' => $id_scheduled,
|
|
|
|
];
|
2019-12-04 03:04:45 +01:00
|
|
|
|
2021-03-19 02:45:12 +01:00
|
|
|
return $this->_delete('media_scheduled', $where);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unlink all medias of a received
|
|
|
|
*
|
|
|
|
* @param int $id_received : Scheduled id
|
|
|
|
*
|
|
|
|
* @return bool | int
|
|
|
|
*/
|
|
|
|
public function delete_all_for_received (int $id_received)
|
|
|
|
{
|
|
|
|
$where = [
|
|
|
|
'id_received' => $id_received,
|
|
|
|
];
|
2019-12-04 03:04:45 +01:00
|
|
|
|
2021-03-19 02:45:12 +01:00
|
|
|
return $this->_delete('media_received', $where);
|
2019-12-04 03:04:45 +01:00
|
|
|
}
|
2020-01-17 18:19:25 +01:00
|
|
|
|
2019-12-04 03:04:45 +01:00
|
|
|
/**
|
2021-03-19 02:45:12 +01:00
|
|
|
* Unlink all medias of a sended
|
|
|
|
*
|
|
|
|
* @param int $id_sended : Scheduled id
|
2020-01-17 18:19:25 +01:00
|
|
|
*
|
2021-03-19 02:45:12 +01:00
|
|
|
* @return bool | int
|
2019-12-04 03:04:45 +01:00
|
|
|
*/
|
2021-03-19 02:45:12 +01:00
|
|
|
public function delete_all_for_sended (int $id_sended)
|
2019-12-04 03:04:45 +01:00
|
|
|
{
|
2021-03-19 02:45:12 +01:00
|
|
|
$where = [
|
|
|
|
'id_sended' => $id_sended,
|
2019-12-04 03:04:45 +01:00
|
|
|
];
|
|
|
|
|
2021-03-19 02:45:12 +01:00
|
|
|
return $this->_delete('media_sended', $where);
|
2019-12-04 03:04:45 +01:00
|
|
|
}
|
2020-01-17 18:19:25 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return table name.
|
|
|
|
*/
|
|
|
|
protected function get_table_name(): string
|
|
|
|
{
|
|
|
|
return 'media';
|
|
|
|
}
|
2019-12-04 03:04:45 +01:00
|
|
|
}
|