Skip to content
Snippets Groups Projects
Commit e20f18f3 authored by Marius Cramer's avatar Marius Cramer
Browse files

Added config storage method

- Use it like $app->conf('yourpluginname', 'config-key', 'value')
- omit the value to read the config value, provide it to set the value
parent 35767935
No related branches found
No related tags found
No related merge requests found
ALTER TABLE `sys_config` DROP `config_id`,
ADD PRIMARY KEY (`group`, `name`);
...@@ -1486,10 +1486,10 @@ CREATE TABLE `support_message` ( ...@@ -1486,10 +1486,10 @@ CREATE TABLE `support_message` (
-- --
CREATE TABLE `sys_config` ( CREATE TABLE `sys_config` (
`config_id` int(11) unsigned NOT NULL,
`group` varchar(64) NOT NULL, `group` varchar(64) NOT NULL,
`name` varchar(64) NOT NULL, `name` varchar(64) NOT NULL,
`value` varchar(255) NOT NULL `value` varchar(255) NOT NULL,
PRIMARY KEY (`group`, `name`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8; ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
...@@ -2280,7 +2280,7 @@ INSERT INTO `sys_user` (`userid`, `sys_userid`, `sys_groupid`, `sys_perm_user`, ...@@ -2280,7 +2280,7 @@ INSERT INTO `sys_user` (`userid`, `sys_userid`, `sys_groupid`, `sys_perm_user`,
-- Dumping data for table `sys_config` -- Dumping data for table `sys_config`
-- --
INSERT INTO sys_config VALUES ('1','db','db_version','3.0.5.3'); INSERT INTO sys_config VALUES ('db','db_version','3.0.5.3');
INSERT INTO sys_config VALUES ('2','interface','session_timeout','0'); INSERT INTO sys_config VALUES ('interface','session_timeout','0');
SET FOREIGN_KEY_CHECKS = 1; SET FOREIGN_KEY_CHECKS = 1;
...@@ -68,8 +68,8 @@ class app { ...@@ -68,8 +68,8 @@ class app {
if($this->_conf['start_session'] == true) { if($this->_conf['start_session'] == true) {
$this->uses('session'); $this->uses('session');
$tmp = $this->db->queryOneRecord("SELECT `value` FROM sys_config WHERE `config_id` = 2 AND `group` = 'interface' AND `name` = 'session_timeout'"); $sess_timeout = $this->conf('interface', 'session_timeout');
if($tmp && $tmp['value'] > 0) { if($sess_timeout) {
/* check if user wants to stay logged in */ /* check if user wants to stay logged in */
if(isset($_POST['s_mod']) && isset($_POST['s_pg']) && $_POST['s_mod'] == 'login' && $_POST['s_pg'] == 'index' && isset($_POST['stay']) && $_POST['stay'] == '1') { if(isset($_POST['s_mod']) && isset($_POST['s_pg']) && $_POST['s_mod'] == 'login' && $_POST['s_pg'] == 'index' && isset($_POST['stay']) && $_POST['stay'] == '1') {
/* check if staying logged in is allowed */ /* check if staying logged in is allowed */
...@@ -77,8 +77,8 @@ class app { ...@@ -77,8 +77,8 @@ class app {
$tmp = $this->db->queryOneRecord('SELECT config FROM sys_ini WHERE sysini_id = 1'); $tmp = $this->db->queryOneRecord('SELECT config FROM sys_ini WHERE sysini_id = 1');
$tmp = $this->ini_parser->parse_ini_string(stripslashes($tmp['config'])); $tmp = $this->ini_parser->parse_ini_string(stripslashes($tmp['config']));
if(!isset($tmp['misc']['session_allow_endless']) || $tmp['misc']['session_allow_endless'] != 'y') { if(!isset($tmp['misc']['session_allow_endless']) || $tmp['misc']['session_allow_endless'] != 'y') {
$this->session->set_timeout($tmp['value']); $this->session->set_timeout($sess_timeout);
session_set_cookie_params(($tmp['value'] * 60) + 300); // make the cookie live 5 minutes longer session_set_cookie_params(($sess_timeout * 60) + 300); // make the cookie live 5 minutes longer
} else { } else {
// we are doing login here, so we need to set the session data // we are doing login here, so we need to set the session data
$this->session->set_permanent(true); $this->session->set_permanent(true);
...@@ -86,8 +86,8 @@ class app { ...@@ -86,8 +86,8 @@ class app {
session_set_cookie_params(365 * 24 * 3600); // make the cookie live 5 minutes longer session_set_cookie_params(365 * 24 * 3600); // make the cookie live 5 minutes longer
} }
} else { } else {
$this->session->set_timeout($tmp['value']); $this->session->set_timeout($sess_timeout);
session_set_cookie_params(($tmp['value'] * 60) + 300); // make the cookie live 5 minutes longer session_set_cookie_params(($sess_timeout * 60) + 300); // make the cookie live 5 minutes longer
} }
} else { } else {
session_set_cookie_params(0); // until browser is closed session_set_cookie_params(0); // until browser is closed
...@@ -148,6 +148,22 @@ class app { ...@@ -148,6 +148,22 @@ class app {
} }
} }
} }
public function conf($plugin, $key, $value = null) {
if(is_null($value)) {
$tmpconf = $this->db->queryOneRecord("SELECT `value` FROM `sys_config` WHERE `group` = '" . $this->db->quote($plugin) . "' AND `name` = '" . $this->db->quote($key) . "'");
if($tmpconf) return $tmpconf['value'];
else return null;
} else {
if($value === false) {
$this->db->query("DELETE FROM `sys_config` WHERE `group` = '" . $this->db->quote($plugin) . "' AND `name` = '" . $this->db->quote($key) . "'");
return null;
} else {
$this->db->query("REPLACE INTO `sys_config` (`group`, `name`, `value`) VALUES ('" . $this->db->quote($plugin) . "', '" . $this->db->quote($key) . "', '" . $this->db->quote($value) . "')");
return $value;
}
}
}
/** Priority values are: 0 = DEBUG, 1 = WARNING, 2 = ERROR */ /** Priority values are: 0 = DEBUG, 1 = WARNING, 2 = ERROR */
......
...@@ -150,8 +150,7 @@ class page_action extends tform_actions { ...@@ -150,8 +150,7 @@ class page_action extends tform_actions {
} elseif($section == 'mail') { } elseif($section == 'mail') {
if($new_config['smtp_pass'] == '') $new_config['smtp_pass'] = $server_config_array['mail']['smtp_pass']; if($new_config['smtp_pass'] == '') $new_config['smtp_pass'] = $server_config_array['mail']['smtp_pass'];
} elseif($section == 'misc' && $new_config['session_timeout'] != $server_config_array['misc']['session_timeout']) { } elseif($section == 'misc' && $new_config['session_timeout'] != $server_config_array['misc']['session_timeout']) {
$app->db->query("DELETE FROM sys_config WHERE `config_id` = 2 AND `group` = 'interface' AND `name` = 'session_timeout'"); $app->conf('interface', 'session_timeout', intval($new_config['session_timeout']));
$app->db->query("INSERT INTO sys_config (`config_id`, `group`, `name`, `value`) VALUES (2, 'interface', 'session_timeout', '" . intval($new_config['session_timeout']) . "')");
} }
$server_config_array[$section] = $new_config; $server_config_array[$section] = $new_config;
$server_config_str = $app->ini_parser->get_ini_string($server_config_array); $server_config_str = $app->ini_parser->get_ini_string($server_config_array);
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment