Update and fix broadband traffic
This commit is contained in:
26
app/Classes/External/Supplier.php
vendored
26
app/Classes/External/Supplier.php
vendored
@@ -17,6 +17,8 @@ abstract class Supplier
|
||||
protected $o = NULL;
|
||||
protected $_columns = [];
|
||||
|
||||
public const traffic_connection_keys = ['user','pass','url'];
|
||||
|
||||
public function __construct(Model $o)
|
||||
{
|
||||
$this->o = $o;
|
||||
@@ -26,24 +28,29 @@ abstract class Supplier
|
||||
/**
|
||||
* Connect and pull down traffic data
|
||||
*
|
||||
* @param array $connection
|
||||
* @param string $type
|
||||
* @return Collection
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function fetch(): Collection
|
||||
public function fetch(array $connection,string $type): Collection
|
||||
{
|
||||
if (count(array_intersect(array_keys($connection),self::traffic_connection_keys)) !== 3)
|
||||
throw new \Exception('No or missing connection details for:'.$type);
|
||||
|
||||
if ($x=$this->mustPause()) {
|
||||
Log::notice(sprintf('%s:API Throttle, waiting [%s]...',self::LOGKEY,$x),['m'=>__METHOD__]);
|
||||
sleep($x);
|
||||
}
|
||||
|
||||
Log::debug(sprintf('%s:Supplier [%d], fetch data for [%s]...',self::LOGKEY,$this->o->id,$this->o->stats_lastupdate),['m'=>__METHOD__]);
|
||||
$key = 'Supplier:'.$this->o->id.$this->o->stats_lastupdate;
|
||||
$result = Cache::remember($key,86400,function() {
|
||||
$client = $this->getClient();
|
||||
Log::debug(sprintf('%s:Supplier [%d], fetch data for [%s]...',self::LOGKEY,$this->o->id,Arr::get($connection,'last')),['m'=>__METHOD__]);
|
||||
$key = 'Supplier:'.$this->o->id.Arr::get($connection,'last');
|
||||
|
||||
$response = Http::get($this->o->stats_url,[
|
||||
$this->login_user_field => $this->o->stats_username,
|
||||
$this->login_pass_field => $this->o->stats_password,
|
||||
$this->date_field => $this->o->stats_lastupdate->format('Y-m-d'),
|
||||
$result = Cache::remember($key,86400,function() use ($connection) {
|
||||
$response = Http::get(Arr::get($connection,'url'),[
|
||||
$this->login_user_field => Arr::get($connection,'user'),
|
||||
$this->login_pass_field => Arr::get($connection,'pass'),
|
||||
$this->date_field => Arr::get($connection,'last'),
|
||||
]);
|
||||
|
||||
// @todo These API rate limiting is untested.
|
||||
@@ -55,7 +62,6 @@ abstract class Supplier
|
||||
Cache::put('api_throttle',$api_reset,now()->addSeconds($api_reset));
|
||||
}
|
||||
|
||||
//dd($response->header('Content-Type'),$response->headers());
|
||||
// Assume the supplier provides an ASCII output for text/html
|
||||
if (preg_match('#^text/html;#',$x=$response->header('Content-Type'))) {
|
||||
return collect(explode("\n",$response->body()))->filter();
|
||||
|
Reference in New Issue
Block a user