Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
0.00% covered (danger)
0.00%
0 / 21
0.00% covered (danger)
0.00%
0 / 3
CRAP
0.00% covered (danger)
0.00%
0 / 1
tao_helpers_form_elements_xhtml_Password
0.00% covered (danger)
0.00%
0 / 21
0.00% covered (danger)
0.00%
0 / 3
56
0.00% covered (danger)
0.00%
0 / 1
 feed
0.00% covered (danger)
0.00%
0 / 2
0.00% covered (danger)
0.00%
0 / 1
12
 render
0.00% covered (danger)
0.00%
0 / 15
0.00% covered (danger)
0.00%
0 / 1
12
 getEvaluatedValue
0.00% covered (danger)
0.00%
0 / 4
0.00% covered (danger)
0.00%
0 / 1
2
1<?php
2
3/**
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation; under version 2
7 * of the License (non-upgradable).
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17 *
18 * Copyright (c) 2008-2010 (original work) Deutsche Institut für Internationale Pädagogische Forschung
19 *                         (under the project TAO-TRANSFER);
20 *               2009-2012 (update and modification) Public Research Centre Henri Tudor
21 *                         (under the project TAO-SUSTAIN & TAO-DEV);
22 *
23 */
24
25use oat\tao\helpers\form\elements\xhtml\XhtmlRenderingTrait;
26
27/**
28 * Short description of class tao_helpers_form_elements_xhtml_Password
29 *
30 * @access public
31 * @author Joel Bout, <joel.bout@tudor.lu>
32 * @package tao
33 */
34class tao_helpers_form_elements_xhtml_Password extends tao_helpers_form_elements_Password
35{
36    use XhtmlRenderingTrait;
37
38    /**
39     * Short description of method feed
40     *
41     * @access public
42     * @author Joel Bout, <joel.bout@tudor.lu>
43     */
44    public function feed()
45    {
46        if (isset($_POST[$this->name]) && is_array($_POST[$this->name])) {
47            $this->setValue(array_values($_POST[$this->name]));
48        }
49    }
50
51    /**
52     * Short description of method render
53     *
54     * @access public
55     * @author Joel Bout, <joel.bout@tudor.lu>
56     * @return string
57     */
58    public function render()
59    {
60        $returnValue = (string) '';
61
62        // custom label rendering
63        if (! isset($this->attributes['noLabel'])) {
64            $returnValue .= "<label class='form_desc' for='{$this->name}'>" . _dh($this->getDescription())
65                . (strlen($this->value) == 0 ? '' : ' (change)') . "</label>";
66        } else {
67            unset($this->attributes['noLabel']);
68        }
69        $returnValue .= "<input type='password' name='{$this->name}[]' id='{$this->name}"
70            . "data-testid='{$this->getDescription()}";
71        $returnValue .= $this->renderAttributes();
72        $returnValue .= ' value=""  /><br /><br />';
73        $returnValue .= "<label class='form_desc'></label>";
74        $returnValue .= "<input type='password' name='{$this->name}[]' id='{$this->name}"
75            . "data-testid='{$this->getDescription()}";
76        $returnValue .= $this->renderAttributes();
77        $returnValue .= ' value=""  />';
78
79        return (string) $returnValue;
80    }
81
82    /**
83     * returns the md5 hash of the password
84     *
85     * @access public
86     * @author Joel Bout, <joel.bout@tudor.lu>
87     * @return mixed
88     */
89    public function getEvaluatedValue()
90    {
91        $returnValue = null;
92
93        $arr = $this->getRawValue();
94        $returnValue = core_kernel_users_Service::getPasswordHash()->encrypt(array_shift($arr));
95
96        return $returnValue;
97    }
98}