207 lines
7.7 KiB
PHP
Raw Normal View History

2020-05-16 20:18:32 +02:00
<?php
require_once 'src/SSettings.php';
2020-07-31 01:03:51 +02:00
require_once 'RequestBase.php';
/**
* Class Video
* backend for all interactions with videoloads and receiving of video infos
*/
2020-07-31 01:03:51 +02:00
class Video extends RequestBase {
private string $videopath;
2020-07-31 01:03:51 +02:00
public function __construct() {
$settings = new SSettings();
// load video path from settings
$this->videopath = $settings->getVideoPath();
}
2020-05-16 20:18:32 +02:00
2020-07-31 01:03:51 +02:00
function initHandlers() {
$this->getVideos();
$this->loadVideos();
$this->addToVideo();
}
/**
* function handles load of all videos and search for videos
*/
private function getVideos() {
2020-07-31 01:03:51 +02:00
$this->addActionHandler("getMovies", function () {
$query = "SELECT movie_id,movie_name FROM videos ORDER BY create_date DESC, movie_name";
if (isset($_POST['tag'])) {
$tag = $_POST['tag'];
if ($_POST['tag'] != "all") {
$query = "SELECT movie_id,movie_name FROM videos
INNER JOIN video_tags vt on videos.movie_id = vt.video_id
INNER JOIN tags t on vt.tag_id = t.tag_id
WHERE t.tag_name = '$tag'
ORDER BY likes DESC, create_date, movie_name";
}
}
2020-07-31 01:03:51 +02:00
$result = $this->conn->query($query);
2020-05-29 17:19:19 +02:00
$rows = array();
while ($r = mysqli_fetch_assoc($result)) {
array_push($rows, $r);
}
$this->commitMessage(json_encode($rows));
2020-07-31 01:03:51 +02:00
});
$this->addActionHandler("getRandomMovies", function () {
$return = new stdClass();
$query = "SELECT movie_id,movie_name FROM videos ORDER BY RAND() LIMIT " . $_POST['number'];
2020-07-31 01:03:51 +02:00
$result = $this->conn->query($query);
$return->rows = array();
// get tags of random videos
$ids = [];
while ($r = mysqli_fetch_assoc($result)) {
array_push($return->rows, $r);
2020-06-06 11:48:12 +00:00
array_push($ids, "video_tags.video_id=" . $r['movie_id']);
}
2020-06-06 11:48:12 +00:00
$idstring = implode(" OR ", $ids);
$return->tags = array();
$query = "SELECT t.tag_name FROM video_tags
INNER JOIN tags t on video_tags.tag_id = t.tag_id
WHERE $idstring
GROUP BY t.tag_name";
2020-07-31 01:03:51 +02:00
$result = $this->conn->query($query);
while ($r = mysqli_fetch_assoc($result)) {
array_push($return->tags, $r);
}
$this->commitMessage(json_encode($return));
2020-07-31 01:03:51 +02:00
});
$this->addActionHandler("getSearchKeyWord", function () {
$search = $_POST['keyword'];
$query = "SELECT movie_id,movie_name FROM videos
WHERE movie_name LIKE '%$search%'
ORDER BY likes DESC, create_date DESC, movie_name";
2020-07-31 01:03:51 +02:00
$result = $this->conn->query($query);
$rows = array();
while ($r = mysqli_fetch_assoc($result)) {
array_push($rows, $r);
}
$this->commitMessage(json_encode($rows));
2020-07-31 01:03:51 +02:00
});
}
/**
* function to handle stuff for loading specific videos and startdata
*/
private function loadVideos() {
2020-07-31 01:03:51 +02:00
$this->addActionHandler("loadVideo", function () {
2020-06-06 11:48:12 +00:00
$query = "SELECT movie_name,movie_id,movie_url,thumbnail,poster,likes,quality,length FROM videos WHERE movie_id='" . $_POST['movieid'] . "'";
2020-07-31 01:03:51 +02:00
$result = $this->conn->query($query);
$row = $result->fetch_assoc();
$arr = array();
2020-06-06 11:48:12 +00:00
if ($row["poster"] == null) {
$arr["thumbnail"] = $row["thumbnail"];
2020-06-06 11:48:12 +00:00
} else {
$arr["thumbnail"] = $row["poster"];
}
2020-06-06 11:48:12 +00:00
$arr["movie_id"] = $row["movie_id"];
$arr["movie_name"] = $row["movie_name"];
// todo drop video url from db -- maybe one with and one without extension
// extension hardcoded here!!!
2020-07-31 01:03:51 +02:00
$arr["movie_url"] = str_replace("?", "%3F", $this->videopath . $row["movie_name"] . ".mp4");
2020-05-24 16:16:45 +02:00
$arr["likes"] = $row["likes"];
$arr["quality"] = $row["quality"];
$arr["length"] = $row["length"];
// load tags of this video
2020-06-06 11:48:12 +00:00
$arr['tags'] = array();
$query = "SELECT t.tag_name FROM video_tags
INNER JOIN tags t on video_tags.tag_id = t.tag_id
2020-06-06 11:48:12 +00:00
WHERE video_tags.video_id=" . $_POST['movieid'] . "
GROUP BY t.tag_name";
2020-07-31 01:03:51 +02:00
$result = $this->conn->query($query);
while ($r = mysqli_fetch_assoc($result)) {
array_push($arr['tags'], $r);
}
$this->commitMessage(json_encode($arr));
2020-07-31 01:03:51 +02:00
});
2020-07-31 01:03:51 +02:00
$this->addActionHandler("readThumbnail", function () {
$query = "SELECT thumbnail FROM videos WHERE movie_id='" . $_POST['movieid'] . "'";
2020-07-31 01:03:51 +02:00
$result = $this->conn->query($query);
$row = $result->fetch_assoc();
$this->commitMessage($row["thumbnail"]);
2020-07-31 01:03:51 +02:00
});
$this->addActionHandler("getStartData", function () {
$query = "SELECT COUNT(*) as nr FROM videos";
2020-07-31 01:03:51 +02:00
$result = $this->conn->query($query);
$r = mysqli_fetch_assoc($result);
$arr = array();
$arr['total'] = $r['nr'];
$query = "SELECT COUNT(*) as nr FROM videos
INNER JOIN video_tags vt on videos.movie_id = vt.video_id
INNER JOIN tags t on vt.tag_id = t.tag_id";
2020-07-31 01:03:51 +02:00
$result = $this->conn->query($query);
$r = mysqli_fetch_assoc($result);
$arr['tagged'] = $r['nr'];
$query = "SELECT COUNT(*) as nr FROM videos
INNER JOIN video_tags vt on videos.movie_id = vt.video_id
INNER JOIN tags t on vt.tag_id = t.tag_id
WHERE t.tag_name='hd'";
2020-07-31 01:03:51 +02:00
$result = $this->conn->query($query);
$r = mysqli_fetch_assoc($result);
$arr['hd'] = $r['nr'];
$query = "SELECT COUNT(*) as nr FROM videos
INNER JOIN video_tags vt on videos.movie_id = vt.video_id
INNER JOIN tags t on vt.tag_id = t.tag_id
WHERE t.tag_name='fullhd'";
2020-07-31 01:03:51 +02:00
$result = $this->conn->query($query);
$r = mysqli_fetch_assoc($result);
$arr['fullhd'] = $r['nr'];
$query = "SELECT COUNT(*) as nr FROM videos
INNER JOIN video_tags vt on videos.movie_id = vt.video_id
INNER JOIN tags t on vt.tag_id = t.tag_id
WHERE t.tag_name='lowquality'";
2020-07-31 01:03:51 +02:00
$result = $this->conn->query($query);
$r = mysqli_fetch_assoc($result);
$arr['sd'] = $r['nr'];
$query = "SELECT COUNT(*) as nr FROM tags";
2020-07-31 01:03:51 +02:00
$result = $this->conn->query($query);
$r = mysqli_fetch_assoc($result);
$arr['tags'] = $r['nr'];
$this->commitMessage(json_encode($arr));
2020-07-31 01:03:51 +02:00
});
}
2020-07-31 01:03:51 +02:00
/**
* function to handle api handlers for stuff to add to video or database
*/
private function addToVideo() {
$this->addActionHandler("addLike", function () {
2020-06-06 11:48:12 +00:00
$movieid = $_POST['movieid'];
$query = "update videos set likes = likes + 1 where movie_id = '$movieid'";
2020-06-06 11:48:12 +00:00
2020-07-31 01:03:51 +02:00
if ($this->conn->query($query) === TRUE) {
$this->commitMessage('{"result":"success"}');
2020-06-06 11:48:12 +00:00
} else {
$this->commitMessage('{"result":"' . $this->conn->error . '"}');
2020-06-06 11:48:12 +00:00
}
2020-07-31 01:03:51 +02:00
});
}
2020-05-16 20:18:32 +02:00
}