Proyectos de Subversion Moodle

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 1
<?php
2
// This file is part of Moodle - http://moodle.org/
3
//
4
// Moodle is free software: you can redistribute it and/or modify
5
// it under the terms of the GNU General Public License as published by
6
// the Free Software Foundation, either version 3 of the License, or
7
// (at your option) any later version.
8
//
9
// Moodle 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 Moodle.  If not, see <http://www.gnu.org/licenses/>.
16
 
17
/**
18
 * Configurable Reports
19
 * A Moodle block for creating customizable reports
20
 * @package blocks
21
 * @author: Juan leyva <http://www.twitter.com/jleyvadelgado>
22
 * @date: 2009
23
 */
24
 
25
class component_permissions extends component_base {
26
 
27
    public function init() {
28
        $this->plugins = true;
29
        $this->ordering = false;
30
        $this->form = true;
31
        $this->help = true;
32
    }
33
 
34
    public function form_process_data(&$cform) {
35
        global $DB;
36
 
37
        if ($this->form) {
38
            $data = $cform->get_data();
39
            // Function cr_serialize() will add slashes.
40
 
41
            $components = cr_unserialize($this->config->components);
42
            $components['permissions']['config'] = $data;
43
            if (isset($components['permissions']['config']->conditionexpr)) {
44
                $components['permissions']['config']->conditionexpr = $this->add_missing_conditions($components['permissions']['config']->conditionexpr);
45
            }
46
            $this->config->components = cr_serialize($components);
47
            $DB->update_record('block_configurable_reports', $this->config);
48
        }
49
    }
50
 
51
    public function add_missing_conditions($cond) {
52
        $components = cr_unserialize($this->config->components);
53
        if (isset($components['permissions']['elements'])) {
54
            $elements = $components['permissions']['elements'];
55
            $count = count($elements);
56
            if ($count == 0 || $count == 1) {
57
                return '';
58
            }
59
            for ($i = $count; $i > 0; $i--) {
60
                if (strpos($cond, 'c'.$i) === false) {
61
                    if ($count > 1 && $cond) {
62
                        $cond .= " and c$i";
63
                    } else {
64
                        $cond .= "c$i";
65
                    }
66
                }
67
            }
68
            $cond = trim($cond);
69
 
70
            // Deleting extra conditions.
71
            for ($i = $count + 1; $i <= $count + 5; $i++) {
72
                $cond = preg_replace('/(\bc'.$i.'\b\s+\b(and|or|not)\b\s*)/i', '', $cond);
73
                $cond = preg_replace('/(\s+\b(and|or|not)\b\s+\bc'.$i.'\b)/i', '', $cond);
74
            }
75
        }
76
        return $cond;
77
 
78
    }
79
 
80
    public function form_set_data(&$cform) {
81
        global $DB;
82
 
83
        if ($this->form) {
84
            $fdata = new stdclass;
85
            $components = cr_unserialize($this->config->components);
86
            $conditionsconfig = (isset($components['permissions']['config'])) ? $components['permissions']['config'] : new \stdclass;
87
 
88
            if (!isset($conditionsconfig->conditionexpr)) {
89
                $fdata->conditionexpr = '';
90
                $conditionsconfig->conditionexpr = '';
91
            }
92
            $conditionsconfig->conditionexpr = $this->add_missing_conditions($conditionsconfig->conditionexpr);
93
            $fdata->conditionexpr = $conditionsconfig->conditionexpr;
94
 
95
            if (empty($components['permissions'])) {
96
                $components['permissions'] = array();
97
            }
98
 
99
            if (!array_key_exists('config', $components['permissions'])) {
100
                $components['permissions']['config'] = new StdClass;
101
            }
102
 
103
            $components['permissions']['config']->conditionexpr = $fdata->conditionexpr;
104
            $this->config->components = cr_serialize($components);
105
            $DB->update_record('block_configurable_reports', $this->config);
106
 
107
            $cform->set_data($fdata);
108
        }
109
    }
110
}