Passed
Pull Request — master (#241)
by Arman
03:20
created

Result::paginate()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 1
c 0
b 0
f 0
nc 1
nop 2
dl 0
loc 3
rs 10
1
<?php
2
3
/**
4
 * Quantum PHP Framework
5
 *
6
 * An open source software development framework for PHP
7
 *
8
 * @package Quantum
9
 * @author Arman Ag. <[email protected]>
10
 * @copyright Copyright (c) 2018 Softberg LLC (https://softberg.org)
11
 * @link http://quantum.softberg.org/
12
 * @since 2.9.6
13
 */
14
15
namespace Quantum\Libraries\Database\Adapters\Idiorm\Statements;
16
17
use Quantum\Libraries\Database\Exceptions\DatabaseException;
18
use Quantum\Libraries\Database\Contracts\DbalInterface;
19
20
/**
21
 * Trait Result
22
 * @package Quantum\Libraries\Database
23
 */
24
trait Result
25
{
26
27
    /**
28
     * @inheritDoc
29
     * @throws DatabaseException
30
     */
31
    public function get(): array
32
    {
33
        return array_map(function ($element) {
34
            $item = clone $this;
35
            $item->updateOrmModel($element);
0 ignored issues
show
Bug introduced by
It seems like updateOrmModel() 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

35
            $item->/** @scrutinizer ignore-call */ 
36
                   updateOrmModel($element);
Loading history...
36
            return $item;
37
        }, $this->getOrmModel()->find_many());
0 ignored issues
show
Bug introduced by
It seems like getOrmModel() 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 */ getOrmModel()->find_many());
Loading history...
38
    }
39
40
    /**
41
     * @inheritDoc
42
     * @throws DatabaseException
43
     */
44
    public function findOne(int $id): DbalInterface
45
    {
46
        $ormObject = $this->getOrmModel()->find_one($id);
47
48
        if ($ormObject) {
49
            $this->updateOrmModel($ormObject);
50
        }
51
52
        return $this;
0 ignored issues
show
Bug Best Practice introduced by
The expression return $this returns the type Quantum\Libraries\Databa...diorm\Statements\Result which is incompatible with the type-hinted return Quantum\Libraries\Database\Contracts\DbalInterface.
Loading history...
53
    }
54
55
    /**
56
     * @inheritDoc
57
     * @throws DatabaseException
58
     */
59
    public function findOneBy(string $column, $value): DbalInterface
60
    {
61
        $ormObject = $this->getOrmModel()->where($column, $value)->find_one();
62
        if ($ormObject) {
63
            $this->updateOrmModel($ormObject);
64
        }
65
66
        return $this;
0 ignored issues
show
Bug Best Practice introduced by
The expression return $this returns the type Quantum\Libraries\Databa...diorm\Statements\Result which is incompatible with the type-hinted return Quantum\Libraries\Database\Contracts\DbalInterface.
Loading history...
67
    }
68
69
    /**
70
     * @inheritDoc
71
     * @throws DatabaseException
72
     */
73
    public function first(): DbalInterface
74
    {
75
        $ormObject = $this->getOrmModel()->find_one();
76
        if ($ormObject) {
77
            $this->updateOrmModel($ormObject);
78
        }
79
80
        return $this;
0 ignored issues
show
Bug Best Practice introduced by
The expression return $this returns the type Quantum\Libraries\Databa...diorm\Statements\Result which is incompatible with the type-hinted return Quantum\Libraries\Database\Contracts\DbalInterface.
Loading history...
81
    }
82
83
    /**
84
     * @inheritDoc
85
     * @throws DatabaseException
86
     */
87
    public function count(): int
88
    {
89
        return $this->getOrmModel()->count();
90
    }
91
92
    /**
93
     * @inheritDoc
94
     * @throws DatabaseException
95
     */
96
    public function asArray(): array
97
    {
98
        $result = $this->getOrmModel()->as_array();
99
100
        if (count($this->hidden) > 0) {
101
            $result = $this->setHidden($result);
102
        }
103
104
        return $result;
105
    }
106
107
    /**
108
     * @param $result
109
     * @return array
110
     */
111
    public function setHidden($result): array
112
    {
113
        return array_diff_key($result, array_flip($this->hidden));
114
    }
115
}