2021-05-13 22:40:21 +10:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Models;
|
|
|
|
|
2021-11-20 17:58:46 +11:00
|
|
|
use Carbon\Carbon;
|
2021-06-15 22:19:14 +10:00
|
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
2021-05-13 22:40:21 +10:00
|
|
|
use Illuminate\Database\Eloquent\Model;
|
2021-11-26 16:58:50 +11:00
|
|
|
use Illuminate\Support\Facades\Cache;
|
2021-10-26 23:19:55 +11:00
|
|
|
use Illuminate\Support\Collection;
|
2021-05-13 22:40:21 +10:00
|
|
|
|
|
|
|
use App\Traits\ScopeActive;
|
|
|
|
|
|
|
|
class Domain extends Model
|
|
|
|
{
|
2021-06-15 22:19:14 +10:00
|
|
|
use HasFactory,ScopeActive;
|
2021-11-26 16:58:50 +11:00
|
|
|
private const CACHE_TIME = 3600;
|
2021-06-14 15:46:18 +10:00
|
|
|
|
2021-06-14 21:33:18 +10:00
|
|
|
/* SCOPES */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Only query active records
|
|
|
|
*/
|
|
|
|
public function scopePublic($query)
|
|
|
|
{
|
|
|
|
return $query->where('public',TRUE);
|
|
|
|
}
|
|
|
|
|
2021-06-14 15:46:18 +10:00
|
|
|
/* RELATIONS */
|
|
|
|
|
2021-08-11 23:45:30 +10:00
|
|
|
public function echoareas()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Echoarea::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function fileareas()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Filearea::class);
|
|
|
|
}
|
|
|
|
|
2021-06-14 15:46:18 +10:00
|
|
|
public function zones()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Zone::class);
|
|
|
|
}
|
2021-06-14 21:33:18 +10:00
|
|
|
|
|
|
|
/* CASTS */
|
|
|
|
|
|
|
|
public function getHomePageAttribute($value)
|
|
|
|
{
|
|
|
|
return $value ? gzuncompress(base64_decode($value)) : 'No available information at the moment.';
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setHomePageAttribute($value)
|
|
|
|
{
|
|
|
|
$this->attributes['homepage'] = base64_encode(gzcompress($value,9));
|
|
|
|
}
|
2021-10-26 23:19:55 +11:00
|
|
|
|
|
|
|
/* METHODS */
|
|
|
|
|
2021-11-20 17:58:46 +11:00
|
|
|
public function daily_area_stats(): Collection
|
|
|
|
{
|
|
|
|
if (! $this->echoareas->count())
|
|
|
|
return collect();
|
|
|
|
|
2021-11-26 16:58:50 +11:00
|
|
|
$key = sprintf('%s_%d','daily_echoarea_stats',$this->id);
|
2021-11-20 17:58:46 +11:00
|
|
|
|
2021-11-26 16:58:50 +11:00
|
|
|
return Cache::driver('redis')->remember($key,self::CACHE_TIME,function() {
|
|
|
|
$where = ['echoarea_id'=>$this->echoareas->pluck('id')->toArray()];
|
2021-11-20 17:58:46 +11:00
|
|
|
|
2021-11-26 16:58:50 +11:00
|
|
|
$echostats = Echomail::countGroupBy(['datetime',['datetime'=>'%Y-%m-%d']],$where);
|
|
|
|
|
|
|
|
return $echostats
|
|
|
|
->sortBy(function($item) { return $item->id->datetime; })
|
|
|
|
->map(function($item) { return ['x'=>Carbon::createFromFormat('Y-m-d',$item->id->datetime)->timestamp*1000,'y'=>$item->count]; })
|
|
|
|
->values();
|
|
|
|
});
|
2021-11-20 17:58:46 +11:00
|
|
|
}
|
|
|
|
|
2021-11-26 16:16:33 +11:00
|
|
|
public function daily_echoarea_stats(Echoarea $o): Collection
|
|
|
|
{
|
|
|
|
if (! $this->echoareas->count())
|
|
|
|
return collect();
|
|
|
|
|
2021-11-26 16:58:50 +11:00
|
|
|
$key = sprintf('%s_%d-%d','daily_echoarea_stats',$this->id,$o->id);
|
2021-11-26 16:16:33 +11:00
|
|
|
|
2021-11-26 16:58:50 +11:00
|
|
|
return Cache::driver('redis')->remember($key,self::CACHE_TIME,function() use ($o) {
|
|
|
|
$where = ['echoarea_id'=>[$o->id]];
|
2021-11-26 16:16:33 +11:00
|
|
|
|
2021-11-26 16:58:50 +11:00
|
|
|
$echostats = Echomail::countGroupBy(['datetime',['datetime'=>'%Y-%m-%d']],$where);
|
|
|
|
|
|
|
|
return $echostats
|
|
|
|
->sortBy(function($item) { return $item->id->datetime; })
|
|
|
|
->map(function($item) { return ['x'=>Carbon::createFromFormat('Y-m-d',$item->id->datetime)->timestamp*1000,'y'=>$item->count]; })
|
|
|
|
->values();
|
|
|
|
});
|
2021-11-26 16:16:33 +11:00
|
|
|
}
|
|
|
|
|
2021-10-26 23:19:55 +11:00
|
|
|
public function stats(System $o=NULL): Collection
|
|
|
|
{
|
|
|
|
if (! $this->echoareas->count())
|
|
|
|
return collect();
|
|
|
|
|
|
|
|
$where = collect(['echoarea_id'=>$this->echoareas->pluck('id')->toArray()]);
|
|
|
|
|
|
|
|
if ($o)
|
|
|
|
$where->put('fftn_id',$o->addresses()->pluck('id'));
|
|
|
|
|
2021-11-20 17:58:46 +11:00
|
|
|
$echostats = Echomail::countGroupBy(['echoarea_id'],$where->toArray());
|
2021-10-26 23:19:55 +11:00
|
|
|
|
|
|
|
return $this->echoareas->map(function($item) use ($echostats) {
|
|
|
|
$stats = $echostats->filter(function($x) use ($item) {
|
|
|
|
return $x->id->echoarea_id == $item->id;
|
|
|
|
});
|
|
|
|
|
|
|
|
$item->count = 0;
|
|
|
|
|
|
|
|
foreach ($stats as $o)
|
|
|
|
$item->count += $o->count;
|
|
|
|
|
|
|
|
return $item;
|
|
|
|
});
|
|
|
|
}
|
2021-05-13 22:40:21 +10:00
|
|
|
}
|