One Hat Cyber Team
Your IP :
216.73.216.135
Server IP :
194.44.31.54
Server :
Linux zen.imath.kiev.ua 4.18.0-553.77.1.el8_10.x86_64 #1 SMP Fri Oct 3 14:30:23 UTC 2025 x86_64
Server Software :
Apache/2.4.37 (Rocky Linux) OpenSSL/1.1.1k
PHP Version :
5.6.40
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
var
/
www
/
ojs-nosc
/
lib
/
pkp
/
tools
/
View File Name :
generateTestGeoMetrics.php
<?php /** * @file tools/generateTestMGeoetrics.php * * Copyright (c) 2014-2021 Simon Fraser University * Copyright (c) 2003-2021 John Willinsky * Distributed under the GNU GPL v3. For full terms see the file docs/COPYING. * * @class generateTestGeoMetrics * * @ingroup tools * * @brief Generate example Geo metric data. */ require(dirname(__FILE__, 4) . '/tools/bootstrap.php'); use APP\facades\Repo; use APP\submission\Submission; use Illuminate\Support\Facades\DB; use Sokil\IsoCodes\IsoCodesFactory; class generateTestGeoMetrics extends \PKP\cliTool\CommandLineTool { public $contextId; public $dateStart; public $dateEnd; /** * Constructor */ public function __construct($argv = []) { parent::__construct($argv); if (sizeof($this->argv) < 3) { $this->usage(); exit(1); } $this->contextId = (int) $argv[1]; $this->dateStart = $argv[2]; $this->dateEnd = $argv[3]; } /** * Print command usage information. */ public function usage() { echo "Generate fake usage data in the DB table metrics_submission_geo_monthly.\n" . "Usage: {$this->scriptName} [contextId] [dateStart] [dateEnd]\n" . "contextId The context to add metrics for.\n" . "dateStart Add monthly metrics after this date. YYYY-MM-DD\n" . "dateEnd Add monthly metrics before this date. YYYY-MM-DD\n"; } /** * Generate test metrics */ public function execute() { $isoCodes = app(IsoCodesFactory::class); $countries = $isoCodes->getCountries()->toArray(); $subDivisions = $isoCodes->getSubdivisions(); $submissionIds = $this->getPublishedSubmissionIds(); $currentDate = new DateTime($this->dateStart); $endDate = new DateTime($this->dateEnd); $endDateTimeStamp = $endDate->getTimestamp(); $count = 0; while ($currentDate->getTimestamp() < $endDateTimeStamp) { foreach ($submissionIds as $submissionId) { $randomCountryIndex = array_rand($countries); $randomCountry = $countries[$randomCountryIndex]; $countryRegions = $subDivisions->getAllByCountryCode($randomCountry->getAlpha2()); $randomRegion = ''; if (!empty($countryRegions)) { $randomSubDivisionIndex = array_rand($countryRegions); $randomSubDivision = $countryRegions[$randomSubDivisionIndex]; $regionIsoCodeArray = explode('-', $randomSubDivision->getCode()); $randomRegion = $regionIsoCodeArray[1]; } $randomMetric = random_int(1, 10); DB::table('metrics_submission_geo_monthly')->insert([ 'context_id' => $this->contextId, 'submission_id' => $submissionId, 'country' => $randomCountry->getAlpha2(), 'region' => $randomRegion, 'month' => $currentDate->format('Ym'), 'metric' => $randomMetric, 'metric_unique' => random_int(1, $randomMetric) ]); $count++; } $currentDate->add(new DateInterval('P1M')); } echo $count . ' records added for ' . count($submissionIds) . " submissions.\n"; } /** * Get an array of all published submission IDs in the database */ public function getPublishedSubmissionIds() { return Repo::submission() ->getCollector() ->filterByContextIds([$this->contextId]) ->filterByStatus([Submission::STATUS_PUBLISHED]) ->getIds(); } } $tool = new generateTestGeoMetrics($argv ?? []); $tool->execute();