mirror of
https://github.com/Mibew/java.git
synced 2025-01-26 03:20:34 +03:00
80 lines
2.6 KiB
PHP
80 lines
2.6 KiB
PHP
|
<?php
|
||
|
/*
|
||
|
* This file is part of Web Instant Messenger project.
|
||
|
*
|
||
|
* Copyright (c) 2005-2007 Internet Services Ltd.
|
||
|
* 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);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
mysql_close($link);
|
||
|
header("Location: ".dirname($_SERVER['PHP_SELF'])."/index.php");
|
||
|
exit;
|
||
|
?>
|