clrghouz/app/Models/Domain.php

175 lines
5.1 KiB
PHP
Raw Normal View History

2021-05-13 12:40:21 +00:00
<?php
namespace App\Models;
use AgliPanci\LaravelCase\Facades\CaseBuilder;
2021-11-20 06:58:46 +00:00
use Carbon\Carbon;
2021-06-15 12:19:14 +00:00
use Illuminate\Database\Eloquent\Factories\HasFactory;
2021-05-13 12:40:21 +00:00
use Illuminate\Database\Eloquent\Model;
2021-10-26 12:19:55 +00:00
use Illuminate\Support\Collection;
use Illuminate\Support\Facades\Auth;
2024-04-20 12:03:47 +00:00
use Illuminate\Support\Facades\Cache;
2022-01-01 05:59:35 +00:00
use Illuminate\Support\Facades\DB;
2021-05-13 12:40:21 +00:00
use App\Casts\CompressedString;
2022-01-01 05:59:35 +00:00
use App\Traits\{QueryCacheableConfig,ScopeActive};
2021-05-13 12:40:21 +00:00
class Domain extends Model
{
2022-01-01 05:59:35 +00:00
use HasFactory,ScopeActive,QueryCacheableConfig;
private const CACHE_TIME = 3600;
private const STATS_MONTHS = 6;
protected $casts = [
'homepage' => CompressedString::class,
];
2021-06-14 11:33:18 +00:00
/* SCOPES */
/**
* Only query active records
*/
public function scopePublic($query)
{
$user = Auth::user();
return $query
->when(((! $user) || (! $user->isAdmin())),function($query) { return $query->where('public',TRUE)->active(); });
2021-06-14 11:33:18 +00:00
}
/* RELATIONS */
2021-08-11 13:45:30 +00:00
public function echoareas()
{
return $this->hasMany(Echoarea::class);
}
public function fileareas()
{
return $this->hasMany(Filearea::class);
}
public function nodelist_filearea()
{
return $this->belongsTo(Filearea::class);
}
public function zones()
{
return $this->hasMany(Zone::class);
}
2021-06-14 11:33:18 +00:00
/* ATTRIBUTES */
2021-06-14 11:33:18 +00:00
public function getHomePageAttribute(?string $value): string
2021-06-14 11:33:18 +00:00
{
//0xFD2FB528
return $this->castAttribute('homepage',$value) ?: 'No available information at the moment.';
2021-06-14 11:33:18 +00:00
}
2021-10-26 12:19:55 +00:00
/* METHODS */
/**
* 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 06:58:46 +00:00
{
if (! $this->echoareas->count())
return collect();
$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 05:59:35 +00:00
->where('datetime','>=',Carbon::now()->subMonths(self::STATS_MONTHS)->startOfMonth())
->groupBy(['echoarea_id','echoareas.name','date'])
->orderBy('date')
->orderBy('echoareas.name')
->with(['echoarea'])
2022-01-01 05:59:35 +00:00
->get();
if ($byarea)
return $echostats
->sortBy('name')
->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',
'visible'=>(bool)$item->first()->echoarea->show,
];
})->values();
else
return $echostats
->groupBy('date')
->map(function($item) { return ['x'=>Carbon::create($item->first()->date)->timestamp*1000,'y'=>$item->sum('count')]; })
->values();
}
public function echoarea_stats(): Collection
2021-10-26 12:19:55 +00:00
{
$dt = Carbon::now()->startOfday();
$case = CaseBuilder::whenRaw("datetime >= '?'",$dt->subDay()->format('Y-m-d'))->thenRaw("'day'")
->whenRaw("datetime >= '?'",$dt->subDays(7)->format('Y-m-d'))->thenRaw("'week'")
->whenRaw("datetime >= '?'",$dt->subMonth()->format('Y-m-d'))->thenRaw("'month'")
->elseRaw("'all'");
return Echoarea::cacheFor(self::CACHE_TIME)
->select(['echoareas.id','name','description','active',DB::raw('count(echomails.id) AS count'),DB::raw('max(datetime) as last_message')])
->selectRaw($case->toRaw().' AS stats')
->join('echomails',['echomails.echoarea_id'=>'echoareas.id'],NULL,NULL,'left outer')
->where('domain_id',$this->id)
->groupBy('echoareas.id')
->groupBy('echoareas.name')
->groupBy('stats')
->orderBy('echoareas.name')
->orderBy('last_message','DESC')
->get();
2021-10-26 12:19:55 +00:00
}
2022-11-25 10:44:03 +00:00
public function isManaged(): bool
{
return our_address()->pluck('zone.domain')->pluck('id')->contains($this->id);
}
2022-11-25 10:44:03 +00:00
/**
* Determine if this zone is managed by this host
*
* @return bool
* @deprecated use self::isManaged();
2022-11-25 10:44:03 +00:00
*/
public function managed(): bool
{
return our_address($this)->count() > 0;
2022-11-25 10:44:03 +00:00
}
2024-04-20 12:03:47 +00:00
public function total_echomail(Collection $systems=NULL): Collection
{
return Cache::remember(sprintf('%d-%s',$this->id,$systems?->pluck('id')->join(',')),self::CACHE_TIME,function() use ($systems) {
return DB::query()
->select(['echoareas.name',DB::raw('count(*) as count')])
->from($this->getTable())
->join('echoareas',['echoareas.domain_id'=>'domains.id'])
->join('echomails',['echomails.echoarea_id'=>'echoareas.id'])
->where('domains.id',$this->id)
->where('echomails.datetime','>=',Carbon::now()->subMonths(self::STATS_MONTHS)->startOfMonth())
->when($systems?->count(),function($query) use ($systems) { return $query->whereIn('echomails.fftn_id',$systems->pluck('addresses')->flatten()->pluck('id')); })
->groupBy(['echoareas.id'])
->orderBy('echoareas.name')
->get();
});
}
2021-05-13 12:40:21 +00:00
}