Пример #1
0
if (!isset($_GET["server"])) {
    echo "*******************************************\n";
    echo " This script kill babies : don't use it !! \n";
    echo "*******************************************\n";
    die("\nUsage : php -q -f rollbackocs.php --server=# [ --run=1 ]\n");
}
$DBocs = new DBocs($_GET["server"]);
echo "Connecting to " . $DBocs->dbhost . "\n";
if (!PluginOcsinventoryngOcsServer::checkOCSconnection($_GET["server"])) {
    die("Failed connexion to OCS\n");
}
$run = isset($_GET["run"]) && $_GET["run"] > 0;
$debug = isset($_GET["debug"]) && $_GET["debug"] > 0;
// Find Last Machine ID + time
$sql = "SELECT *\n        FROM `hardware`\n        ORDER BY `ID` DESC\n        LIMIT 0,1";
$res = $DBocs->query($sql);
if (!($res && $DBocs->numrows($res) > 0)) {
    die("No data from OCS\n");
}
$data = $DBocs->fetch_array($res);
$maxid = $data["ID"];
$maxti = $data["LASTCOME"];
echo "Last new computer : " . $data["DEVICEID"] . " ({$maxid}, {$maxti})\n";
if (!$maxid) {
    die("Bad value\n");
}
// Computer from OCS : New, ID Changed, Linked
$sql = "SELECT *\n        FROM `glpi_logs`\n        WHERE `date_mod` >= '{$maxti}'\n              AND `itemtype` = 1\n              AND `linked_action` IN (8,10,11)\n        ORDER BY `id` DESC";
$res = $DB->query($sql);
if (!$res) {
    die("No data from GLPI\n");
Пример #2
0
function update068to0681()
{
    global $DB, $LANG, $CFG_GLPI;
    if (TableExists("glpi_repair_item")) {
        $query = "DROP TABLE `glpi_repair_item`;";
        $DB->query($query) or die("0.68.1 drop glpi_repair_item " . $LANG['update'][90] . $DB->error());
    }
    $tables = array("computers", "monitors", "networking", "peripherals", "phones", "printers");
    foreach ($tables as $tbl) {
        if (isIndex("glpi_" . $tbl, "type")) {
            $query = "ALTER TABLE `glpi_{$tbl}` DROP INDEX `type`;";
            $DB->query($query) or die("0.68.1 drop index type glpi_{$tbl} " . $LANG['update'][90] . $DB->error());
        }
        if (isIndex("glpi_" . $tbl, "type_2")) {
            $query = "ALTER TABLE `glpi_{$tbl}` DROP INDEX `type_2`;";
            $DB->query($query) or die("0.68.1 drop index type_2 glpi_{$tbl} " . $LANG['update'][90] . $DB->error());
        }
        if (isIndex("glpi_" . $tbl, "model")) {
            $query = "ALTER TABLE `glpi_{$tbl}` DROP INDEX `model`;";
            $DB->query($query) or die("0.68.1 drop index model glpi_{$tbl} " . $LANG['update'][90] . $DB->error());
        }
        if (!isIndex("glpi_" . $tbl, "type")) {
            $query = "ALTER TABLE `glpi_{$tbl}` ADD INDEX ( `type` )";
            $DB->query($query) or die("0.68.1 add index type glpi_{$tbl} " . $LANG['update'][90] . $DB->error());
        }
        if (!isIndex("glpi_" . $tbl, "model")) {
            $query = "ALTER TABLE `glpi_{$tbl}` ADD INDEX ( `model` )";
            $DB->query($query) or die("0.68.1 add index model glpi_{$tbl} " . $LANG['update'][90] . $DB->error());
        }
        if (!isIndex("glpi_" . $tbl, "FK_groups")) {
            $query = "ALTER TABLE `glpi_{$tbl}` ADD INDEX ( `FK_groups` )";
            $DB->query($query) or die("0.68.1 add index on glpi_{$tbl}.FK_groups " . $LANG['update'][90] . $DB->error());
        }
        if (!isIndex("glpi_" . $tbl, "FK_users")) {
            $query = "ALTER TABLE `glpi_{$tbl}` ADD INDEX ( `FK_users` )";
            $DB->query($query) or die("0.68.1 add index on glpi_{$tbl}.FK_users " . $LANG['update'][90] . $DB->error());
        }
    }
    if (!isIndex("glpi_software", "FK_groups")) {
        $query = "ALTER TABLE `glpi_software` ADD INDEX ( `FK_groups` )";
        $DB->query($query) or die("0.68.1 add index on glpi_software.FK_groups " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_software", "FK_users")) {
        $query = "ALTER TABLE `glpi_software` ADD INDEX ( `FK_users` )";
        $DB->query($query) or die("0.68.1 add index on glpi_software.FK_users " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_cartridges_type", "location")) {
        $query = "ALTER TABLE `glpi_cartridges_type` ADD INDEX ( `location` )";
        $DB->query($query) or die("0.68.1 add index on glpi_cartridges_type.location " . $LANG['update'][90] . $DB->error());
    }
    if (FieldExists("glpi_cartridges_type", "type")) {
        $query = "ALTER TABLE `glpi_cartridges_type` CHANGE `type` `type` INT NOT NULL DEFAULT '0'";
        $DB->query($query) or die("0.68.1 alter glpi_cartridges_type.type " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_cartridges_type", "type")) {
        $query = "ALTER TABLE `glpi_cartridges_type` ADD INDEX ( type )";
        $DB->query($query) or die("0.68.1 add index on glpi_cartridges_type.type " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_cartridges_type", "alarm")) {
        $query = "ALTER TABLE `glpi_cartridges_type` ADD INDEX ( alarm )";
        $DB->query($query) or die("0.68.1 add index on glpi_cartridges_type.alarm " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_computers", "os_sp")) {
        $query = "ALTER TABLE `glpi_computers` ADD INDEX ( `os_sp` )";
        $DB->query($query) or die("0.68.1 add index on glpi_computers.os_sp " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_computers", "os_version")) {
        $query = "ALTER TABLE `glpi_computers` ADD INDEX ( `os_version` )";
        $DB->query($query) or die("0.68.1 add index on glpi_computers.os_version " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_computers", "network")) {
        $query = "ALTER TABLE `glpi_computers` ADD INDEX ( `network` )";
        $DB->query($query) or die("0.68.1 add index on glpi_computers.network " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_computers", "domain")) {
        $query = "ALTER TABLE `glpi_computers` ADD INDEX ( `domain` )";
        $DB->query($query) or die("0.68.1 add index on glpi_computers.domain " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_computers", "auto_update")) {
        $query = "ALTER TABLE `glpi_computers` ADD INDEX ( `auto_update` )";
        $DB->query($query) or die("0.68.1 add index on glpi_computers.auto_update " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_computers", "ocs_import")) {
        $query = "ALTER TABLE `glpi_computers` ADD INDEX ( `ocs_import` )";
        $DB->query($query) or die("0.68.1 add index on glpi_computers.ocs_import " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_consumables", "id_user")) {
        $query = "ALTER TABLE `glpi_consumables` ADD INDEX ( `id_user` )";
        $DB->query($query) or die("0.68.1 add index on glpi_consumables.id_user " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_consumables_type", "location")) {
        $query = "ALTER TABLE `glpi_consumables_type` ADD INDEX ( `location` )";
        $DB->query($query) or die("0.68.1 add index on glpi_consumables_type.location " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_consumables_type", "type")) {
        $query = "ALTER TABLE `glpi_consumables_type` ADD INDEX ( `type` )";
        $DB->query($query) or die("0.68.1 add index on glpi_consumables_type.type " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_consumables_type", "alarm")) {
        $query = "ALTER TABLE `glpi_consumables_type` ADD INDEX ( `alarm` )";
        $DB->query($query) or die("0.68.1 add index on glpi_consumables_type.alarm " . $LANG['update'][90] . $DB->error());
    }
    if (FieldExists("glpi_contacts", "type")) {
        $query = "ALTER TABLE `glpi_contacts` CHANGE `type` `type` INT( 11 ) NULL ";
        $DB->query($query) or die("0.68.1 alter glpi_contacts.type " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_contract_device", "device_type")) {
        $query = "ALTER TABLE `glpi_contract_device` ADD INDEX ( `device_type` )";
        $DB->query($query) or die("0.68.1 add index on glpi_contract_device.device_type " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_contract_device", "is_template")) {
        $query = "ALTER TABLE `glpi_contract_device` ADD INDEX ( `is_template` )";
        $DB->query($query) or die("0.68.1 add index on glpi_contract_device.is_template " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_device_hdd", "interface")) {
        $query = "ALTER TABLE `glpi_device_hdd` ADD INDEX ( `interface` )";
        $DB->query($query) or die("0.68.1 add index on glpi_device_hdd.interface " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_device_ram", "type")) {
        $query = "ALTER TABLE `glpi_device_ram` ADD INDEX ( `type` )";
        $DB->query($query) or die("0.68.1 add index on glpi_device_ram.type " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_display", "FK_users")) {
        $query = "ALTER TABLE `glpi_display` ADD INDEX ( `FK_users` )";
        $DB->query($query) or die("0.68.1 add index on glpi_display.FK_users " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_docs", "FK_users")) {
        $query = "ALTER TABLE `glpi_docs` ADD INDEX ( `FK_users` )";
        $DB->query($query) or die("0.68.1 add index on glpi_docs.FK_users " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_docs", "FK_tracking")) {
        $query = "ALTER TABLE `glpi_docs` ADD INDEX ( `FK_tracking` )";
        $DB->query($query) or die("0.68.1 add index on glpi_docs.FK_tracking " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_doc_device", "device_type")) {
        $query = "ALTER TABLE `glpi_doc_device` ADD INDEX ( `device_type` )";
        $DB->query($query) or die("0.68.1 add index on glpi_doc_device.device_type " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_dropdown_tracking_category", "parentID")) {
        $query = "ALTER TABLE `glpi_dropdown_tracking_category` ADD INDEX ( `parentID` )";
        $DB->query($query) or die("0.68.1 add index on glpi_dropdown_tracking_category.parentID " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_history", "device_type")) {
        $query = "ALTER TABLE `glpi_history` ADD INDEX ( `device_type` )";
        $DB->query($query) or die("0.68.1 add index on glpi_history.device_type " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_history", "device_internal_type")) {
        $query = "ALTER TABLE `glpi_history` ADD INDEX ( `device_internal_type` )";
        $DB->query($query) or die("0.68.1 add index on glpi_history.device_internal_type " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_infocoms", "budget")) {
        $query = "ALTER TABLE `glpi_infocoms` ADD INDEX ( `budget` )";
        $DB->query($query) or die("0.68.1 add index on glpi_infocoms.budget " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_infocoms", "alert")) {
        $query = "ALTER TABLE `glpi_infocoms` ADD INDEX ( `alert` )";
        $DB->query($query) or die("0.68.1 add index on glpi_infocoms.alert " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_kbitems", "author")) {
        $query = "ALTER TABLE `glpi_kbitems` ADD INDEX ( `author` )";
        $DB->query($query) or die("0.68.1 add index on glpi_kbitems.author " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_kbitems", "faq")) {
        $query = "ALTER TABLE `glpi_kbitems` ADD INDEX ( `faq` )";
        $DB->query($query) or die("0.68.1 add index on glpi_kbitems.faq " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_licenses", "oem_computer")) {
        $query = "ALTER TABLE `glpi_licenses` ADD INDEX ( `oem_computer` )";
        $DB->query($query) or die("0.68.1 add index on glpi_licenses.oem_computer " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_licenses", "oem")) {
        $query = "ALTER TABLE `glpi_licenses` ADD INDEX ( `oem` )";
        $DB->query($query) or die("0.68.1 add index on glpi_licenses.oem " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_licenses", "buy")) {
        $query = "ALTER TABLE `glpi_licenses` ADD INDEX ( `buy` )";
        $DB->query($query) or die("0.68.1 add index on glpi_licenses.buy " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_licenses", "serial")) {
        $query = "ALTER TABLE `glpi_licenses` ADD INDEX ( `serial` )";
        $DB->query($query) or die("0.68.1 add index on glpi_licenses.serial " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_licenses", "expire")) {
        $query = "ALTER TABLE `glpi_licenses` ADD INDEX ( `expire` )";
        $DB->query($query) or die("0.68.1 add index on glpi_licenses.expire " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_networking", "network")) {
        $query = "ALTER TABLE `glpi_networking` ADD INDEX ( `network` )";
        $DB->query($query) or die("0.68.1 add index on glpi_networking.network " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_networking", "domain")) {
        $query = "ALTER TABLE `glpi_networking` ADD INDEX ( `domain` )";
        $DB->query($query) or die("0.68.1 add index on glpi_networking.domain " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_networking_ports", "iface")) {
        $query = "ALTER TABLE `glpi_networking_ports` ADD INDEX ( `iface` )";
        $DB->query($query) or die("0.68.1 add index on glpi_networking_ports.iface " . $LANG['update'][90] . $DB->error());
    }
    if (FieldExists("glpi_phones", "power")) {
        $query = "ALTER TABLE `glpi_phones` CHANGE `power` `power` INT NOT NULL DEFAULT '0'";
        $DB->query($query) or die("0.68.1 alter glpi_phones.power " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_phones", "power")) {
        $query = "ALTER TABLE `glpi_phones` ADD INDEX ( `power` )";
        $DB->query($query) or die("0.68.1 add index on glpi_phones.power " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_reminder", "begin")) {
        $query = "ALTER TABLE `glpi_reminder` ADD INDEX ( `begin` )";
        $DB->query($query) or die("0.68.1 add index on glpi_reminder.begin " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_reminder", "end")) {
        $query = "ALTER TABLE `glpi_reminder` ADD INDEX ( `end` )";
        $DB->query($query) or die("0.68.1 add index on glpi_reminder.end " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_software", "update_software")) {
        $query = "ALTER TABLE `glpi_software` ADD INDEX ( `update_software` )";
        $DB->query($query) or die("0.68.1 add index on glpi_software.update_software " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_state_item", "state")) {
        $query = "ALTER TABLE `glpi_state_item` ADD INDEX ( `state` )";
        $DB->query($query) or die("0.68.1 add index on glpi_state_item.state " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_tracking", "FK_group")) {
        $query = "ALTER TABLE `glpi_tracking` ADD INDEX ( `FK_group` )";
        $DB->query($query) or die("0.68.1 add index on glpi_tracking.FK_group " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_tracking", "assign_ent")) {
        $query = "ALTER TABLE `glpi_tracking` ADD INDEX ( `assign_ent` )";
        $DB->query($query) or die("0.68.1 add index on glpi_tracking.assign_ent " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_tracking", "device_type")) {
        $query = "ALTER TABLE `glpi_tracking` ADD INDEX ( `device_type` )";
        $DB->query($query) or die("0.68.1 add index on glpi_tracking.device_type " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_tracking", "priority")) {
        $query = "ALTER TABLE `glpi_tracking` ADD INDEX ( `priority` )";
        $DB->query($query) or die("0.68.1 add index on glpi_tracking.priority " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_tracking", "request_type")) {
        $query = "ALTER TABLE `glpi_tracking` ADD INDEX ( `request_type` )";
        $DB->query($query) or die("0.68.1 add index on glpi_tracking.request_type " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_users", "location")) {
        $query = "ALTER TABLE `glpi_users` ADD INDEX ( `location` )";
        $DB->query($query) or die("0.68.1 add index on glpi_users.location " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_printers", "network")) {
        $query = "ALTER TABLE `glpi_printers` ADD INDEX ( `network` )";
        $DB->query($query) or die("0.68.1 add index on glpi_printers.network " . $LANG['update'][90] . $DB->error());
    }
    if (!isIndex("glpi_printers", "domain")) {
        $query = "ALTER TABLE `glpi_printers` ADD INDEX ( `domain` )";
        $DB->query($query) or die("0.68.1 add index on glpi_printers.domain " . $LANG['update'][90] . $DB->error());
    }
    if (FieldExists("glpi_device_case", "format")) {
        $query = "ALTER TABLE `glpi_device_case` CHANGE `format` `format` ENUM( 'Grand', 'Moyen', 'Micro', 'Slim', '' ) NULL DEFAULT 'Moyen'";
        $DB->query($query) or die("0.68.1 alter glpi_device_case.format " . $LANG['update'][90] . $DB->error());
    }
    if (FieldExists("glpi_device_gfxcard", "interface")) {
        $query = "ALTER TABLE `glpi_device_gfxcard` CHANGE `interface` `interface` ENUM( 'AGP', 'PCI', 'PCI-X', 'Other', '' ) NULL DEFAULT 'AGP'";
        $DB->query($query) or die("0.68.1 alter glpi_device_gfxcard.interface " . $LANG['update'][90] . $DB->error());
    }
    // Add default values in GLPI_DROPDOWN_HDD_TYPE
    // Rename glpi_dropdown HDD_TYPE -> INTERFACE
    if (!TableExists("glpi_dropdown_interface")) {
        $query = "ALTER TABLE `glpi_dropdown_hdd_type` RENAME `glpi_dropdown_interface` ";
        $DB->query($query) or die("0.68.1 alter dropdown_hdd_type -> dropdown_interface " . $LANG['update'][90] . $DB->error());
        $values = array("SATA", "IDE", "SCSI", "USB");
        $interfaces = array();
        foreach ($values as $val) {
            $query = "SELECT * FROM glpi_dropdown_interface WHERE name LIKE '{$val}';";
            $result = $DB->query($query);
            if ($DB->numrows($result) == 1) {
                $row = $DB->fetch_array($result);
                $interfaces[$val] = $row["ID"];
            } else {
                $query = "INSERT INTO glpi_dropdown_interface (`name`) VALUES ('{$val}');";
                $DB->query($query);
                $interfaces[$val] = $DB->insert_id();
            }
        }
        // ALTER TABLES
        $query = "ALTER TABLE `glpi_device_control` CHANGE `interface` `interface2` ENUM( 'IDE', 'SATA', 'SCSI', 'USB' ) NOT NULL DEFAULT 'IDE'";
        $DB->query($query) or die("0.68.1 alter device_control " . $LANG['update'][90] . $DB->error());
        $query = "ALTER TABLE `glpi_device_drive` CHANGE `interface` `interface2` ENUM( 'IDE', 'SATA', 'SCSI' )  NOT NULL DEFAULT 'IDE'";
        $DB->query($query) or die("0.68.1 alter device_drive " . $LANG['update'][90] . $DB->error());
        $query = "ALTER TABLE `glpi_device_control` ADD `interface` INT NULL ";
        $DB->query($query) or die("0.68.1 alter device_control " . $LANG['update'][90] . $DB->error());
        $query = "ALTER TABLE `glpi_device_drive` ADD `interface` INT NULL ";
        $DB->query($query) or die("0.68.1 alter device_drive " . $LANG['update'][90] . $DB->error());
        foreach ($interfaces as $name => $ID) {
            $query = "UPDATE glpi_device_drive SET interface='{$ID}' WHERE interface2='{$name}';";
            $DB->query($query) or die("0.68.1 update data device_drive " . $LANG['update'][90] . $DB->error());
            $query = "UPDATE glpi_device_control SET interface='{$ID}' WHERE interface2='{$name}';";
            $DB->query($query) or die("0.68.1 update data device_control " . $LANG['update'][90] . $DB->error());
        }
        // DROP TABLES
        $query = "ALTER TABLE `glpi_device_control` DROP `interface2`;";
        $DB->query($query) or die("0.68.1 drop interface2 device_drive " . $LANG['update'][90] . $DB->error());
        $query = "ALTER TABLE `glpi_device_drive` DROP `interface2`;";
        $DB->query($query) or die("0.68.1 drop interface2 device_drive " . $LANG['update'][90] . $DB->error());
        // ADD INDEX
        $query = "ALTER TABLE `glpi_device_drive` ADD INDEX ( `interface` )";
        $DB->query($query) or die("0.68.1 add index on glpi_device_drive.interface " . $LANG['update'][90] . $DB->error());
        $query = "ALTER TABLE `glpi_device_control` ADD INDEX ( `interface` )";
        $DB->query($query) or die("0.68.1 add index on glpi_device_drive.interface " . $LANG['update'][90] . $DB->error());
    }
    if (FieldExists("glpi_profiles", "update")) {
        $query = "ALTER TABLE `glpi_profiles` CHANGE `update` `check_update` CHAR( 1 ) NULL DEFAULT NULL";
        $DB->query($query) or die("0.68.1 alter glpi_profiles.update " . $LANG['update'][90] . $DB->error());
    }
    if (FieldExists("glpi_config", "last_update_check")) {
        $query = "ALTER TABLE `glpi_config` DROP `last_update_check`;";
        $DB->query($query) or die("0.68.1 drop glpi_config.last_update_check " . $LANG['update'][90] . $DB->error());
    }
    if (!FieldExists("glpi_config", "keep_tracking_on_delete")) {
        $query = "ALTER TABLE `glpi_config` ADD `keep_tracking_on_delete` INT DEFAULT '1'";
        $DB->query($query) or die("0.68.1 drop glpi_config.keep_tracking_on_delete " . $LANG['update'][90] . $DB->error());
    }
    if (!FieldExists("glpi_config", "show_admin_doc")) {
        $query = "ALTER TABLE `glpi_config` ADD `show_admin_doc` INT DEFAULT '0' ";
        $DB->query($query) or die("0.68.1 drop glpi_config.show_admin_doc " . $LANG['update'][90] . $DB->error());
    }
    if (!FieldExists("glpi_config", "time_step")) {
        $query = "ALTER TABLE `glpi_config` ADD `time_step` INT DEFAULT '5' ";
        $DB->query($query) or die("0.68.1 drop glpi_config.time_step " . $LANG['update'][90] . $DB->error());
    }
    $query = "UPDATE glpi_config SET time_step='5', show_admin_doc='0', keep_tracking_on_delete='0';";
    $DB->query($query) or die("0.68.1 update glpi_config data " . $LANG['update'][90] . $DB->error());
    if (!FieldExists("glpi_ocs_config", "cron_sync_number")) {
        $query = "ALTER TABLE `glpi_ocs_config` ADD `cron_sync_number` INT DEFAULT '1' ";
        $DB->query($query) or die("0.68.1 drop glpi_ocs_config.cron_sync_number " . $LANG['update'][90] . $DB->error());
    }
    if (!FieldExists("glpi_profiles", "show_group_ticket")) {
        $query = "ALTER TABLE `glpi_profiles` ADD `show_group_ticket` char(1) DEFAULT '0' ";
        $DB->query($query) or die("0.68.1 drop glpi_profiles.show_group_ticket " . $LANG['update'][90] . $DB->error());
    }
    if (!FieldExists("glpi_config", "ldap_group_condition")) {
        $query = "ALTER TABLE `glpi_config` ADD `ldap_group_condition` VARCHAR( 255 ) NULL ,\n\t\t\tADD `ldap_search_for_groups` TINYINT NOT NULL DEFAULT '0',\n\t\t\tADD `ldap_field_group_member` VARCHAR( 255 ) NULL ";
        $DB->query($query) or die("0.68.1 add glpi_config.ldap_*_groups " . $LANG['update'][90] . $DB->error());
    }
    if (!FieldExists("glpi_groups", "ldap_group_dn")) {
        $query = "ALTER TABLE `glpi_groups` ADD `ldap_group_dn` VARCHAR( 255 ) NULL ";
        $DB->query($query) or die("0.68.1 add glpi_groups.ldap_group_dn " . $LANG['update'][90] . $DB->error());
    }
    if (!FieldExists("glpi_ocs_link", "ocs_deviceid")) {
        $query = "ALTER TABLE `glpi_ocs_link` CHANGE `ocs_id` `ocs_deviceid` VARCHAR( 255 ) NOT NULL ;";
        $DB->query($query) or die("0.68.1 add glpi_ocs_link.ocs_deviceid " . $LANG['update'][90] . $DB->error());
    }
    if (!FieldExists("glpi_ocs_link", "ocs_id")) {
        $query = "ALTER TABLE `glpi_ocs_link` ADD `ocs_id` INT NOT NULL DEFAULT '0' AFTER `glpi_id` ;";
        $DB->query($query) or die("0.68.1 add glpi_ocs_link.ocs_id " . $LANG['update'][90] . $DB->error());
    }
    if (!FieldExists("glpi_ocs_link", "last_ocs_update")) {
        $query = "ALTER TABLE `glpi_ocs_link` ADD `last_ocs_update` DATETIME NULL AFTER `last_update` ;";
        $DB->query($query) or die("0.68.1 add glpi_ocs_link.last_ocs_update " . $LANG['update'][90] . $DB->error());
    }
    if (countElementsInTable("glpi_ocs_link")) {
        include_once GLPI_ROOT . "/inc/commondbtm.class.php";
        include_once GLPI_ROOT . "/inc/ocsng.function.php";
        include_once GLPI_ROOT . "/inc/ocsng.class.php";
        $CFG_GLPI["ocs_mode"] = 1;
        $DBocs = new DBocs(1);
        // Get datas to update
        $query = "SELECT * \n\t\t\tFROM glpi_ocs_link";
        $result_glpi = $DB->query($query);
        while ($data_glpi = $DB->fetch_array($result_glpi)) {
            // Get ocs informations
            $query_ocs = "SELECT * \n\t\t\t\tFROM hardware WHERE DEVICEID='" . $data_glpi["ocs_deviceid"] . "' \n\t\t\t\tLIMIT 1;";
            $result_ocs = $DBocs->query($query_ocs) or die("0.68.1 get ocs infos " . $LANG['update'][90] . $DB->error());
            if ($result_ocs && $DBocs->numrows($result_ocs)) {
                $data_ocs = $DBocs->fetch_array($result_ocs);
                $query_update = "UPDATE glpi_ocs_link\n\t\t\t\t\tSET ocs_id='" . $data_ocs["ID"] . "', \n\t\t\t\t\t    last_ocs_update='" . $data_ocs["LASTDATE"] . "'\n\t\t\t\t\t\t    WHERE ID='" . $data_glpi["ID"] . "';";
                $DB->query($query_update) or die("0.68.1 update ocs infos " . $LANG['update'][90] . $DB->error());
            }
        }
    }
    if (!TableExists("glpi_dropdown_case_type")) {
        $query = "CREATE TABLE `glpi_dropdown_case_type` (\n\t\t\t`ID` int(11) NOT NULL auto_increment,\n\t\t\t`name` varchar(255) NOT NULL,\n\t\t\t`comments` text,\n\t\t\tPRIMARY KEY  (`ID`),\n\t\t\tKEY `name` (`name`)\n\t\t\t\t) ENGINE=MyISAM ;";
        $DB->query($query) or die("0.68.1 add table dropdown_case_type " . $LANG['update'][90] . $DB->error());
        // ajout du champs type
        $query = "ALTER TABLE `glpi_device_case` ADD  `type` INT( 11 ) default NULL AFTER `designation` ;";
        $DB->query($query) or die("0.68.1 add glpi_device_case.type " . $LANG['update'][90] . $DB->error());
        // Ajout des entrees dans la table dropdown_case_type
        $query = "INSERT INTO `glpi_dropdown_case_type` ( `ID` , `name` , `comments` ) VALUES ('1' , 'Grand', NULL);";
        $DB->query($query) or die("0.68.1 glpi_device_case " . $LANG['update'][90] . $DB->error());
        $query = "INSERT INTO `glpi_dropdown_case_type` ( `ID` , `name` , `comments` ) VALUES ('2' , 'Moyen', NULL);";
        $DB->query($query) or die("0.68.1 glpi_device_case " . $LANG['update'][90] . $DB->error());
        $query = "INSERT INTO `glpi_dropdown_case_type` ( `ID` , `name` , `comments` ) VALUES ('3' , 'Micro', NULL);";
        $DB->query($query) or die("0.68.1 glpi_device_case " . $LANG['update'][90] . $DB->error());
        // Mapping format enum / type
        $query = "UPDATE `glpi_device_case` SET  `type`='1' WHERE `format`='Grand';";
        $DB->query($query) or die("0.68.1 glpi_device_case " . $LANG['update'][90] . $DB->error());
        $query = "UPDATE `glpi_device_case` SET  `type`='2' WHERE `format`='Moyen';";
        $DB->query($query) or die("0.68.1 glpi_device_case " . $LANG['update'][90] . $DB->error());
        $query = "UPDATE `glpi_device_case` SET  `type`='3' WHERE `format`='Micro';";
        $DB->query($query) or die("0.68.1 glpi_device_case " . $LANG['update'][90] . $DB->error());
        // Supression du champts format
        $query = "ALTER TABLE `glpi_device_case` DROP `format`;";
        $DB->query($query) or die("0.68.1 drop format from glpi_device_case " . $LANG['update'][90] . $DB->error());
    }
    // Clean state datas
    if (TableExists("glpi_state_item")) {
        $query = "SELECT COUNT(*) AS CPT, device_type, id_device \n\t\t\tFROM glpi_state_item\n\t\t\tGROUP BY device_type, id_device\n\t\t\tHAVING CPT > 1";
        $result = $DB->query($query);
        if ($DB->numrows($result)) {
            while ($data = $DB->fetch_array($result)) {
                $query2 = "DELETE FROM glpi_state_item\n\t\t\t\t\t\t\t\tWHERE device_type='" . $data["device_type"] . "'\n\t\t\t\t\t\t\t\tAND id_device='" . $data["id_device"] . "'\n\t\t\t\t\t\t\t\tLIMIT " . ($data["CPT"] - 1) . ";";
                $DB->query($query2) or die("0.68.1 clean glpi_state_item " . $LANG['update'][90] . $DB->error());
            }
        }
        if (isIndex("glpi_state_item", "device_type")) {
            $query = " ALTER TABLE `glpi_state_item` DROP INDEX `device_type` ;";
            $DB->query($query) or die("0.68.1 drop index glpi_state_item " . $LANG['update'][90] . $DB->error());
        }
        if (isIndex("glpi_state_item", "device_type2")) {
            $query = " ALTER TABLE `glpi_state_item` DROP INDEX `device_type2` ;";
            $DB->query($query) or die("0.68.1 drop index glpi_state_item " . $LANG['update'][90] . $DB->error());
        }
        $query = " ALTER TABLE `glpi_state_item` ADD INDEX ( `device_type` ) ";
        $DB->query($query) or die("0.68.1 add index glpi_state_item " . $LANG['update'][90] . $DB->error());
        $query = " ALTER TABLE `glpi_state_item` ADD UNIQUE ( `device_type`,`id_device` ) ";
        $DB->query($query) or die("0.68.1 add unique glpi_state_item " . $LANG['update'][90] . $DB->error());
    }
}
function glpiuImportPrinters($mode, $start = 0)
{
    global $PRINTERSLIST, $UC_OCSIDS, $UC_NAMES, $CFG_GLPI, $LANG;
    $DBocs = new DBocs($_SESSION["ocsservers_id"]);
    $DB = new DB();
    $noPort = 0;
    $numrows = 0;
    $UC_OCSIDS = array();
    // Correspondance UC ocs/glpi
    // Recherche les ports
    $query_ports = "select distinct hardware.NAME as UC_Name, hardware.DEVICEID, printers.NAME, printers.PORT, printers.DRIVER from printers " . "inner join hardware on hardware.ID = printers.HARDWARE_ID  where  printers.DRIVER <> '' order by hardware.DEVICEID, printers.NAME, printers.PORT, printers.DRIVER";
    $result_ports = $DBocs->query($query_ports) or die($DBocs->error());
    if ($DBocs->numrows($result_ports) > 0) {
        // Récupère les UC dans GLPI
        $query_UC = "select distinct glpi_id, ocs_id from glpi_ocs_link order by glpi_id";
        $result_UC = $DB->query($query_UC) or die($DB->error());
        if ($DB->numrows($result_UC) > 0) {
            while ($data = $DB->fetch_array($result_UC)) {
                $UC_OCSIDS[$data["ocs_id"]] = array('glpi_id' => $data["glpi_id"], 'UC_Name' => '', 'driver' => '');
            }
        }
        unset($result_UC);
        // Recherche les UC liés à une imprimante dans OCS
        $query_UC = "select distinct hardware.NAME as UC_Name, hardware.ID as ocs_id from hardware " . "inner join printers on printers.HARDWARE_ID = hardware.ID order by hardware.DEVICEID, hardware.NAME";
        $result_UC = $DBocs->query($query_UC) or die($DBocs->error());
        if ($DBocs->numrows($result_UC) > 0) {
            while ($data = $DBocs->fetch_array($result_UC)) {
                if (array_key_exists($data["ocs_id"], $UC_OCSIDS)) {
                    $UC_OCSIDS[$data["ocs_id"]]['UC_Name'] = strtoupper($data["UC_Name"]);
                }
            }
        }
        unset($result_UC);
        // Suppression des UC sans imprimante
        // création d'une table des UC avec nom pour clé
        foreach ($UC_OCSIDS as $ocs_id => &$item) {
            if ($item['UC_Name'] === '') {
                unset($UC_OCSIDS[$ocs_id]);
            } else {
                $UC_NAMES[$item['UC_Name']] = array('glpi_id' => $item["glpi_id"], 'ocs_id' => $ocs_id);
            }
        }
        unset($UC_OCSIDS);
        // Création des imprimantes
        while ($data = $DBocs->fetch_array($result_ports)) {
            glpiuInsertPrinter($data["PORT"], $data["NAME"], $data["UC_Name"], $data["DRIVER"]);
        }
        unset($result_ports);
        unset($UC_NAMES);
        // Si en mode action, suppression des imprimantes
        /*if ($mode == 1 && count($PRINTERSLIST) > 0)
        		{
        		processObjects(PRINTER_TYPE, DELETE_ACTION);
        		}*/
        // Récupère les imprimantes dans GLPI
        $printer_names = array();
        if (count($PRINTERSLIST) > 0) {
            $query_PRN = "select distinct ID, name from glpi_printers where deleted='0' ";
            $result_PRN = $DB->query($query_PRN) or die($DB->error());
            if ($DB->numrows($result_PRN) > 0) {
                while ($data = $DB->fetch_array($result_PRN)) {
                    $printer_names[$data["name"]] = $data["ID"];
                }
            }
        }
        // Complétion des imprimantes et suppression de celles à ne pas importer
        $numrows = 0;
        foreach ($PRINTERSLIST as $prn_no => &$printer) {
            if ($printer->portType <= PORT_TYPE_USB) {
                $printer->getName();
                if ($printer->server != '' && !isset($printer_names[$printer->name])) {
                    $numrows++;
                } else {
                    unset($PRINTERSLIST[$prn_no]);
                }
            } else {
                unset($PRINTERSLIST[$prn_no]);
            }
        }
        unset($printer_names);
        // Importation
        if ($mode == 1 && isset($_POST['toimport'])) {
            foreach ($_POST['toimport'] as $prn_no => $val) {
                if ($val == "on") {
                    $PRINTERSLIST[$prn_no]->addToDB();
                    unset($PRINTERSLIST[$prn_no]);
                    $numrows--;
                }
            }
        }
        unset($_POST['toimport']);
        // Affichage
        echo "<div align='center'>";
        if ($numrows) {
            $readOnly = !haveRight("ocsng", "w");
            $parameters = "objectType=" . PRINTER_TYPE . "&amp;actionId=" . IMPORT_PRINTERS_ACTION;
            printPager($start, $numrows, $_SERVER["PHP_SELF"], $parameters);
            // delete end
            array_splice($PRINTERSLIST, $start + $_SESSION["glpilist_limit"]);
            // delete begin
            if ($start > 0) {
                array_splice($PRINTERSLIST, 0, $start);
            }
            echo "<form method='post' name='printer_form' id='printer_form' action='" . $_SERVER["PHP_SELF"] . "'>";
            echo "<a href='" . $_SERVER["PHP_SELF"] . "' onclick= \"if ( markAllRows('printer_form') ) return false;\">" . $LANG["buttons"][18] . "</a>&nbsp;/&nbsp;<a href='" . $_SERVER["PHP_SELF"] . "' onclick= \"if ( unMarkAllRows('printer_form') ) return false;\">" . $LANG["buttons"][19] . "</a>";
            echo "<input type='hidden' name='objectType' value='" . PRINTER_TYPE . "'>";
            echo "<input type='hidden' name='actionId' value='" . IMPORT_PRINTERS_ACTION . "'>";
            echo "<table class='tab_cadre'>";
            if (!$readOnly) {
                echo "<tr class='tab_bg_1'><th colspan=8><input class='submit' type='submit' name='do_action' value='" . $LANG["buttons"][37] . "'></th></tr>" . chr(10);
            }
            echo '<tr><th></th><th>Type</th><th>IP</th><th>Nom</th><th width="150px">Port</th><th>Serveurs</th><th>Files d\'impression</th><th>Erreurs</th></tr>' . chr(10);
            foreach ($PRINTERSLIST as &$printer) {
                $printer->display();
            }
            if (!$readOnly) {
                echo "<tr class='tab_bg_1'><th colspan=8><input  class='submit' type='submit' name='do_action' value='" . $LANG["buttons"][37] . "'></th></tr>" . chr(10);
            }
            echo "</table>";
            //echo '<br>'.$numrows.'<br>';
            echo "</form>";
            printPager($start, $numrows, $_SERVER["PHP_SELF"], $parameters);
        } else {
            echo "<strong>" . $LANG["ocsng"][9] . "<br>";
            echo "<a href='../index.php'>" . $LANG["buttons"][13] . "</a></strong>";
        }
        echo "</div>";
    }
    return $numrows;
}