osb/app/Models/Usage/Broadband.php

50 lines
1.4 KiB
PHP
Raw Normal View History

2020-05-28 15:08:13 +10:00
<?php
2022-04-20 16:24:58 +10:00
namespace App\Models\Usage;
2020-05-28 15:08:13 +10:00
use Carbon\Carbon;
2020-05-28 15:08:13 +10:00
use Illuminate\Database\Eloquent\Model;
2022-04-20 16:24:58 +10:00
use App\Models\Service\Broadband as ServiceBroadband;
class Broadband extends Model
2020-05-28 15:08:13 +10:00
{
protected $dates = ['date'];
2022-04-20 16:24:58 +10:00
protected $table = 'usage_broadband';
public $timestamps = FALSE;
2021-03-12 21:08:40 +11:00
private $traffic_end = 14;
2020-05-28 15:08:13 +10:00
2022-04-20 16:24:58 +10:00
/* RELATIONS */
2020-05-28 15:08:13 +10:00
public function broadband()
{
2022-04-20 16:24:58 +10:00
return $this->belongsTo(ServiceBroadband::class);
2020-05-28 15:08:13 +10:00
}
2021-03-12 21:08:40 +11:00
2022-04-20 16:24:58 +10:00
/* ATTRIBUTES */
2021-03-12 21:08:40 +11:00
public function getTotalAttribute() {
return $this->up_peak+$this->down_peak+$this->up_offpeak+$this->down_offpeak;
}
public function getTrafficMonthEndAttribute() {
if ($this->date->day > $this->traffic_end) {
// If we are the last day of the month, we'll temporarily take 3 days since Jan 31 and addMonth() results in March.
if ($this->date->addMonth()->day != $this->date->day)
$this->date=$this->date->subDays(3);
2021-03-12 21:08:40 +11:00
return Carbon::createFromFormat('Y-m-d',$this->date->addMonth()->format('Y-m-').$this->traffic_end);
} else {
return Carbon::createFromFormat('Y-m-d',$this->date->format('Y-m-').$this->traffic_end);
}
}
public function getTrafficMonthStartAttribute() {
if ($this->date->day > $this->traffic_end) {
return Carbon::createFromFormat('Y-m-d',$this->date->format('Y-m-').($this->traffic_end+1));
} else {
return Carbon::createFromFormat('Y-m-d',$this->date->subMonth()->format('Y-m-').($this->traffic_end+1));
}
}
2020-05-28 15:08:13 +10:00
}