2007-10-17 14:43:34 +04:00
< ? php
/*
* This file is part of Web Instant Messenger project .
*
2008-05-06 01:12:06 +04:00
* Copyright ( c ) 2005 - 2008 Internet Services Ltd .
2007-10-17 14:43:34 +04:00
* All rights reserved . This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1 . 0
* which accompanies this distribution , and is available at
* http :// www . eclipse . org / legal / epl - v10 . html
*
* Contributors :
* Evgeny Gryaznov - initial API and implementation
*/
require ( '../libs/common.php' );
require ( '../libs/operator.php' );
require ( 'dbinfo.php' );
function runsql ( $query , $link ) {
mysql_query ( $query , $link )
or show_install_err ( ' Query failed: ' . mysql_error ());
}
$act = verifyparam ( " act " , " /^(createdb|createtables|droptables|addcolumns) $ / " );
$link = @ mysql_connect ( $mysqlhost , $mysqllogin , $mysqlpass )
or show_install_err ( 'Could not connect: ' . mysql_error ());
if ( $act == " createdb " ) {
mysql_query ( " CREATE DATABASE $mysqldb " , $link )
or show_install_err ( ' Query failed: ' . mysql_error ());
} else {
mysql_select_db ( $mysqldb , $link )
or show_install_err ( 'Could not select database' );
if ( $force_charset_in_connection ) {
mysql_query ( " SET character set $dbencoding " , $link );
}
if ( $act == " createtables " ) {
$curr_tables = get_tables ( $link );
if ( $curr_tables === false ) {
show_install_err ( $errors [ 0 ]);
}
$tocreate = array_diff ( array_keys ( $dbtables ), $curr_tables );
foreach ( $tocreate as $id ) {
create_table ( $id , $link );
}
} else if ( $act == " droptables " ) {
foreach ( array_keys ( $dbtables ) as $id ) {
mysql_query ( " DROP TABLE IF EXISTS $id " , $link )
or show_install_err ( ' Query failed: ' . mysql_error ());
}
} else if ( $act == " addcolumns " ) {
$absent = array ();
foreach ( $dbtables as $id => $columns ) {
$curr_columns = get_columns ( $id , $link );
if ( $curr_columns === false ) {
show_install_err ( $errors [ 0 ]);
}
$tocreate = array_diff ( array_keys ( $columns ), $curr_columns );
foreach ( $tocreate as $v ) {
$absent [] = " $id . $v " ;
}
}
if ( in_array ( " chatmessage.agentId " , $absent ) ) {
runsql ( " ALTER TABLE chatmessage ADD agentId int NOT NULL DEFAULT 0 AFTER ikind " , $link );
runsql ( " update chatmessage,chatoperator set agentId = operatorid where agentId = 0 AND ikind = 2 AND (vclocalename = tname OR vccommonname = tname) " , $link );
}
if ( in_array ( " chatthread.agentId " , $absent ) ) {
runsql ( " ALTER TABLE chatthread ADD agentId int NOT NULL DEFAULT 0 AFTER agentName " , $link );
runsql ( " update chatthread,chatoperator set agentId = operatorid where agentId = 0 AND (vclocalename = agentName OR vccommonname = agentName) " , $link );
}
2007-12-03 00:32:47 +03:00
2007-10-17 14:43:34 +04:00
}
}
mysql_close ( $link );
header ( " Location: " . dirname ( $_SERVER [ 'PHP_SELF' ]) . " /index.php " );
exit ;
?>