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-10-26 23:19:55 +11:00
|
|
|
use Illuminate\Support\Collection;
|
2022-01-01 16:59:35 +11:00
|
|
|
use Illuminate\Support\Facades\DB;
|
2021-05-13 22:40:21 +10:00
|
|
|
|
2022-10-30 23:42:30 +11:00
|
|
|
use App\Casts\CompressedString;
|
2022-01-01 16:59:35 +11:00
|
|
|
use App\Traits\{QueryCacheableConfig,ScopeActive};
|
2021-05-13 22:40:21 +10:00
|
|
|
|
|
|
|
class Domain extends Model
|
|
|
|
{
|
2022-01-01 16:59:35 +11:00
|
|
|
use HasFactory,ScopeActive,QueryCacheableConfig;
|
|
|
|
|
2021-11-26 16:58:50 +11:00
|
|
|
private const CACHE_TIME = 3600;
|
2021-12-03 11:24:23 +11:00
|
|
|
private const STATS_MONTHS = 6;
|
2021-06-14 15:46:18 +10:00
|
|
|
|
2022-10-30 23:42:30 +11:00
|
|
|
protected $casts = [
|
|
|
|
'homepage' => CompressedString::class,
|
|
|
|
];
|
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
|
2022-11-04 17:20:22 +11:00
|
|
|
public function nodelist_filearea()
|
|
|
|
{
|
|
|
|
return $this->belongsTo(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
|
|
|
|
2022-01-06 00:19:57 +11:00
|
|
|
/* ATTRIBUTES */
|
2021-06-14 21:33:18 +10:00
|
|
|
|
2022-12-01 23:51:43 +11:00
|
|
|
public function getHomePageAttribute(?string $value): string
|
2021-06-14 21:33:18 +10:00
|
|
|
{
|
2022-10-23 20:11:03 +11:00
|
|
|
//0xFD2FB528
|
2022-10-30 23:42:30 +11:00
|
|
|
return $this->castAttribute('homepage',$value) ?: 'No available information at the moment.';
|
2021-06-14 21:33:18 +10:00
|
|
|
}
|
2021-10-26 23:19:55 +11:00
|
|
|
|
|
|
|
/* METHODS */
|
|
|
|
|
2022-01-06 00:19:57 +11:00
|
|
|
/**
|
|
|
|
* Get some message area stats for this domain
|
|
|
|
*
|
|
|
|
* @param bool $byarea
|
|
|
|
* @param Collection|NULL $systems
|
|
|
|
* @return Collection
|
|
|
|
*/
|
|
|
|
public function daily_area_stats(bool $byarea=FALSE,Collection $systems=NULL): Collection
|
2021-11-20 17:58:46 +11:00
|
|
|
{
|
|
|
|
if (! $this->echoareas->count())
|
|
|
|
return collect();
|
|
|
|
|
2022-01-06 00:19:57 +11:00
|
|
|
$echostats = Echomail::cacheFor(self::CACHE_TIME)->select([DB::raw('datetime::date as date'),'echoarea_id','echoareas.name',DB::raw('COUNT(*)')])
|
|
|
|
->join('echoareas',['echoareas.id'=>'echomails.echoarea_id'])
|
|
|
|
->join('domains',['domains.id'=>'echoareas.domain_id'])
|
|
|
|
->where('domain_id',$this->id)
|
|
|
|
->when($systems?->count(),function($query) use ($systems) { return $query->whereIn('fftn_id',$systems->pluck('addresses')->flatten()->pluck('id')->toArray()); })
|
2022-01-01 16:59:35 +11:00
|
|
|
->where('datetime','>=',Carbon::now()->subMonths(self::STATS_MONTHS)->startOfMonth())
|
2022-01-06 00:19:57 +11:00
|
|
|
->groupBy(['echoarea_id','echoareas.name','date'])
|
|
|
|
->orderBy('date')
|
2022-01-14 19:15:37 +11:00
|
|
|
->orderBy('echoareas.name')
|
2022-01-06 00:19:57 +11:00
|
|
|
->with(['echoarea'])
|
2022-01-01 16:59:35 +11:00
|
|
|
->get();
|
2021-11-26 16:58:50 +11:00
|
|
|
|
2022-01-06 00:19:57 +11:00
|
|
|
if ($byarea)
|
2021-11-26 16:58:50 +11:00
|
|
|
return $echostats
|
2022-01-14 19:15:37 +11:00
|
|
|
->sortBy('name')
|
2022-01-06 00:19:57 +11:00
|
|
|
->groupBy(['echoarea_id'])
|
|
|
|
->map(function($item,$key) {
|
|
|
|
return [
|
|
|
|
'name' => $item->first()->echoarea->name,
|
|
|
|
'data' => $item->groupby('date')->map(function($item) {
|
|
|
|
return [
|
|
|
|
'x' => Carbon::create($item->first()->date)->timestamp*1000,
|
|
|
|
'y' => $item->sum('count')
|
|
|
|
];
|
|
|
|
})->values(),
|
|
|
|
'dashStyle' => 'ShortDot',
|
2023-07-28 13:22:39 +10:00
|
|
|
'visible'=>(bool)$item->first()->echoarea->show,
|
2022-01-06 00:19:57 +11:00
|
|
|
];
|
|
|
|
})->values();
|
|
|
|
|
|
|
|
else
|
2021-11-26 16:58:50 +11:00
|
|
|
return $echostats
|
2022-01-06 00:19:57 +11:00
|
|
|
->groupBy('date')
|
|
|
|
->map(function($item) { return ['x'=>Carbon::create($item->first()->date)->timestamp*1000,'y'=>$item->sum('count')]; })
|
2021-11-26 16:58:50 +11:00
|
|
|
->values();
|
2021-11-26 16:16:33 +11:00
|
|
|
}
|
|
|
|
|
2022-01-06 00:19:57 +11:00
|
|
|
/**
|
|
|
|
* Get the latest message in each echomail area
|
|
|
|
*
|
|
|
|
* @return Collection
|
|
|
|
*/
|
|
|
|
public function latest_echomail_message(): Collection
|
2021-10-26 23:19:55 +11:00
|
|
|
{
|
2022-01-06 00:19:57 +11:00
|
|
|
return Echoarea::cacheFor(self::CACHE_TIME)
|
|
|
|
->select([
|
|
|
|
'echoareas.*',DB::raw('max(datetime) as last_message')
|
|
|
|
])
|
|
|
|
->leftJoin('echomails',['echomails.echoarea_id'=>'echoareas.id'])
|
|
|
|
->where('domain_id',$this->id)
|
|
|
|
->groupBy('echoareas.id')
|
|
|
|
->orderBy('echoareas.name')
|
|
|
|
->get();
|
2021-10-26 23:19:55 +11:00
|
|
|
}
|
2022-11-25 17:44:03 +07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine if this zone is managed by this host
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function managed(): bool
|
|
|
|
{
|
|
|
|
static $so = NULL;
|
|
|
|
|
|
|
|
if (is_null($so))
|
|
|
|
$so = Setup::findOrFail(config('app.id'));
|
|
|
|
|
|
|
|
return $so
|
|
|
|
->system
|
|
|
|
->addresses
|
|
|
|
->where('zone.domain.active',TRUE)
|
|
|
|
->pluck('zone.domain_id')
|
|
|
|
->contains($this->id);
|
|
|
|
}
|
2021-05-13 22:40:21 +10:00
|
|
|
}
|