OracleBlueprint   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 68
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 1

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
dl 0
loc 68
ccs 13
cts 13
cp 1
rs 10
c 0
b 0
f 0
wmc 4
lcom 1
cbo 1

3 Methods

Rating   Name   Duplication   Size   Complexity  
A setTablePrefix() 0 4 1
A createIndexName() 0 15 2
A nvarchar2() 0 4 1
1
<?php
2
3
namespace Yajra\Oci8\Schema;
4
5
use Illuminate\Database\Schema\Blueprint;
6
7
class OracleBlueprint extends Blueprint
8
{
9
    /**
10
     * Table comment.
11
     *
12
     * @var string
13
     */
14
    public $comment = null;
15
16
    /**
17
     * Column comments
18
     *
19
     * @var array
20
     */
21
    public $commentColumns = [];
22
23
    /**
24
     * Database prefix variable.
25
     *
26
     * @var string
27
     */
28
    protected $prefix;
29
30
    /**
31
     * Set table prefix settings.
32
     *
33
     * @param string $prefix
34
     */
35 24
    public function setTablePrefix($prefix = '')
36
    {
37 24
        $this->prefix = $prefix;
38 24
    }
39
40
    /**
41
     * Create a default index name for the table.
42
     *
43
     * @param  string $type
44
     * @param  array $columns
45
     * @return string
46
     */
47 66
    protected function createIndexName($type, array $columns)
48
    {
49
        $short_type = [
50 66
            'primary' => 'pk',
51 66
            'foreign' => 'fk',
52 66
            'unique'  => 'uk',
53 66
        ];
54
55 66
        $type = isset($short_type[$type]) ? $short_type[$type] : $type;
56
57 66
        $index = strtolower($this->prefix . $this->table . '_' . implode('_', $columns) . '_' . $type);
58
59
        // max index name length is 30 chars
60 66
        return substr(str_replace(['-', '.'], '_', $index), 0, 30);
61
    }
62
63
    /**
64
     * Create a new nvarchar2 column on the table.
65
     *
66
     * @param string $column
67
     * @param int $length
68
     * @return \Illuminate\Support\Fluent
69
     */
70 3
    public function nvarchar2($column, $length = 255)
71
    {
72 3
        return $this->addColumn('nvarchar2', $column, compact('length'));
73
    }
74
}
75