Completed
Branch master (a0b8e2)
by Konstantin
02:08
created

SettlementsDatabaseQuery::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
c 0
b 0
f 0
dl 0
loc 4
rs 10
cc 1
eloc 2
nc 1
nop 0
1
<?php
2
3
namespace GeoFixer\models\queries;
4
5
/**
6
 * Class SettlementsDatabaseQuery
7
 *
8
 * @package GeoFixer\models\queries
9
 */
10
class SettlementsDatabaseQuery extends AbstractDatabaseQuery
11
{
12
    /**
13
     * SettlementsDatabaseQuery constructor.
14
     */
15
    public function __construct()
16
    {
17
        parent::__construct();
18
    }
19
20
    /**
21
     * Получаем города и поселения
22
     *
23
     * @return $this
24
     */
25
    public function getSettlements()
26
    {
27
        $this->db = $this->db->select(['address_id', 'title', 'code'])->from('fias_address_object');
28
29
        return $this;
30
    }
31
32
    /**
33
     * Address level равен городу или поселению
34
     *
35
     * @param bool $full_settlements
36
     *
37
     * @return $this
38
     */
39
    public function addressLevel($full_settlements = false)
40
    {
41
        if ($full_settlements == false) {
0 ignored issues
show
Coding Style Best Practice introduced by
It seems like you are loosely comparing two booleans. Considering using the strict comparison === instead.

When comparing two booleans, it is generally considered safer to use the strict comparison operator.

Loading history...
42
            $this->db = $this->db->andWhere(['address_level' => self::CITY]);
43
        } else {
44
            $this->db = $this->db->andWhere(['OR' => [['address_level' => self::CITY], ['address_level' => self::SETTLEMENT]]]);
45
        }
46
47
        return $this;
48
    }
49
}