FileUpload   A
last analyzed

Complexity

Total Complexity 5

Size/Duplication

Total Lines 53
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 2

Importance

Changes 0
Metric Value
dl 0
loc 53
rs 10
c 0
b 0
f 0
wmc 5
lcom 1
cbo 2

4 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 7 1
A setPath() 0 4 1
A _saveFile() 0 4 1
A _validates() 0 10 2
1
<?php
2
/**
3
 * KumbiaPHP web & app Framework
4
 *
5
 * LICENSE
6
 *
7
 * This source file is subject to the new BSD license that is bundled
8
 * with this package in the file LICENSE.
9
 *
10
 * @category   Kumbia
11
 * @package    Upload
12
 * @subpackage Adapters
13
 *
14
 * @copyright  Copyright (c) 2005 - 2019 KumbiaPHP Team (http://www.kumbiaphp.com)
15
 * @license    https://github.com/KumbiaPHP/KumbiaPHP/blob/master/LICENSE   New BSD License
16
 */
17
18
/**
19
 * Clase para guardar archivo subido
20
 *
21
 * @category   Kumbia
22
 * @package    Upload
23
 * @subpackage Adapters
24
 */
25
class FileUpload extends Upload
26
{
27
    /**
28
     * Constructor
29
     *
30
     * @param string $name nombre de archivo por metodo POST
31
     */
32
    public function __construct($name)
33
    {
34
        parent::__construct($name);
35
36
        // Ruta donde se guardara el archivo
37
        $this->_path = dirname($_SERVER['SCRIPT_FILENAME']) . '/files/upload';
38
    }
39
40
    /**
41
     * Asigna la ruta al directorio de destino para el archivo
42
     *
43
     * @param string $path ruta al directorio de destino (Ej: /home/usuario/data)
44
     */
45
    public function setPath($path)
46
    {
47
        $this->_path = $path;
48
    }
49
50
    /**
51
     * Guardar el archivo en el servidor
52
     *
53
     * @param string $name nombre con el que se guardarĂ¡ el archivo
54
     * @return boolean
55
     */
56
    protected function _saveFile($name)
57
    {
58
        return move_uploaded_file($_FILES[$this->_name]['tmp_name'], "$this->_path/$name");
59
    }
60
61
    /**
62
     * Valida el archivo antes de guardar
63
     *
64
     * @return boolean
65
     */
66
    protected function _validates()
67
    {
68
        // Verifica que se pueda escribir en el directorio
69
        if (!is_writable($this->_path)) {
70
            Flash::error('Error: no se puede escribir en el directorio');
71
            return FALSE;
72
        }
73
74
        return parent::_validates();
75
    }
76
77
}
78