Merge pull request #115 from francislavoie/stats-url

Add support for overriding stats logger's base URL
This commit is contained in:
rennokki 2020-08-13 10:03:56 +03:00 committed by GitHub
commit 9d8e2ff323
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 20 additions and 1 deletions

View File

@ -92,6 +92,14 @@ return [
*/
'delete_statistics_older_than_days' => 60,
/*
* By default, the websockets server attempts to connect to whatever
* your APP_URL is set to. If running in a more complex environment,
* you may wish to override the base URL for internal requests to
* allow statistics to be collected.
*/
'base_url_override' => null,
/*
* Use an DNS resolver to make the requests to the statistics logger
* default is to resolve everything to 127.0.0.1.

View File

@ -79,7 +79,7 @@ class HttpStatisticsLogger implements StatisticsLogger
$this
->browser
->post(
action([WebSocketStatisticsEntriesController::class, 'store']),
$this->storeStatisticsUrl(),
['Content-Type' => 'application/json'],
stream_for(json_encode($postData))
);
@ -88,4 +88,15 @@ class HttpStatisticsLogger implements StatisticsLogger
$statistic->reset($currentConnectionCount);
}
}
protected function storeStatisticsUrl(): string
{
$action = [WebSocketStatisticsEntriesController::class, 'store'];
$overridenUrl = config('websockets.statistics.base_url_override');
return $overridentUrl
? $overridenUrl.action($action, [], false)
: action($action);
}
}