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-06-30 23:51:20 +10:00
use App\Models\Supplier\ { Broadband , Domain , Email , Ethernet , Generic , Host , HSPA , Phone , SSL , Type };
2021-12-24 12:14:01 +11:00
2018-06-05 21:13:57 +10:00
class Supplier extends Model
{
2022-06-12 11:21:20 +10:00
/**
2022-06-30 23:51:20 +10:00
* The offerings types we provide
2022-06-12 11:21:20 +10:00
*/
2022-06-30 23:51:20 +10:00
private const offering_types = [
'broadband' => Broadband :: class ,
'hspa' => HSPA :: class ,
'ethernet' => Ethernet :: class ,
'domainname' => Domain :: class ,
'email' => Email :: class ,
'generic' => Generic :: class ,
'hosting' => Host :: class ,
'phone' => Phone :: class ,
'ssl' => SSL :: class ,
2021-12-24 12:14:01 +11:00
];
2022-06-30 23:51:20 +10:00
use ScopeActive ;
2021-12-20 14:25:43 +11:00
2022-06-30 23:51:20 +10:00
public $timestamps = FALSE ;
2021-12-24 12:14:01 +11:00
2022-06-30 23:51:20 +10:00
/* STATIC METHODS */
2021-12-24 12:14:01 +11:00
/**
* Return the offerings that this supplier provides
*
2022-06-30 23:51:20 +10:00
* @ param Supplier | null $so
* @ return Collection
2021-12-24 12:14:01 +11:00
*/
2022-06-30 23:51:20 +10:00
public static function offeringTypes ( self $so = NULL ) : Collection
2021-12-24 12:14:01 +11:00
{
$result = collect ();
2022-06-30 23:51:20 +10:00
foreach ( self :: offering_types as $type ) {
$class = new $type ;
2021-12-24 12:14:01 +11:00
2022-06-30 23:51:20 +10:00
if ( $so ) {
// If we have a connections configuration for that supplier, then build the child relationships
if ( Arr :: get ( $so -> detail -> connections , $class -> category )) {
$result -> put ( $class -> category ,( object )[
'type' => $class -> category_name ,
'items' => $class -> where ( 'supplier_detail_id' , $so -> detail -> id ),
2021-12-24 12:14:01 +11:00
]);
2022-06-30 23:51:20 +10:00
continue ;
}
2021-12-24 12:14:01 +11:00
2022-06-30 23:51:20 +10:00
// Even if we dont have any connections, see if we have any products defined
$o = new $class ;
$o -> where ( 'supplier_detail_id' , $so -> detail -> id );
2021-12-24 12:14:01 +11:00
2022-06-30 23:51:20 +10:00
if ( $o -> count ())
$result -> put ( $class -> category ,( object )[
'type' => $class -> category_name ,
'items' => $class -> where ( 'supplier_detail_id' , $so -> detail -> id ),
]);
} else {
$result -> put ( $class -> category_name , $class );
}
2021-12-24 12:14:01 +11:00
}
return $result ;
}
2022-04-20 16:24:58 +10:00
2022-06-30 23:51:20 +10:00
/**
* Return a new model object for the offering type
*
* @ param string $type
* @ return Type
*/
public static function offeringTypeClass ( string $type ) : Type
{
return ( $class = collect ( self :: offering_types ) -> get ( $type )) ? new $class : new Generic ;
}
/**
* Return our supported offering type keys
*
* @ return Collection
*/
public static function offeringTypeKeys () : Collection
{
return collect ( self :: offering_types ) -> keys ();
}
/* RELATIONS */
// @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".
public function detail ()
{
return $this -> hasOne ( SupplierDetail :: class )
-> withoutGlobalScope ( \App\Models\Scopes\SiteScope :: class );
}
/* METHODS */
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
}