Passed
Push — master ( f8bf80...f2cf88 )
by Jonas
01:49
created

BuildsParamLimitFixQueries   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 36
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 11
c 1
b 0
f 0
dl 0
loc 36
ccs 7
cts 7
cp 1
rs 10
wmc 5

1 Method

Rating   Name   Duplication   Size   Complexity  
A eagerLoadRelations() 0 13 5
1
<?php
2
3
namespace Staudenmeir\EloquentParamLimitFix\Traits;
4
5
use Illuminate\Database\MySqlConnection;
6
use Illuminate\Database\SQLiteConnection;
7
use Illuminate\Database\SqlServerConnection;
8
9
trait BuildsParamLimitFixQueries
10
{
11
    /**
12
     * The maximum number of parameters per query.
13
     *
14
     * The values are lower than the actual limits
15
     * to have a margin for polymorphic relationships
16
     * and other query parameters.
17
     *
18
     * @var array
19
     */
20
    protected $parameterLimits = [
21
        MySqlConnection::class => 65000,
22
        SQLiteConnection::class => 900,
23
        SqlServerConnection::class => 2000,
24
    ];
25
26
    /**
27
     * Eager load the relationships for the models.
28
     *
29
     * @param array $models
30
     * @return array
31
     */
32 1
    public function eagerLoadRelations(array $models)
33
    {
34 1
        foreach ($this->parameterLimits as $class => $limit) {
35 1
            if ($this->query->getConnection() instanceof $class && count($models) > $limit) {
36 1
                foreach (array_chunk($models, $limit) as $chunk) {
37 1
                    $this->eagerLoadRelations($chunk);
38
                }
39
40 1
                return $models;
41
            }
42
        }
43
44 1
        return parent::eagerLoadRelations($models);
45
    }
46
}
47