Passed
Pull Request — master (#40)
by Wilmer
14:30
created

MysqlTableSchema   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 29
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 5
dl 0
loc 29
rs 10
c 1
b 0
f 0
wmc 3

3 Methods

Rating   Name   Duplication   Size   Complexity  
A getForeignKeys() 0 3 1
A foreignKeys() 0 3 1
A foreignKey() 0 3 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Db\Mysql\Schema;
6
7
use Yiisoft\Db\Schema\TableSchema;
8
9
final class MysqlTableSchema extends TableSchema
10
{
11
    private array $foreignKeys = [];
12
13
    /**
14
     * @return array foreign keys of this table. Each array element is of the following structure:
15
     *
16
     * ```php
17
     * [
18
     *  'ForeignTableName',
19
     *  'fk1' => 'pk1',  // pk1 is in foreign table
20
     *  'fk2' => 'pk2',  // if composite foreign key
21
     * ]
22
     * ```
23
     */
24
    public function getForeignKeys(): array
25
    {
26
        return $this->foreignKeys;
27
    }
28
29
30
    public function foreignKey(string $id, array $to): void
31
    {
32
        $this->foreignKeys[$id] = $to;
33
    }
34
35
    public function foreignKeys(array $value): void
36
    {
37
        $this->foreignKeys = $value;
38
    }
39
}
40