mirror of
https://github.com/DanielnetoDotCom/YouPHPTube
synced 2025-10-03 01:39:24 +02:00
Compare commits
2 commits
80d51d93a5
...
5abbb80f6b
Author | SHA1 | Date | |
---|---|---|---|
![]() |
5abbb80f6b | ||
![]() |
ac340dfc7e |
2 changed files with 109 additions and 101 deletions
|
@ -1,101 +1,101 @@
|
||||||
<?php
|
<?php
|
||||||
header('Content-Type: application/json');
|
header('Content-Type: application/json');
|
||||||
global $global, $config;
|
global $global, $config;
|
||||||
if (!isset($global['systemRootPath'])) {
|
if (!isset($global['systemRootPath'])) {
|
||||||
require_once '../videos/configuration.php';
|
require_once '../videos/configuration.php';
|
||||||
}
|
}
|
||||||
|
|
||||||
AVideoPlugin::getDataObject('VideosStatistics');
|
AVideoPlugin::getDataObject('VideosStatistics');
|
||||||
|
|
||||||
_session_write_close();
|
_session_write_close();
|
||||||
|
|
||||||
$obj = new stdClass();
|
$obj = new stdClass();
|
||||||
$obj->error = true;
|
$obj->error = true;
|
||||||
$obj->msg = '';
|
$obj->msg = '';
|
||||||
$obj->configAuthCanViewChart = $config->getAuthCanViewChart();
|
$obj->configAuthCanViewChart = $config->getAuthCanViewChart();
|
||||||
$obj->performance = new stdClass();
|
$obj->performance = new stdClass();
|
||||||
$obj->performance->start = microtime(true);
|
$obj->performance->start = microtime(true);
|
||||||
|
|
||||||
if (empty($_REQUEST['users_id'])) {
|
if (empty($_REQUEST['users_id'])) {
|
||||||
$obj->users_id = User::getId();
|
$obj->users_id = User::getId();
|
||||||
} else {
|
} else {
|
||||||
$obj->users_id = intval($_REQUEST['users_id']);
|
$obj->users_id = intval($_REQUEST['users_id']);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (empty($obj->users_id)) {
|
if (empty($obj->users_id)) {
|
||||||
$obj->msg = 'You MUST Specify a user';
|
$obj->msg = 'You MUST Specify a user';
|
||||||
die(_json_encode($obj));
|
die(_json_encode($obj));
|
||||||
}
|
}
|
||||||
|
|
||||||
$user = new User($obj->users_id);
|
$user = new User($obj->users_id);
|
||||||
|
|
||||||
if (empty($user->getUser())) {
|
if (empty($user->getUser())) {
|
||||||
$obj->msg = 'Invalid user';
|
$obj->msg = 'Invalid user';
|
||||||
die(_json_encode($obj));
|
die(_json_encode($obj));
|
||||||
}
|
}
|
||||||
|
|
||||||
$obj->users_id_statistics = $obj->users_id;
|
$obj->users_id_statistics = $obj->users_id;
|
||||||
if (User::isAdmin() && !empty($_REQUEST['isAdminPanel'])) {
|
if (User::isAdmin() && !empty($_REQUEST['isAdminPanel'])) {
|
||||||
$obj->users_id_statistics = 0; // show all results
|
$obj->users_id_statistics = 0; // show all results
|
||||||
$obj->totalUsers = User::getTotalUsers(false, 'a');
|
$obj->totalUsers = User::getTotalUsers(false, 'a');
|
||||||
} elseif (User::getId() !== $obj->users_id_statistics) {
|
} elseif (User::getId() !== $obj->users_id_statistics) {
|
||||||
$obj->msg = 'Invalid user';
|
$obj->msg = 'Invalid user';
|
||||||
die(_json_encode($obj));
|
die(_json_encode($obj));
|
||||||
}
|
}
|
||||||
|
|
||||||
$cacheName = 'statisticsReport_'.$obj->users_id_statistics;
|
$cacheName = 'statisticsReport_'.$obj->users_id_statistics;
|
||||||
|
|
||||||
$cache = ObjectYPT::getCache($cacheName, 300); // 5 min cache
|
$cache = ObjectYPT::getCache($cacheName, 300); // 5 min cache
|
||||||
if (!empty($cache)) {
|
if (!empty($cache)) {
|
||||||
if (empty($cache->performance)) {
|
if (empty($cache->performance)) {
|
||||||
$cache->performance = new stdClass();
|
$cache->performance = new stdClass();
|
||||||
}
|
}
|
||||||
if (empty($cache->performance->cache)) {
|
if (empty($cache->performance->cache)) {
|
||||||
$cache->performance->cache = new stdClass();
|
$cache->performance->cache = new stdClass();
|
||||||
}
|
}
|
||||||
$cache->performance->cache->time = time();
|
$cache->performance->cache->time = time();
|
||||||
$cache->performance->cache->date = date('Y-m-d H:i:s');
|
$cache->performance->cache->date = date('Y-m-d H:i:s');
|
||||||
$cache->performance->cache->cache_duration = microtime(true) - $obj->performance->start;
|
$cache->performance->cache->cache_duration = microtime(true) - $obj->performance->start;
|
||||||
$cache->performance->cache->human = humanTimingAgo($cache->performance->time, 2);
|
$cache->performance->cache->human = humanTimingAgo($cache->performance->time, 2);
|
||||||
die(_json_encode($cache));
|
die(_json_encode($cache));
|
||||||
}
|
}
|
||||||
|
|
||||||
$obj->can_upload = $user->getCanUpload();
|
$obj->can_upload = AVideoPlugin::userCanUpload(User::getId());
|
||||||
$obj->can_view_charts = $user->getCanViewChart();
|
$obj->can_view_charts = $user->getCanViewChart();
|
||||||
|
|
||||||
if (!$user->getIsAdmin() && empty($obj->can_view_charts)) {
|
if (!$user->getIsAdmin() && empty($obj->can_view_charts)) {
|
||||||
if ($obj->configAuthCanViewChart == 0 && !$obj->can_upload) {
|
if ($obj->configAuthCanViewChart == 0 && !$obj->can_upload) {
|
||||||
$obj->msg = 'Only uploaders have charts';
|
$obj->msg = 'Only uploaders have charts';
|
||||||
die(_json_encode($obj));
|
die(_json_encode($obj));
|
||||||
}
|
}
|
||||||
if ($obj->configAuthCanViewChart == 1) {
|
if ($obj->configAuthCanViewChart == 1) {
|
||||||
$obj->msg = 'This user is not selected to display charts';
|
$obj->msg = 'This user is not selected to display charts';
|
||||||
die(_json_encode($obj));
|
die(_json_encode($obj));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$obj->error = false;
|
$obj->error = false;
|
||||||
$obj->totalVideos = VideosStatistics::getTotalVideos($obj->users_id_statistics);
|
$obj->totalVideos = VideosStatistics::getTotalVideos($obj->users_id_statistics);
|
||||||
$obj->totalSubscriptions = VideosStatistics::getTotalSubscriptions($obj->users_id_statistics);
|
$obj->totalSubscriptions = VideosStatistics::getTotalSubscriptions($obj->users_id_statistics);
|
||||||
$obj->totalComents = VideosStatistics::getTotalComments($obj->users_id_statistics);
|
$obj->totalComents = VideosStatistics::getTotalComments($obj->users_id_statistics);
|
||||||
$obj->totalVideosViews = VideosStatistics::getTotalVideosViews($obj->users_id_statistics);
|
$obj->totalVideosViews = VideosStatistics::getTotalVideosViews($obj->users_id_statistics);
|
||||||
$obj->totalDurationVideos = intval(VideosStatistics::getTotalDuration($obj->users_id_statistics) / 60);
|
$obj->totalDurationVideos = intval(VideosStatistics::getTotalDuration($obj->users_id_statistics) / 60);
|
||||||
$obj->totalLikes = VideosStatistics::getTotalLikes($obj->users_id_statistics);
|
$obj->totalLikes = VideosStatistics::getTotalLikes($obj->users_id_statistics);
|
||||||
$obj->totalDislikes = VideosStatistics::getTotalDislikes($obj->users_id_statistics);
|
$obj->totalDislikes = VideosStatistics::getTotalDislikes($obj->users_id_statistics);
|
||||||
|
|
||||||
$obj->today = VideosStatistics::getMostViewedVideosFromLastDays($obj->users_id_statistics, 1, 10);
|
$obj->today = VideosStatistics::getMostViewedVideosFromLastDays($obj->users_id_statistics, 1, 10);
|
||||||
$obj->last7Days = VideosStatistics::getMostViewedVideosFromLastDays($obj->users_id_statistics, 7, 10);
|
$obj->last7Days = VideosStatistics::getMostViewedVideosFromLastDays($obj->users_id_statistics, 7, 10);
|
||||||
$obj->last15Days = VideosStatistics::getMostViewedVideosFromLastDays($obj->users_id_statistics, 15, 10);
|
$obj->last15Days = VideosStatistics::getMostViewedVideosFromLastDays($obj->users_id_statistics, 15, 10);
|
||||||
$obj->last30Days = VideosStatistics::getMostViewedVideosFromLastDays($obj->users_id_statistics, 30);
|
$obj->last30Days = VideosStatistics::getMostViewedVideosFromLastDays($obj->users_id_statistics, 30);
|
||||||
$obj->last90Days = VideosStatistics::getMostViewedVideosFromLastDays($obj->users_id_statistics, 90);
|
$obj->last90Days = VideosStatistics::getMostViewedVideosFromLastDays($obj->users_id_statistics, 90);
|
||||||
|
|
||||||
|
|
||||||
$obj->performance->end = microtime(true);
|
$obj->performance->end = microtime(true);
|
||||||
$obj->performance->time = time();
|
$obj->performance->time = time();
|
||||||
$obj->performance->date = date('Y-m-d H:i:s');
|
$obj->performance->date = date('Y-m-d H:i:s');
|
||||||
$obj->performance->duration = $obj->performance->end - $obj->performance->start;
|
$obj->performance->duration = $obj->performance->end - $obj->performance->start;
|
||||||
|
|
||||||
|
|
||||||
ObjectYPT::setCache($cacheName, $obj);
|
ObjectYPT::setCache($cacheName, $obj);
|
||||||
|
|
||||||
echo _json_encode($obj);
|
echo _json_encode($obj);
|
||||||
|
|
|
@ -1,3 +1,11 @@
|
||||||
|
<?php
|
||||||
|
if(!User::isAdmin()) {
|
||||||
|
echo '<!-- Only admin can see the users report -->';
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
|
|
||||||
<div class="col-md-12 col-sm-12 col-xs-12 <?php echo getCSSAnimationClassAndStyle('animate__fadeInUp'); ?>">
|
<div class="col-md-12 col-sm-12 col-xs-12 <?php echo getCSSAnimationClassAndStyle('animate__fadeInUp'); ?>">
|
||||||
<div class="panel panel-default">
|
<div class="panel panel-default">
|
||||||
<div class="panel-heading">
|
<div class="panel-heading">
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue