CompressedString::class, ]; /* 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(); }); } /* RELATIONS */ 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); } /* ATTRIBUTES */ public function getHomePageAttribute(?string $value): string { //0xFD2FB528 return $this->castAttribute('homepage',$value) ?: 'No available information at the moment.'; } /* 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 { 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()); }) ->where('datetime','>=',Carbon::now()->subMonths(self::STATS_MONTHS)->startOfMonth()) ->groupBy(['echoarea_id','echoareas.name','date']) ->orderBy('date') ->orderBy('echoareas.name') ->with(['echoarea']) ->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 { $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(); } public function isManaged(): bool { return our_address()->pluck('zone.domain')->pluck('id')->contains($this->id); } /** * Determine if this zone is managed by this host * * @return bool * @deprecated use self::isManaged(); */ public function managed(): bool { return our_address($this)->count() > 0; } 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(); }); } }