Passed
Push — master ( e18e45...a1f222 )
by Emmanuel
03:09
created

PostgreSQL   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 40
Duplicated Lines 0 %

Test Coverage

Coverage 66.67%

Importance

Changes 0
Metric Value
wmc 4
eloc 11
dl 0
loc 40
c 0
b 0
f 0
ccs 8
cts 12
cp 0.6667
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A getEnclosureForCSV() 0 3 1
A loadData() 0 20 3
1
<?php
2
/**
3
 * neuralyzer : Data Anonymization Library and CLI Tool
4
 *
5
 * PHP Version 7.1
6
 *
7
 * @author Emmanuel Dyan
8
 * @copyright 2018 Emmanuel Dyan
9
 *
10
 * @package edyan/neuralyzer
11
 *
12
 * @license GNU General Public License v2.0
13
 *
14
 * @link https://github.com/edyan/neuralyzer
15
 */
16
17
namespace Edyan\Neuralyzer\Helper\DB;
18
19
/**
20
 * Various methods related to PostgreSQL
21
 */
22
class PostgreSQL extends AbstractDBHelper
23
{
24
    /**
25
     * Set the right enclosure
26
     * @return string
27
     */
28 1
    public function getEnclosureForCSV(): string
29
    {
30 1
        return chr(0);
31
    }
32
33
34
    /**
35
     * Load Data from a CSV
36
     * @param  string  $table
37
     * @param  string  $filename
38
     * @param  array   $fields
39
     * @param  string  $mode  Not in used here
40
     * @return string
41
     */
42 1
    public function loadData(
43
        string $table,
44
        string $filename,
45
        array $fields,
46
        string $mode
47
    ): string {
48 1
        $fields = implode(', ', $fields);
49
50 1
        if ($this->pretend === false) {
51
            if ($mode === 'update') {
52
                $this->conn->query("TRUNCATE {$table}");
53
            }
54
            $pdo = $this->conn->getWrappedConnection();
55
            $pdo->pgsqlCopyFromFile($table, $filename, '|', '\\\\N', $fields);
56
        }
57
58 1
        $sql = "COPY {$table} ($fields) FROM '{$filename}' ";
59 1
        $sql.= '... Managed by pgsqlCopyFromFile';
60
61 1
        return $sql;
62
    }
63
}
64