Passed
Push — master ( 96d33b...43186b )
by Gabriel
13:27
created

IsPurchasableRepositoryTrait   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 25
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 1
Metric Value
eloc 9
c 1
b 0
f 1
dl 0
loc 25
rs 10
wmc 4

4 Methods

Rating   Name   Duplication   Size   Complexity  
A initRelations() 0 4 1
A initRelationsSessions() 0 3 1
A initRelationsPaymentMethod() 0 3 1
A initRelationsPayments() 0 5 1
1
<?php
2
3
namespace ByTIC\Payments\Models\Purchase\Traits;
4
5
6
use ByTIC\Payments\Models\AbstractModels\HasCustomer\HasCustomerRepository;
7
use ByTIC\Payments\Utility\PaymentsModels;
8
9
/**
10
 * Trait IsPurchasableRepositoryTrait
11
 * @package ByTIC\Payments\Models\Purchase\Traits
12
 */
13
trait IsPurchasableRepositoryTrait
14
{
15
    use HasCustomerRepository;
16
17
    public function initRelations()
18
    {
19
        parent::initRelations();
20
        $this->initRelationsPayments();
21
    }
22
23
    protected function initRelationsPayments()
24
    {
25
        $this->initRelationsCustomer();
26
        $this->initRelationsPaymentMethod();
27
        $this->initRelationsSessions();
28
    }
29
30
    protected function initRelationsPaymentMethod()
31
    {
32
        $this->belongsTo('PaymentMethod');
0 ignored issues
show
Bug introduced by
It seems like belongsTo() must be provided by classes using this trait. How about adding it as abstract method to this trait? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

32
        $this->/** @scrutinizer ignore-call */ 
33
               belongsTo('PaymentMethod');
Loading history...
33
    }
34
35
    protected function initRelationsSessions()
36
    {
37
        $this->hasMany('PurchasesSessions', ['class' => get_class(PaymentsModels::sessions()), 'fk' => 'id_purchase']);
0 ignored issues
show
Bug introduced by
It seems like hasMany() must be provided by classes using this trait. How about adding it as abstract method to this trait? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

37
        $this->/** @scrutinizer ignore-call */ 
38
               hasMany('PurchasesSessions', ['class' => get_class(PaymentsModels::sessions()), 'fk' => 'id_purchase']);
Loading history...
38
    }
39
}
40