removed visitors feature
This commit is contained in:
parent
12c6c665fc
commit
c892ef5b6e
@ -36,40 +36,11 @@ class Stats extends Request {
|
|||||||
return $this->success;
|
return $this->success;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getVisitorCount() {
|
|
||||||
$sql = $this->context->getSQL();
|
|
||||||
$date = new DateTime();
|
|
||||||
$monthStart = $date->format("Ym00");
|
|
||||||
$monthEnd = $date->modify("+1 month")->format("Ym00");
|
|
||||||
$res = $sql->select(new Count(new Distinct("cookie")))
|
|
||||||
->from("Visitor")
|
|
||||||
->where(new Compare("day", $monthStart, ">="))
|
|
||||||
->where(new Compare("day", $monthEnd, "<"))
|
|
||||||
->where(new Compare("count", 2, ">="))
|
|
||||||
->execute();
|
|
||||||
|
|
||||||
$this->success = ($res !== false);
|
|
||||||
$this->lastError = $sql->getLastError();
|
|
||||||
return ($this->success ? $res[0]["count"] : $this->success);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function _execute(): bool {
|
public function _execute(): bool {
|
||||||
$sql = $this->context->getSQL();
|
$sql = $this->context->getSQL();
|
||||||
$userCount = User::count($sql);
|
$userCount = User::count($sql);
|
||||||
$pageCount = Route::count($sql, new CondBool("active"));
|
$pageCount = Route::count($sql, new CondBool("active"));
|
||||||
$groupCount = Group::count($sql);
|
$groupCount = Group::count($sql);
|
||||||
$req = new \Core\API\Visitors\Stats($this->context);
|
|
||||||
$this->success = $req->execute(array("type"=>"monthly"));
|
|
||||||
$this->lastError = $req->getLastError();
|
|
||||||
if (!$this->success) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$visitorStatistics = $req->getResult()["visitors"];
|
|
||||||
$visitorCount = $this->getVisitorCount();
|
|
||||||
if (!$this->success) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$req = new \Core\API\Logs\Get($this->context, false);
|
$req = new \Core\API\Logs\Get($this->context, false);
|
||||||
$success = $req->execute([
|
$success = $req->execute([
|
||||||
@ -96,8 +67,6 @@ class Stats extends Request {
|
|||||||
"userCount" => $userCount,
|
"userCount" => $userCount,
|
||||||
"pageCount" => $pageCount,
|
"pageCount" => $pageCount,
|
||||||
"groupCount" => $groupCount,
|
"groupCount" => $groupCount,
|
||||||
"visitors" => $visitorStatistics,
|
|
||||||
"visitorsTotal" => $visitorCount,
|
|
||||||
"errorCount" => $errorCount,
|
"errorCount" => $errorCount,
|
||||||
"server" => [
|
"server" => [
|
||||||
"version" => WEBBASE_VERSION,
|
"version" => WEBBASE_VERSION,
|
||||||
|
@ -1,122 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace Core\API {
|
|
||||||
|
|
||||||
use Core\Objects\Context;
|
|
||||||
|
|
||||||
abstract class VisitorsAPI extends Request {
|
|
||||||
public function __construct(Context $context, bool $externalCall = false, array $params = []) {
|
|
||||||
parent::__construct($context, $externalCall, $params);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace Core\API\Visitors {
|
|
||||||
|
|
||||||
use Core\API\Parameter\Parameter;
|
|
||||||
use Core\API\Parameter\StringType;
|
|
||||||
use Core\API\VisitorsAPI;
|
|
||||||
use Core\Driver\SQL\Expression\Count;
|
|
||||||
use Core\Driver\SQL\Query\Insert;
|
|
||||||
use Core\Objects\DatabaseEntity\Group;
|
|
||||||
use DateTime;
|
|
||||||
use Core\Driver\SQL\Condition\Compare;
|
|
||||||
use Core\Driver\SQL\Expression\Add;
|
|
||||||
use Core\Driver\SQL\Query\Select;
|
|
||||||
use Core\Driver\SQL\Strategy\UpdateStrategy;
|
|
||||||
use Core\Objects\Context;
|
|
||||||
|
|
||||||
class ProcessVisit extends VisitorsAPI {
|
|
||||||
public function __construct(Context $context, bool $externalCall = false) {
|
|
||||||
parent::__construct($context, $externalCall, array(
|
|
||||||
"cookie" => new StringType("cookie", 26)
|
|
||||||
));
|
|
||||||
$this->isPublic = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function _execute(): bool {
|
|
||||||
$sql = $this->context->getSQL();
|
|
||||||
$cookie = $this->getParam("cookie");
|
|
||||||
$day = (new DateTime())->format("Ymd");
|
|
||||||
$sql->insert("Visitor", array("cookie", "day"))
|
|
||||||
->addRow($cookie, $day)
|
|
||||||
->onDuplicateKeyStrategy(new UpdateStrategy(
|
|
||||||
array("day", "cookie"),
|
|
||||||
array("count" => new Add("Visitor.count", 1))))
|
|
||||||
->execute();
|
|
||||||
|
|
||||||
return $this->success;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class Stats extends VisitorsAPI {
|
|
||||||
public function __construct(Context $context, bool $externalCall = false) {
|
|
||||||
parent::__construct($context, $externalCall, array(
|
|
||||||
'type' => new StringType('type', 32),
|
|
||||||
'date' => new Parameter('date', Parameter::TYPE_DATE, true, new DateTime())
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
private function setConditions(string $type, DateTime $date, Select $query): bool {
|
|
||||||
if ($type === "yearly") {
|
|
||||||
$yearStart = $date->format("Y0000");
|
|
||||||
$yearEnd = $date->modify("+1 year")->format("Y0000");
|
|
||||||
$query->where(new Compare("day", $yearStart, ">="));
|
|
||||||
$query->where(new Compare("day", $yearEnd, "<"));
|
|
||||||
} else if($type === "monthly") {
|
|
||||||
$monthStart = $date->format("Ym00");
|
|
||||||
$monthEnd = $date->modify("+1 month")->format("Ym00");
|
|
||||||
$query->where(new Compare("day", $monthStart, ">="));
|
|
||||||
$query->where(new Compare("day", $monthEnd, "<"));
|
|
||||||
} else if($type === "weekly") {
|
|
||||||
$weekStart = ($date->modify("monday this week"))->format("Ymd");
|
|
||||||
$weekEnd = ($date->modify("sunday this week"))->format("Ymd");
|
|
||||||
$query->where(new Compare("day", $weekStart, ">="));
|
|
||||||
$query->where(new Compare("day", $weekEnd, "<="));
|
|
||||||
} else {
|
|
||||||
return $this->createError("Invalid scope: $type");
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function _execute(): bool {
|
|
||||||
$date = $this->getParam("date");
|
|
||||||
$type = $this->getParam("type");
|
|
||||||
|
|
||||||
$sql = $this->context->getSQL();
|
|
||||||
$query = $sql->select(new Count(), "day")
|
|
||||||
->from("Visitor")
|
|
||||||
->whereGt("count", 1)
|
|
||||||
->groupBy("day")
|
|
||||||
->orderBy("day")
|
|
||||||
->ascending();
|
|
||||||
|
|
||||||
$this->success = $this->setConditions($type, $date, $query);
|
|
||||||
if (!$this->success) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$res = $query->execute();
|
|
||||||
$this->success = ($res !== FALSE);
|
|
||||||
$this->lastError = $sql->getLastError();
|
|
||||||
|
|
||||||
if ($this->success) {
|
|
||||||
$this->result["type"] = $type;
|
|
||||||
$this->result["visitors"] = array();
|
|
||||||
|
|
||||||
foreach($res as $row) {
|
|
||||||
$day = DateTime::createFromFormat("Ymd", $row["day"])->format("Y/m/d");
|
|
||||||
$count = $row["count"];
|
|
||||||
$this->result["visitors"][$day] = $count;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->success;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function getDefaultACL(Insert $insert): void {
|
|
||||||
$insert->addRow(self::getEndpoint(), [Group::ADMIN, Group::SUPPORT], "Allows users to view visitor statistics", true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -18,12 +18,6 @@ class CreateDatabase extends DatabaseScript {
|
|||||||
|
|
||||||
self::loadEntities($queries, $sql);
|
self::loadEntities($queries, $sql);
|
||||||
|
|
||||||
$queries[] = $sql->createTable("Visitor")
|
|
||||||
->addInt("day")
|
|
||||||
->addInt("count", false, 1)
|
|
||||||
->addString("cookie", 26)
|
|
||||||
->unique("day", "cookie");
|
|
||||||
|
|
||||||
$queries[] = $sql->createTable("Settings")
|
$queries[] = $sql->createTable("Settings")
|
||||||
->addString("name", 32)
|
->addString("name", 32)
|
||||||
->addString("value", 1024, true)
|
->addString("value", 1024, true)
|
||||||
|
@ -3,7 +3,6 @@
|
|||||||
return [
|
return [
|
||||||
"title" => "Administration",
|
"title" => "Administration",
|
||||||
"dashboard" => "Dashboard",
|
"dashboard" => "Dashboard",
|
||||||
"visitor_statistics" => "Besucherstatistiken",
|
|
||||||
"user_groups" => "Benutzer & Gruppen",
|
"user_groups" => "Benutzer & Gruppen",
|
||||||
"users" => "Benutzer",
|
"users" => "Benutzer",
|
||||||
"groups" => "Gruppen",
|
"groups" => "Gruppen",
|
||||||
|
@ -3,7 +3,6 @@
|
|||||||
return [
|
return [
|
||||||
"title" => "Administration",
|
"title" => "Administration",
|
||||||
"dashboard" => "Dashboard",
|
"dashboard" => "Dashboard",
|
||||||
"visitor_statistics" => "Visitor Statistics",
|
|
||||||
"user_groups" => "Users & Groups",
|
"user_groups" => "Users & Groups",
|
||||||
"users" => "Users",
|
"users" => "Users",
|
||||||
"groups" => "Groups",
|
"groups" => "Groups",
|
||||||
|
@ -139,18 +139,6 @@ class Context {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function processVisit(): void {
|
|
||||||
if (isset($_COOKIE["PHPSESSID"]) && !empty($_COOKIE["PHPSESSID"])) {
|
|
||||||
if ($this->isBot()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$cookie = $_COOKIE["PHPSESSID"];
|
|
||||||
$req = new \Core\API\Visitors\ProcessVisit($this);
|
|
||||||
$req->execute(["cookie" => $cookie]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private function isBot(): bool {
|
private function isBot(): bool {
|
||||||
if (empty($_SERVER["HTTP_USER_AGENT"])) {
|
if (empty($_SERVER["HTTP_USER_AGENT"])) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -64,7 +64,7 @@ if ($installation) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ($router !== null) {
|
if ($router !== null) {
|
||||||
|
$logger = $router->getLogger();
|
||||||
if ((!isset($_GET["site"]) || $_GET["site"] === "/") && isset($_GET["error"]) &&
|
if ((!isset($_GET["site"]) || $_GET["site"] === "/") && isset($_GET["error"]) &&
|
||||||
is_string($_GET["error"]) && preg_match("/^\d+$/", $_GET["error"])) {
|
is_string($_GET["error"]) && preg_match("/^\d+$/", $_GET["error"])) {
|
||||||
$response = $router->returnStatusCode(intval($_GET["error"]));
|
$response = $router->returnStatusCode(intval($_GET["error"]));
|
||||||
@ -84,12 +84,13 @@ if ($installation) {
|
|||||||
} else {
|
} else {
|
||||||
$response = $router->returnStatusCode(403, ["message" => $error]);
|
$response = $router->returnStatusCode(403, ["message" => $error]);
|
||||||
}
|
}
|
||||||
|
$logger->warning("The site was accessed by an untrusted domain: $currentHostName");
|
||||||
} else {
|
} else {
|
||||||
$response = $route->call($router, $pathParams);
|
$response = $route->call($router, $pathParams);
|
||||||
}
|
}
|
||||||
} catch (\Throwable $e) {
|
} catch (\Throwable $e) {
|
||||||
http_response_code(500);
|
http_response_code(500);
|
||||||
$router->getLogger()->error($e->getMessage());
|
$logger->error($e->getMessage());
|
||||||
$response = $router->returnStatusCode(500);
|
$response = $router->returnStatusCode(500);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -97,8 +98,6 @@ if ($installation) {
|
|||||||
http_response_code(500);
|
http_response_code(500);
|
||||||
$response = "Router could not be instantiated.";
|
$response = "Router could not be instantiated.";
|
||||||
}
|
}
|
||||||
|
|
||||||
$context->processVisit();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$context->sendCookies();
|
$context->sendCookies();
|
||||||
|
@ -40,10 +40,6 @@ export default function Sidebar(props) {
|
|||||||
"name": "admin.dashboard",
|
"name": "admin.dashboard",
|
||||||
"icon": "tachometer-alt"
|
"icon": "tachometer-alt"
|
||||||
},
|
},
|
||||||
"visitors": {
|
|
||||||
"name": "admin.visitor_statistics",
|
|
||||||
"icon": "chart-bar",
|
|
||||||
},
|
|
||||||
"users": {
|
"users": {
|
||||||
"name": "admin.users",
|
"name": "admin.users",
|
||||||
"icon": "users"
|
"icon": "users"
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
import * as React from "react";
|
import * as React from "react";
|
||||||
import {Link} from "react-router-dom";
|
import {Link} from "react-router-dom";
|
||||||
import {format, getDaysInMonth} from "date-fns";
|
|
||||||
import {useCallback, useContext, useEffect, useState} from "react";
|
import {useCallback, useContext, useEffect, useState} from "react";
|
||||||
import {LocaleContext} from "shared/locale";
|
import {LocaleContext} from "shared/locale";
|
||||||
import {ArrowCircleRight, BugReport, Groups, LibraryBooks, People} from "@mui/icons-material";
|
import {ArrowCircleRight, BugReport, Groups, LibraryBooks, People} from "@mui/icons-material";
|
||||||
@ -57,41 +56,6 @@ export default function Overview(props) {
|
|||||||
onFetchStats();
|
onFetchStats();
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
const today = new Date();
|
|
||||||
const numDays = getDaysInMonth(today);
|
|
||||||
|
|
||||||
let colors = [ '#ff4444', '#ffbb33', '#00C851', '#33b5e5' ];
|
|
||||||
while (colors.length < numDays) {
|
|
||||||
colors = colors.concat(colors);
|
|
||||||
}
|
|
||||||
|
|
||||||
let data = new Array(numDays).fill(0);
|
|
||||||
let visitorCount = 0;
|
|
||||||
/*
|
|
||||||
for (let date in this.state.visitors) {
|
|
||||||
if (this.state.visitors.hasOwnProperty(date)) {
|
|
||||||
let day = parseInt(date.split("/")[2]) - 1;
|
|
||||||
if (day >= 0 && day < numDays) {
|
|
||||||
let count = parseInt(this.state.visitors[date]);
|
|
||||||
data[day] = count;
|
|
||||||
visitorCount += count;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
let labels = Array.from(Array(numDays), (_, i) => i + 1);
|
|
||||||
let chartOptions = {};
|
|
||||||
let chartData = {
|
|
||||||
labels: labels,
|
|
||||||
datasets: [{
|
|
||||||
label: 'Unique Visitors ' + format(today, "MMMM"),
|
|
||||||
borderWidth: 1,
|
|
||||||
data: data,
|
|
||||||
backgroundColor: colors,
|
|
||||||
}]
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
let loadAvg = this.state.server.load_avg;
|
let loadAvg = this.state.server.load_avg;
|
||||||
if (Array.isArray(this.state.server.load_avg)) {
|
if (Array.isArray(this.state.server.load_avg)) {
|
||||||
@ -125,7 +89,7 @@ export default function Overview(props) {
|
|||||||
<StatBox color={"success"} count={stats?.groupCount}
|
<StatBox color={"success"} count={stats?.groupCount}
|
||||||
text={L("admin.available_groups")}
|
text={L("admin.available_groups")}
|
||||||
icon={<Groups />}
|
icon={<Groups />}
|
||||||
link={"/admin/users"} />
|
link={"/admin/groups"} />
|
||||||
<StatBox color={"warning"} count={stats?.pageCount}
|
<StatBox color={"warning"} count={stats?.pageCount}
|
||||||
text={L("admin.routes_defined")}
|
text={L("admin.routes_defined")}
|
||||||
icon={<LibraryBooks />}
|
icon={<LibraryBooks />}
|
||||||
|
@ -314,11 +314,6 @@ export default class API {
|
|||||||
return this.apiCall("permission/delete", { method: method });
|
return this.apiCall("permission/delete", { method: method });
|
||||||
}
|
}
|
||||||
|
|
||||||
/** VisitorsAPI **/
|
|
||||||
async getVisitors(type, date) {
|
|
||||||
return this.apiCall("visitors/stats", { type: type, date: date });
|
|
||||||
}
|
|
||||||
|
|
||||||
/** LanguageAPI **/
|
/** LanguageAPI **/
|
||||||
async getLanguages() {
|
async getLanguages() {
|
||||||
return this.apiCall("language/get");
|
return this.apiCall("language/get");
|
||||||
|
Loading…
Reference in New Issue
Block a user