_a['table'] = 'idf_conf'; $this->_a['model'] = __CLASS__; $this->_a['cols'] = array( // It is mandatory to have an "id" column. 'id' => array( 'type' => 'Pluf_DB_Field_Sequence', //It is automatically added. 'blank' => true, ), 'project' => array( 'type' => 'Pluf_DB_Field_Foreignkey', 'model' => 'IDF_Project', 'blank' => false, 'verbose' => __('project'), ), 'vkey' => array( 'type' => 'Pluf_DB_Field_Varchar', 'blank' => false, 'size' => 50, 'verbose' => __('key'), ), 'vdesc' => array( 'type' => 'Pluf_DB_Field_Varchar', 'blank' => false, 'size' => 250, 'verbose' => __('value'), ), ); $this->_a['idx'] = array('project_vkey_idx' => array( 'col' => 'project, vkey', 'type' => 'unique', ), ); $this->f = new IDF_Conf_DataProxy($this); } function setProject($project) { $this->datacache = null; $this->_project = $project; } function initCache() { $this->datacache = new ArrayObject(); $sql = new Pluf_SQL('project=%s', $this->_project); foreach ($this->getList(array('filter' => $sql->gen())) as $val) { $this->datacache[$val->vkey] = $val->vdesc; } } /** * FIXME: This is not efficient when setting a large number of * values in a loop. */ function setVal($key, $value) { if (!is_null($this->getVal($key, null)) and $value == $this->getVal($key)) { return; } $this->delVal($key, false); $conf = new IDF_Conf(); $conf->project = $this->_project; $conf->vkey = $key; $conf->vdesc = $value; $conf->create(); $this->initCache(); } function getVal($key, $default='') { if ($this->datacache === null) { $this->initCache(); } return (isset($this->datacache[$key])) ? $this->datacache[$key] : $default; } function delVal($key, $initcache=true) { $gconf = new IDF_Conf(); $sql = new Pluf_SQL('vkey=%s AND project=%s', array($key, $this->_project)); foreach ($gconf->getList(array('filter' => $sql->gen())) as $c) { $c->delete(); } if ($initcache) { $this->initCache(); } } }