2018-06-05 21:13:57 +10:00
< ? php
namespace App\Models ;
2022-04-20 16:24:58 +10:00
use Carbon\Carbon ;
2018-06-05 21:13:57 +10:00
use Illuminate\Database\Eloquent\Model ;
2021-12-24 12:14:01 +11:00
use Illuminate\Support\Arr ;
use Illuminate\Support\Collection ;
2021-12-20 14:25:43 +11:00
use Leenooks\Traits\ScopeActive ;
2018-06-05 21:13:57 +10:00
2022-04-19 17:07:39 +10:00
use App\Models\Supplier\ { Broadband , Domain , Email , Ethernet , Generic , Host , HSPA , Phone , SSL };
2021-12-24 12:14:01 +11:00
2018-06-05 21:13:57 +10:00
class Supplier extends Model
{
2021-12-20 14:25:43 +11:00
use ScopeActive ;
public $timestamps = FALSE ;
2022-06-12 11:21:20 +10:00
/**
* The offerings we provide
* @ todo Use the product /* category instead of this const . The assumption is the supplier /* type is the same as the product /* type .
* @ deprecated - use the product /* category instead .
*/
2021-12-24 12:14:01 +11:00
public const offering_types = [
'broadband' => [
'name' => 'Broadband' ,
'class' => Broadband :: class ,
],
'hspa' => [
'name' => 'Mobile Broadband' ,
'class' => HSPA :: class ,
],
'ethernet' => [
'name' => 'Ethernet Broadband' ,
'class' => Ethernet :: class ,
],
'domainname' => [
'name' => 'Domain Name' ,
2022-02-01 16:40:46 +11:00
'class' => Domain :: class ,
2021-12-24 12:14:01 +11:00
],
2022-04-02 18:06:34 +11:00
'email' => [
'name' => 'Email Hosting' ,
'class' => Email :: class ,
],
2021-12-24 12:14:01 +11:00
'generic' => [
'name' => 'Generic' ,
2022-02-01 16:40:46 +11:00
'class' => Generic :: class ,
2021-12-24 12:14:01 +11:00
],
'hosting' => [
'name' => 'Hosting' ,
2022-02-01 16:40:46 +11:00
'class' => Host :: class ,
2021-12-24 12:14:01 +11:00
],
2022-04-19 17:07:39 +10:00
'phone' => [
'name' => 'Phone' ,
'class' => Phone :: class ,
],
'ssl' => [
'name' => 'SSL' ,
'class' => SSL :: class ,
2021-12-24 12:14:01 +11:00
],
];
2021-12-20 14:25:43 +11:00
/* RELATIONS */
2022-04-19 17:07:39 +10:00
// @todo Need to put in an integrity constraint to support the hasOne()
// @todo Some suppliers have multiple different configuration urls/passwords and contacts for different types of services, perhaps this should be hasMany()?
// EG: Crazy Domains, "domains" and "hosting".
2021-12-20 14:25:43 +11:00
public function detail ()
{
2022-04-20 16:24:58 +10:00
return $this -> hasOne ( SupplierDetail :: class )
-> withoutGlobalScope ( \App\Models\Scopes\SiteScope :: class );
2021-12-20 14:25:43 +11:00
}
2021-12-24 12:14:01 +11:00
/* METHODS */
/**
* Return the offerings that this supplier provides
*
* @ return void
*/
public function offeringTypes () : Collection
{
$result = collect ();
// See if we have any configurations
foreach ( self :: offering_types as $key => $type ) {
2022-02-01 16:40:46 +11:00
if ( ! ( $class = Arr :: get ( $type , 'class' )))
2021-12-24 12:14:01 +11:00
continue ;
if ( Arr :: get ( $this -> detail -> connections , $key )) {
$result -> put ( $key ,( object )[
'type' => Arr :: get ( $type , 'name' ),
'items' => ( new $class ) -> where ( 'supplier_detail_id' , $this -> detail -> id ),
]);
continue ;
}
// See if we have any products defined
$o = new $class ;
$o -> where ( 'supplier_detail_id' , $this -> detail -> id );
if ( $o -> count ())
$result -> put ( $key ,( object )[
'type' => Arr :: get ( $type , 'name' ),
'items' => ( new $class ) -> where ( 'supplier_detail_id' , $this -> detail -> id ),
]);
}
return $result ;
}
2022-04-20 16:24:58 +10:00
/**
* Return the traffic records , that were not matched to a service .
*
* @ param Carbon $date
* @ return \Illuminate\Database\Eloquent\Collection
*/
public function trafficMismatch ( Carbon $date ) : Collection
{
return Usage\Broadband :: where ( 'date' , $date -> format ( 'Y-m-d' ))
-> where ( 'supplier_id' , $this -> id )
-> whereNULL ( 'service_item_id' )
-> get ();
}
2021-12-20 14:25:43 +11:00
}