HOME


Mini Shell 1.0
DIR: /home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/tools/
Upload File :
Current File : /home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/tools/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();