egroupware/setup/config.php

153 lines
5.1 KiB
PHP
Raw Normal View History

2001-07-30 17:59:25 +02:00
<?php
/**************************************************************************\
* phpGroupWare - Setup *
* http://www.phpgroupware.org *
* -------------------------------------------- *
* This program is free software; you can redistribute it and/or modify it *
* under the terms of the GNU General Public License as published by the *
* Free Software Foundation; either version 2 of the License, or (at your *
* option) any later version. *
\**************************************************************************/
/* $Id$ */
$phpgw_info['flags'] = array(
'noheader' => True,
'nonavbar' => True,
2001-09-12 18:49:41 +02:00
'currentapp' => 'home',
2001-07-30 17:59:25 +02:00
'noapi' => True
);
include('./inc/functions.inc.php');
include('../header.inc.php');
$tpl_root = $phpgw_setup->setup_tpl_dir('setup');
$setup_tpl = CreateObject('phpgwapi.Template',$tpl_root);
$setup_tpl->set_file(array(
'T_head' => 'head.tpl',
'T_footer' => 'footer.tpl',
'T_alert_msg' => 'msg_alert_msg.tpl',
'T_config_pre_script' => 'config_pre_script.tpl',
'T_config_post_script' => 'config_post_script.tpl'
));
/*
Authorize the user to use setup app and load the database
Does not return unless user is authorized
*/
if (!$phpgw_setup->auth('Config'))
{
Header('Location: index.php');
exit;
}
$phpgw_setup->loaddb();
/* Guessing default paths. */
2001-09-12 18:49:41 +02:00
$GLOBALS['current_config']['files_dir'] = ereg_replace('/setup','/files',dirname($SCRIPT_FILENAME));
2001-07-30 17:59:25 +02:00
if (is_dir('/tmp'))
{
2001-09-12 18:49:41 +02:00
$GLOBALS['current_config']['temp_dir'] = '/tmp';
2001-07-30 17:59:25 +02:00
}
else
{
2001-09-12 18:49:41 +02:00
$GLOBALS['current_config']['temp_dir'] = '/path/to/temp/dir';
2001-07-30 17:59:25 +02:00
}
if ($HTTP_POST_VARS['cancel'])
2001-07-30 17:59:25 +02:00
{
Header('Location: index.php');
exit;
}
/* Check api version, use correct table */
$setup_info = $phpgw_setup->get_db_versions();
if($phpgw_setup->alessthanb($setup_info['phpgwapi']['currentver'], '0.9.10pre7'))
{
$configtbl = 'config';
}
else
{
$configtbl = 'phpgw_config';
}
if ($HTTP_POST_VARS['submit'] && $HTTP_POST_VARS['newsettings'])
2001-07-30 17:59:25 +02:00
{
$phpgw_setup->db->transaction_begin();
/* This is only temp: */
$phpgw_setup->db->query("DELETE FROM $configtbl WHERE config_name='useframes'");
$phpgw_setup->db->query("INSERT INTO $configtbl (config_app,config_name, config_value) values ('phpgwapi','useframes','never')");
$newsettings = $HTTP_POST_VARS['newsettings'];
2001-07-30 17:59:25 +02:00
while (list($setting,$value) = @each($newsettings))
{
// echo '<br>Updating: ' . $setting . '=' . $value;
@$phpgw_setup->db->query("DELETE FROM $configtbl WHERE config_name='" . $setting . "'");
if($value)
{
$phpgw_setup->db->query("INSERT INTO $configtbl (config_app,config_name, config_value) VALUES ('phpgwapi','" . $phpgw_setup->db->db_addslashes($setting)
. "','" . $phpgw_setup->db->db_addslashes($value) . "')");
2001-07-30 17:59:25 +02:00
}
}
$phpgw_setup->db->transaction_commit();
/* Add cleaning of app_sessions per skeeter, but with a check for the table being there, just in case */
$tablenames = $phpgw_setup->db->table_names();
while(list($key,$val) = @each($tablenames))
{
$tables[] = $val['table_name'];
}
if ($phpgw_setup->isinarray('phpgw_app_sessions',$tables))
{
$phpgw_setup->db->lock(array('phpgw_app_sessions'));
@$phpgw_setup->db->query("DELETE FROM phpgw_app_sessions WHERE sessionid = '0' and loginid = '0' and app = 'phpgwapi' and location = 'config'",__LINE__,__FILE__);
@$phpgw_setup->db->query("DELETE FROM phpgw_app_sessions WHERE app = 'phpgwapi' and location = 'phpgw_info_cache'",__LINE__,__FILE__);
$phpgw_setup->db->unlock();
}
if ($newsettings['auth_type'] == 'ldap')
{
Header('Location: '.$newsettings['webserver_url'].'/setup/ldap.php');
exit;
}
else
{
Header('Location: index.php');
exit;
}
}
if ($newsettings['auth_type'] != 'ldap')
{
$phpgw_setup->show_header(lang('Configuration'),False,'config',$ConfigDomain . '(' . $phpgw_domain[$ConfigDomain]["db_type"] . ')');
}
@$phpgw_setup->db->query("SELECT * FROM $configtbl");
while (@$phpgw_setup->db->next_record())
{
2001-09-12 18:49:41 +02:00
$GLOBALS['current_config'][$phpgw_setup->db->f('config_name')] = $phpgw_setup->db->f('config_value');
2001-07-30 17:59:25 +02:00
}
2001-09-12 18:49:41 +02:00
if ($GLOBALS['current_config']['files_dir'] == '/path/to/dir/phpgroupware/files')
2001-07-30 17:59:25 +02:00
{
2001-09-12 18:49:41 +02:00
$GLOBALS['current_config']['files_dir'] = $phpgw_info['server']['server_root'] . '/files';
2001-07-30 17:59:25 +02:00
}
if ($error == 'badldapconnection')
{
/* Please check the number and dial again :) */
$phpgw_setup->show_alert_msg('Error',
lang('There was a problem trying to connect to your LDAP server. <br>'
.'please check your LDAP server configuration') . '.');
}
$setup_tpl->pparse('out','T_config_pre_script');
$phpgw_setup->execute_script('config',array('phpgwapi','admin','preferences')); /* ;,'preferences','email','nntp')); */
$setup_tpl->set_var('more_configs',lang('Please login to phpgroupware and run the admin application for additional site configuration') . '.');
$setup_tpl->set_var('lang_submit',lang('submit'));
$setup_tpl->set_var('lang_cancel',lang('cancel'));
$setup_tpl->pparse('out','T_config_post_script');
$phpgw_setup->show_footer();
?>