<?php /**************************************************************************\ * eGroupWare - Setup * * http://www.egroupware.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$ // updates from the stable 1.0.0 branch $test[] = '1.0.0.001'; function phpgwapi_upgrade1_0_0_001() { $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.0.004'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.0.002'; function phpgwapi_upgrade1_0_0_002() { // identical to 1.0.0.001, only created to get a new version of the packages return phpgwapi_upgrade1_0_0_001(); } $test[] = '1.0.0.003'; function phpgwapi_upgrade1_0_0_003() { // identical to 1.0.0.001, only created to get a new version of the final 1.0 packages return phpgwapi_upgrade1_0_0_001(); } $test[] = '1.0.0.004'; function phpgwapi_upgrade1_0_0_004() { $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_async','id','async_id'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_async','next','async_next'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_async','times','async_times'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_async','method','async_method'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_async','data','async_data'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_async','account_id','async_account_id'); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.001'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.0.005'; function phpgwapi_upgrade1_0_0_005() { // identical to 1.0.0.001, only created to get a new version of the bugfix release return phpgwapi_upgrade1_0_0_004(); } $test[] = '1.0.0.006'; function phpgwapi_upgrade1_0_0_006() { // identical to 1.0.0.001, only created to get a new version of the bugfix release return phpgwapi_upgrade1_0_0_004(); } $test[] = '1.0.0.007'; function phpgwapi_upgrade1_0_0_007() { // identical to 1.0.0.001, only created to get a new version of the bugfix release return phpgwapi_upgrade1_0_0_004(); } $test[] = '1.0.0.008'; function phpgwapi_upgrade1_0_0_008() { // identical to 1.0.0.001, only created to get a new version of the bugfix release return phpgwapi_upgrade1_0_0_004(); } $test[] = '1.0.0.009'; function phpgwapi_upgrade1_0_0_009() { // identical to 1.0.0.001, only created to get a new version of the bugfix release return phpgwapi_upgrade1_0_0_004(); } $test[] = '1.0.1.001'; function phpgwapi_upgrade1_0_1_001() { // removing the ACL entries of deleted accounts $GLOBALS['egw_setup']->setup_account_object(); if ($GLOBALS['egw']->accounts->table) { $GLOBALS['egw']->accounts->table = $GLOBALS['egw_setup']->accounts_table; } if (($all_accounts = $GLOBALS['egw']->accounts->search(array('type'=>'both')))) { foreach($all_accounts as $key => $value) { // the latest version of the egw api(>1.2.001) is returning negative groupids // but in the currently updated version of the acl table, the groupids are yet positive $allaccounts[] = abs($key); } $GLOBALS['egw_setup']->oProc->query("DELETE FROM phpgw_acl WHERE acl_account NOT IN (".implode(',',$allaccounts).")",__LINE__,__FILE__); $GLOBALS['egw_setup']->oProc->query("DELETE FROM phpgw_acl WHERE acl_appname='phpgw_group' AND acl_location NOT IN ('".implode("','",$allaccounts)."')",__LINE__,__FILE__); } $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.002'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.002'; function phpgwapi_upgrade1_0_1_002() { $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','file_id','vfs_file_id'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','owner_id','vfs_owner_id'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','createdby_id','vfs_createdby_id'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','modifiedby_id','vfs_modifiedby_id'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','created','vfs_created'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','modified','vfs_modified'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','size','vfs_size'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','mime_type','vfs_mime_type'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','deleteable','vfs_deleteable'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','comment','vfs_comment'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','app','vfs_app'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','directory','vfs_directory'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','name','vfs_name'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','link_directory','vfs_link_directory'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','link_name','vfs_link_name'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','version','vfs_version'); $GLOBALS['egw_setup']->oProc->RenameColumn('phpgw_vfs','content','vfs_content'); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_vfs','egw_vfs'); $GLOBALS['egw_setup']->oProc->RefreshTable('egw_vfs',array( 'fd' => array( 'vfs_file_id' => array('type' => 'auto','nullable' => False), 'vfs_owner_id' => array('type' => 'int','precision' => '4','nullable' => False), 'vfs_createdby_id' => array('type' => 'int','precision' => '4'), 'vfs_modifiedby_id' => array('type' => 'int','precision' => '4'), 'vfs_created' => array('type' => 'date','nullable' => False,'default' => '1970-01-01'), 'vfs_modified' => array('type' => 'date'), 'vfs_size' => array('type' => 'int','precision' => '4'), 'vfs_mime_type' => array('type' => 'varchar','precision' => '64'), 'vfs_deleteable' => array('type' => 'char','precision' => '1','default' => 'Y'), 'vfs_comment' => array('type' => 'varchar','precision' => '255'), 'vfs_app' => array('type' => 'varchar','precision' => '25'), 'vfs_directory' => array('type' => 'varchar','precision' => '255'), 'vfs_name' => array('type' => 'varchar','precision' => '128','nullable' => False), 'vfs_link_directory' => array('type' => 'varchar','precision' => '255'), 'vfs_link_name' => array('type' => 'varchar','precision' => '128'), 'vfs_version' => array('type' => 'varchar','precision' => '30','nullable' => False,'default' => '0.0.0.0'), 'vfs_content' => array('type' => 'text') ), 'pk' => array('vfs_file_id'), 'fk' => array(), 'ix' => array(array('vfs_directory','vfs_name','vfs_mime_type')), 'uc' => array() )); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.003'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.003'; function phpgwapi_upgrade1_0_1_003() { $GLOBALS['egw_setup']->oProc->CreateTable( 'egw_api_content_history', array( 'fd' => array( 'sync_appname' => array('type' => 'varchar','precision' => '60','nullable' => False), 'sync_contentid' => array('type' => 'varchar','precision' => '60','nullable' => False), 'sync_added' => array('type' => 'timestamp', 'nullable' => False), 'sync_modified' => array('type' => 'timestamp', 'nullable' => False), 'sync_deleted' => array('type' => 'timestamp', 'nullable' => False), 'sync_id' => array('type' => 'auto','nullable' => False), 'sync_guid' => array('type' => 'varchar','precision' => '120','nullable' => False), 'sync_changedby' => array('type' => 'int','precision' => '4','nullable' => False), ), 'pk' => array('sync_id'), 'fk' => array(), 'ix' => array(array('sync_appname','sync_contentid'),'sync_added','sync_modified','sync_deleted','sync_guid','sync_changedby'), 'uc' => array() ) ); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.004'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.004'; function phpgwapi_upgrade1_0_1_004() { $GLOBALS['egw_setup']->oProc->AlterColumn('egw_api_content_history','sync_added',array( 'type' => 'timestamp' )); $GLOBALS['egw_setup']->oProc->AlterColumn('egw_api_content_history','sync_modified',array( 'type' => 'timestamp' )); $GLOBALS['egw_setup']->oProc->AlterColumn('egw_api_content_history','sync_deleted',array( 'type' => 'timestamp' )); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.005'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.005'; function phpgwapi_upgrade1_0_1_005() { /*********************************************************************\ * VFS version 2 * \*********************************************************************/ $GLOBALS['egw_setup']->oProc->CreateTable( 'phpgw_vfs2_mimetypes', array( 'fd' => array( 'mime_id' => array('type' => 'auto','nullable' => False), 'extension' => array('type' => 'varchar', 'precision' => 10, 'nullable' => false), 'mime' => array('type' => 'varchar', 'precision' => 50, 'nullable' => false), 'mime_magic' => array('type' => 'varchar', 'precision' => 255, 'nullable' => true), 'friendly' => array('type' => 'varchar', 'precision' => 50, 'nullable' => false), 'image' => array('type' => 'blob'), 'proper_id' => array('type' => 'varchar', 'precision' => 4) ), 'pk' => array('mime_id'), 'fk' => array(), 'ix' => array(), 'uc' => array() ) ); $GLOBALS['egw_setup']->oProc->CreateTable( 'phpgw_vfs2_files' , array( 'fd' => array( 'file_id' => array('type' => 'auto','nullable' => False), 'mime_id' => array('type' => 'int','precision' => 4), 'owner_id' => array('type' => 'int','precision' => 4,'nullable' => False), 'createdby_id' => array('type' => 'int','precision' => 4), 'created' => array('type' => 'timestamp','default' => '1970-01-01 00:00:00', 'nullable' => False), 'size' => array('type' => 'int','precision' => 8), 'deleteable' => array('type' => 'char','precision' => 1,'default' => 'Y'), 'comment' => array('type' => 'varchar','precision' => 255), 'app' => array('type' => 'varchar','precision' => 25), 'directory' => array('type' => 'varchar','precision' => 255), 'name' => array('type' => 'varchar','precision' => 128,'nullable' => False), 'link_directory' => array('type' => 'varchar','precision' => 255), 'link_name' => array('type' => 'varchar','precision' => 128), 'version' => array('type' => 'varchar','precision' => 30,'nullable' => False,'default' => '0.0.0.0'), 'content' => array('type' => 'longtext'), 'is_backup' => array('type' => 'varchar', 'precision' => 1, 'nullable' => False, 'default' => 'N'), 'shared' => array('type' => 'varchar', 'precision' => 1, 'nullable' => False,'default' => 'N'), 'proper_id' => array('type' => 'varchar', 'precision' => 45) ), 'pk' => array('file_id'), 'fk' => array('mime_id' => array ('phpgw_vfs2_mimetypes' => 'mime_id')), 'ix' => array(array('directory','name')), 'uc' => array() ) ); $GLOBALS['egw_setup']->oProc->CreateTable( 'phpgw_vfs2_customfields' , array( 'fd' => array( 'customfield_id' => array('type' => 'auto','nullable' => False), 'customfield_name' => array('type' => 'varchar','precision' => 60,'nullable' => False), 'customfield_description' => array('type' => 'varchar','precision' => 255,'nullable'=> True), 'customfield_type' => array('type' => 'varchar','precision' => 20, 'nullable' => false), 'customfield_precision' => array('type' => 'int', 'precision' => 4, 'nullable' => true), 'customfield_active' => array('type' => 'varchar','precision' => 1,'nullable' => False,'default' => 'N') ), 'pk' => array('customfield_id'), 'fk' => array(), 'ix' => array(), 'uc' => array() ) ); $GLOBALS['egw_setup']->oProc->CreateTable( 'phpgw_vfs2_quota' , array( 'fd' => array( 'account_id' => array('type' => 'int','precision' => 4,'nullable' => false), 'quota' => array('type' => 'int','precision' => 4,'nullable' => false) ), 'pk' => array('account_id'), 'fk' => array('account_id' => array('phpgw_accounts' => 'account_id')), 'ix' => array(), 'uc' => array() ) ); $GLOBALS['egw_setup']->oProc->CreateTable( 'phpgw_vfs2_shares' , array( 'fd' => array( 'account_id' => array('type' => 'int','precision' => 4,'nullable' => false), 'file_id' => array('type' => 'int','precision' => 4,'nullable' => false), 'acl_rights' => array('type' => 'int','precision' => 4,'nullable' => false) ), 'pk' => array('account_id','file_id'), 'fk' => array('account_id' => array('phpgw_accounts' => 'account_id'), 'file_id' => array('phpgw_vfs2_files' => 'file_id')), 'ix' => array(), 'uc' => array() ) ); $GLOBALS['egw_setup']->oProc->CreateTable( 'phpgw_vfs2_versioning' , array( 'fd' => array( 'version_id' => array('type' => 'auto', 'nullable' => false), 'file_id' => array('type' => 'int','precision' => 4,'nullable' => false), 'operation' => array('type' => 'int','precision' => 4, 'nullable' => False), 'modifiedby_id' => array('type' => 'int','precision' => 4,'nullable' => false), 'modified' => array('type' => 'timestamp', 'nullable' => False ), 'version' => array('type' => 'varchar', 'precision' => 30, 'nullable' => False ), 'comment' => array('type' => 'varchar', 'precision' => 255, 'nullable' => True), 'backup_file_id' => array('type' => 'int','precision' => 4, 'nullable' => True), 'backup_content' => array('type' => 'longtext', 'nullable' => True), 'src' => array('type' => 'varchar', 'precision' => 255, 'nullable' => True), 'dest' => array('type' => 'varchar', 'precision' => 255, 'nullable' => True) ), 'pk' => array('version_id'), 'fk' => array('file_id' => array('phpgw_vfs2_files' => 'file_id')), 'ix' => array(), 'uc' => array() ) ); $GLOBALS['egw_setup']->oProc->CreateTable( 'phpgw_vfs2_customfields_data' , array( 'fd' => array( 'file_id' => array('type' => 'int','precision' => 4,'nullable' => false), 'customfield_id' => array('type' => 'int', 'precision' => 4, 'nullable' => false), 'data' => array('type' => 'longtext', 'nullable' => True) ), 'pk' => array('file_id','customfield_id'), 'fk' => array('file_id' => array('phpgw_vfs2_files' => 'file_id'),'customfield_id' => array('phpgw_vfs2_customfields' => 'customfield_id')), 'ix' => array(), 'uc' => array() ) ); $GLOBALS['egw_setup']->oProc->CreateTable( 'phpgw_vfs2_prefixes' , array( 'fd' => array( 'prefix_id' => array('type' => 'auto','nullable' => false), 'prefix' => array('type' => 'varchar', 'precision' => 8, 'nullable' => false), 'owner_id' => array('type' => 'int', 'precision' => 4, 'nullable' => false), 'prefix_description' => array('type' => 'varchar', 'precision' => 30, 'nullable' => True), 'prefix_type' => array('type' => 'varchar', 'precision' => 1, 'nullable' => false, 'default' => 'p') ), 'pk' => array('prefix_id'), 'fk' => array(), 'ix' => array(), 'uc' => array() ) ); /*************************************************************************\ * Default Records for VFS v2 * \*************************************************************************/ if ($GLOBALS['DEBUG']) { echo "<br>\n<b>initiating to create the default records for VFS SQL2..."; } include PHPGW_INCLUDE_ROOT.'/phpgwapi/setup/default_records_mime.inc.php'; $GLOBALS['egw_setup']->oProc->query("INSERT INTO phpgw_vfs2_files (mime_id,owner_id,createdby_id,size,directory,name) SELECT mime_id,0,0,4096,'/','' FROM phpgw_vfs2_mimetypes WHERE mime='Directory'"); if ($GLOBALS['DEBUG']) { echo " DONE!</b>"; } /*************************************************************************/ $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.006'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.006'; function phpgwapi_upgrade1_0_1_006() { $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_async','egw_async'); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.007'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.007'; function phpgwapi_upgrade1_0_1_007() { //Creating cached values for modified and modifiedby_id $GLOBALS['egw_setup']->oProc->AddColumn('phpgw_vfs2_files', 'modifiedby_id', array('type' => 'int','precision' => 4)); $GLOBALS['egw_setup']->oProc->AddColumn('phpgw_vfs2_files', 'modified', array('type' => 'timestamp', 'nullable' => true)); //Updating existing values $sql = "SELECT max(modified) as mod, file_id, min(modifiedby_id) from phpgw_vfs2_versioning group by file_id"; $GLOBALS['egw_setup']->oProc->m_odb->query($sql,__LINE__,__FILE__); $files_to_change = array(); while ($GLOBALS['egw_setup']->oProc->m_odb->next_record()) { $files_to_change[] = $GLOBALS['egw_setup']->oProc->m_odb->Record; } foreach ($files_to_change as $key => $val) { $GLOBALS['egw_setup']->oProc->m_odb->update('phpgw_vfs2_files', array( 'modified' => $val['mod'], 'modifiedby_id' => $val['modifiedby_id'] ), array('file_id' => $val['file_id']),__LINE__,__FILE__ ); } $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.008'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.008'; function phpgwapi_upgrade1_0_1_008() { $GLOBALS['egw_setup']->oProc->CreateTable( 'egw_contentmap', array( 'fd' => array( 'map_id' => array('type' => 'varchar', 'precision' => '255', 'nullable' => False), 'map_guid' => array('type' => 'varchar', 'precision' => '200', 'nullable' => False), 'map_locuid' => array('type' => 'varchar', 'precision' => '200', 'nullable' => False), 'map_timestamp' => array('type' => 'timestamp', 'nullable' => False), 'map_expired' => array('type' => 'bool', 'nullable' => False), ), 'pk' => array(array('map_id','map_guid','map_locuid')), 'fk' => array(), 'ix' => array(array('map_id','map_locuid'),'map_expired'), 'uc' => array() ) ); $GLOBALS['egw_setup']->oProc->CreateTable( 'egw_syncmldevinfo', array( 'fd' => array( 'dev_id' => array('type' => 'varchar', 'precision' => '255', 'nullable' => False), 'dev_dtdversion' => array('type' => 'varchar', 'precision' => '10', 'nullable' => False), 'dev_numberofchanges' => array('type' => 'bool', 'nullable' => False), 'dev_largeobjs' => array('type' => 'bool', 'nullable' => False), 'dev_swversion' => array('type' => 'varchar', 'precision' => '100', 'nullable' => False), 'dev_oem' => array('type' => 'varchar', 'precision' => '100', 'nullable' => False), 'dev_model' => array('type' => 'varchar', 'precision' => '100', 'nullable' => False), 'dev_manufacturer' => array('type' => 'varchar', 'precision' => '100', 'nullable' => False), 'dev_devicetype' => array('type' => 'varchar', 'precision' => '100', 'nullable' => False), 'dev_deviceid' => array('type' => 'varchar', 'precision' => '100', 'nullable' => False), 'dev_datastore' => array('type' => 'text', 'nullable' => False), ), 'pk' => array('dev_id'), 'fk' => array(), 'ix' => array(), 'uc' => array() ) ); $GLOBALS['egw_setup']->oProc->CreateTable( 'egw_syncmlsummary', array( 'fd' => array( 'dev_id' => array('type' => 'varchar', 'precision' => '255', 'nullable' => False), 'sync_path' => array('type' => 'varchar', 'precision' => '100', 'nullable' => False), 'sync_serverts' => array('type' => 'varchar', 'precision' => '20', 'nullable' => False), 'sync_clientts' => array('type' => 'varchar', 'precision' => '20', 'nullable' => False), ), 'pk' => array(array('dev_id','sync_path')), 'fk' => array(), 'ix' => array(), 'uc' => array() ) ); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.009'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.009'; function phpgwapi_upgrade1_0_1_009() { if (@file_exists(EGW_SERVER_ROOT . '/home/setup/setup.inc.php')) { // automatic install of the new home app include(EGW_SERVER_ROOT . '/home/setup/setup.inc.php'); $home_version = $setup_info['home']['version']; $GLOBALS['egw_setup']->db->insert($GLOBALS['egw_setup']->applications_table,array( 'app_enabled' => $setup_info['home']['enable'], 'app_order' => $setup_info['home']['app_order'], 'app_version' => $setup_info['home']['version'], 'app_tables' => '', 'app_version' => $home_version, ),array( 'app_name' => 'home', ),__LINE__,__FILE__,False,False,$GLOBALS['egw_setup']->oProc->GetTableDefinition($GLOBALS['egw_setup']->applications_table)); // give all users and groups with preferences rights, rights for the home app. $GLOBALS['egw_setup']->db->select($GLOBALS['egw_setup']->acl_table,'acl_account',array( 'acl_appname' => 'preferences', 'acl_location' => 'run', 'acl_rights' => 1, ),__LINE__,__FILE__); $accounts_with_preference_rights = array(); while (($row = $GLOBALS['egw_setup']->db->row(true))) { $accounts_with_preference_rights[] = $row['acl_account']; } foreach($accounts_with_preference_rights as $account) { $GLOBALS['egw_setup']->db->insert($GLOBALS['egw_setup']->acl_table,array( 'acl_rights' => 1, ),array( 'acl_appname' => 'home', 'acl_location' => 'run', 'acl_account' => $account, ),__LINE__,__FILE__,False,False,$GLOBALS['egw_setup']->oProc->GetTableDefinition($GLOBALS['egw_setup']->acl_table)); } } $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.010'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.010'; function phpgwapi_upgrade1_0_1_010() { $GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_sessions','session_ip',array( 'type' => 'varchar', 'precision' => '40' )); $GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_access_log','ip',array( 'type' => 'varchar', 'precision' => '40', 'nullable' => False )); $GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_access_log','loginid',array( 'type' => 'varchar', 'precision' => '128' )); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.011'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.011'; function phpgwapi_upgrade1_0_1_011() { // moving the egw_links table into the API if ($GLOBALS['egw_setup']->oProc->GetTableDefinition('phpgw_links')) { // table exists with old name ==> rename it to new one $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_links','egw_links'); } elseif (!$GLOBALS['egw_setup']->oProc->GetTableDefinition('egw_links')) { // table does not exist at all (infolog not installed) ==> create it $GLOBALS['egw_setup']->oProc->CreateTable('egw_links',array( 'fd' => array( 'link_id' => array('type' => 'auto','nullable' => False), 'link_app1' => array('type' => 'varchar','precision' => '25','nullable' => False), 'link_id1' => array('type' => 'varchar','precision' => '50','nullable' => False), 'link_app2' => array('type' => 'varchar','precision' => '25','nullable' => False), 'link_id2' => array('type' => 'varchar','precision' => '50','nullable' => False), 'link_remark' => array('type' => 'varchar','precision' => '50'), 'link_lastmod' => array('type' => 'int','precision' => '4','nullable' => False), 'link_owner' => array('type' => 'int','precision' => '4','nullable' => False) ), 'pk' => array('link_id'), 'fk' => array(), 'ix' => array(array('link_app1','link_id1','link_lastmod'),array('link_app2','link_id2','link_lastmod')), 'uc' => array() )); } // move the link-configuration to the api $GLOBALS['egw_setup']->oProc->query('UPDATE '.$GLOBALS['egw_setup']->config_table." SET config_app='phpgwapi' WHERE config_app='infolog' AND config_name IN ('link_pathes','send_file_ips')",__LINE__,__FILE__); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.012'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.012'; function phpgwapi_upgrade1_0_1_012() { $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_accounts','egw_accounts'); $GLOBALS['egw_setup']->set_table_names(True); if ($GLOBALS['egw']->accounts->table) { $GLOBALS['egw']->accounts->table = $GLOBALS['egw_setup']->accounts_table; } $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_acl','egw_acl'); $GLOBALS['egw_setup']->set_table_names(True); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_log','egw_log'); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_log_msg','egw_log_msg'); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.013'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.013'; function phpgwapi_upgrade1_0_1_013() { $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_config','egw_config'); $GLOBALS['egw_setup']->set_table_names(True); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_applications','egw_applications'); $GLOBALS['egw_setup']->set_table_names(True); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.014'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.014'; function phpgwapi_upgrade1_0_1_014() { // index was to big for mysql with charset utf8 (max 1000byte = 333 utf8 chars) // before we can shorten the message_id, we have to make sure there are no identical message_id > 128 chars // and we have to truncate the message_id explicitly, postgresql f.e. will not do it for us, but bail out instead $to_delete = array(); $to_truncate = array(); $GLOBALS['egw_setup']->db->select('phpgw_lang','app_name,lang,message_id','LENGTH(message_id) > 128',__LINE__,__FILE__, false,'ORDER BY app_name,lang,message_id'); while(($row = $GLOBALS['egw_setup']->db->row(true))) { if ($last_row && $last_row['app_name'] == $row['app_name'] && $last_row['lang'] == $row['lang'] && substr($last_row['message_id'],0,128) == substr($row['message_id'],0,128)) { $to_delete[] = $row; } else { $to_truncate[] = $row; } $last_row = $row; } $table_def = $GLOBALS['egw_setup']->oProc->GetTableDefinition('phpgw_lang'); foreach ($to_delete as $row) { $GLOBALS['egw_setup']->db->delete('phpgw_lang',$row,__LINE__,__FILE__,False,$table_def); } foreach ($to_truncate as $row) { $where = $row; $row['message_id'] = substr($row['message_id'],0,128); $GLOBALS['egw_setup']->db->update('phpgw_lang',$row,$where,__LINE__,__FILE__,'phpgwapi',False,$table_def); } $GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_lang','app_name',array( 'type' => 'varchar', 'precision' => '32', 'nullable' => False, 'default' => 'common' )); $GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_lang','message_id',array( 'type' => 'varchar', 'precision' => '128', 'nullable' => False, 'default' => '' )); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_lang','egw_lang'); $GLOBALS['egw_setup']->set_table_names(True); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_languages','egw_languages'); $GLOBALS['egw_setup']->set_table_names(True); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.015'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.015'; function phpgwapi_upgrade1_0_1_015() { // index was to big for mysql with charset utf8 (max 1000byte = 333 utf8 chars) /* done by RefreshTable() anyway $GLOBALS['egw_setup']->oProc->AlterColumn('egw_contentmap','map_id',array( 'type' => 'varchar', 'precision' => '128', 'nullable' => False ));*/ /* done by RefreshTable() anyway $GLOBALS['egw_setup']->oProc->AlterColumn('egw_contentmap','map_guid',array( 'type' => 'varchar', 'precision' => '128', 'nullable' => False ));*/ /* done by RefreshTable() anyway $GLOBALS['egw_setup']->oProc->AlterColumn('egw_contentmap','map_locuid',array( 'type' => 'int', 'precision' => '8', 'nullable' => False ));*/ $GLOBALS['egw_setup']->oProc->RefreshTable('egw_contentmap',array( 'fd' => array( 'map_id' => array('type' => 'varchar','precision' => '128','nullable' => False), 'map_guid' => array('type' => 'varchar','precision' => '128','nullable' => False), 'map_locuid' => array('type' => 'int','precision' => '8','nullable' => False), 'map_timestamp' => array('type' => 'timestamp','nullable' => False), 'map_expired' => array('type' => 'bool','nullable' => False) ), 'pk' => array('map_id','map_guid','map_locuid'), 'fk' => array(), 'ix' => array('map_expired',array('map_id','map_locuid')), 'uc' => array() )); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.016'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.016'; function phpgwapi_upgrade1_0_1_016() { // index was to big for mysql with charset utf8 (max 1000byte = 333 utf8 chars) $GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_vfs2_files','name',array( 'type' => 'varchar', 'precision' => '64', 'nullable' => False )); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.017'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.017'; function phpgwapi_upgrade1_0_1_017() { // index was to big for mysql with charset utf8 (max 1000byte = 333 utf8 chars) /* done by RefreshTable() anyway $GLOBALS['egw_setup']->oProc->AlterColumn('egw_vfs','vfs_name',array( 'type' => 'varchar', 'precision' => '64', 'nullable' => False ));*/ $GLOBALS['egw_setup']->oProc->RefreshTable('egw_vfs',array( 'fd' => array( 'vfs_file_id' => array('type' => 'auto','nullable' => False), 'vfs_owner_id' => array('type' => 'int','precision' => '4','nullable' => False), 'vfs_createdby_id' => array('type' => 'int','precision' => '4'), 'vfs_modifiedby_id' => array('type' => 'int','precision' => '4'), 'vfs_created' => array('type' => 'date','nullable' => False,'default' => '1970-01-01'), 'vfs_modified' => array('type' => 'date'), 'vfs_size' => array('type' => 'int','precision' => '4'), 'vfs_mime_type' => array('type' => 'varchar','precision' => '64'), 'vfs_deleteable' => array('type' => 'char','precision' => '1','default' => 'Y'), 'vfs_comment' => array('type' => 'varchar','precision' => '255'), 'vfs_app' => array('type' => 'varchar','precision' => '25'), 'vfs_directory' => array('type' => 'varchar','precision' => '255'), 'vfs_name' => array('type' => 'varchar','precision' => '64','nullable' => False), 'vfs_link_directory' => array('type' => 'varchar','precision' => '255'), 'vfs_link_name' => array('type' => 'varchar','precision' => '128'), 'vfs_version' => array('type' => 'varchar','precision' => '30','nullable' => False,'default' => '0.0.0.0'), 'vfs_content' => array('type' => 'text') ), 'pk' => array('vfs_file_id'), 'fk' => array(), 'ix' => array(array('vfs_directory','vfs_name')), 'uc' => array() )); $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.018'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } $test[] = '1.0.1.018'; function phpgwapi_upgrade1_0_1_018() { // This update fixes charset in mysql4+ tables, if the default client charset does not match the eGW system-charset. // It is necessary as update, as we now set the system_charset as client charset, which causes the existing input to be returned wrong. // We have to shorten the felamimail columns first, as this update would fail, because it's run before the felamimail update // (shortening them twice, does no harm) !!! if ($GLOBALS['egw_setup']->table_exist(array('phpgw_felamimail_cache'))) { $table_def_cache = $GLOBALS['egw_setup']->oProc->GetTableDefinition('phpgw_felamimail_cache'); $table_def_folderstatus = $GLOBALS['egw_setup']->oProc->GetTableDefinition('phpgw_felamimail_folderstatus'); foreach (array('fmail_accountname','accountname','fmail_foldername','foldername') as $column_name) { if (isset($table_def_cache['fd'][$column_name])) { $GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_felamimail_cache',$column_name,array( 'type' => 'varchar', 'precision' => '128', 'nullable' => False )); } if (isset($table_def_folderstatus['fd'][$column_name])) { $GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_felamimail_folderstatus',$column_name,array( 'type' => 'varchar', 'precision' => '128', 'nullable' => False )); } } } if (substr($GLOBALS['egw_setup']->db->Type,0,5) == 'mysql' && $GLOBALS['egw_setup']->system_charset && $GLOBALS['egw_setup']->db_charset_was && $GLOBALS['egw_setup']->system_charset != $GLOBALS['egw_setup']->db_charset_was) { include(EGW_SERVER_ROOT.'/setup/fix_mysql_charset.php'); // now the DB is fixed we can set the charset $GLOBALS['egw_setup']->db->Link_ID->SetCharSet($GLOBALS['egw_setup']->system_charset); } return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.019'; } $test[] = '1.0.1.019'; function phpgwapi_upgrade1_0_1_019() { $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_categories','egw_categories'); $GLOBALS['egw_setup']->cats_table = 'egw_categories'; return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.020'; } $test[] = '1.0.1.020'; function phpgwapi_upgrade1_0_1_020() { // in some old installations the email_type is NOT NULL, contrary to what our tables_current says $GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_addressbook','email_type',array( 'type' => 'varchar', 'precision' => '32', 'default' => 'INTERNET' )); $GLOBALS['egw_setup']->oProc->AlterColumn('phpgw_addressbook','email_home_type',array( 'type' => 'varchar', 'precision' => '32', 'default' => 'INTERNET' )); return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.021'; } $test[] = '1.0.1.021'; function phpgwapi_upgrade1_0_1_021() { $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_hooks','egw_hooks'); $GLOBALS['egw_setup']->hooks_table = 'egw_hooks'; return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.022'; } $test[] = '1.0.1.022'; function phpgwapi_upgrade1_0_1_022() { $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_preferences','egw_preferences'); $GLOBALS['egw_setup']->prefs_table = 'egw_preferences'; return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.023'; } $test[] = '1.0.1.023'; function phpgwapi_upgrade1_0_1_023() { $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_sessions','egw_sessions'); $GLOBALS['egw_setup']->oProc->AlterColumn('egw_sessions','session_dla',array( 'type' => 'int', 'precision' => '8', // timestamps need to be 64bit since the 32bit overflow in 2003 )); $GLOBALS['egw_setup']->oProc->AlterColumn('egw_sessions','session_logintime',array( 'type' => 'int', 'precision' => '8', // timestamps need to be 64bit since the 32bit overflow in 2003 )); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_app_sessions','egw_app_sessions'); $GLOBALS['egw_setup']->oProc->AlterColumn('egw_app_sessions','session_dla',array( 'type' => 'int', 'precision' => '8', // timestamps need to be 64bit since the 32bit overflow in 2003 )); return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.024'; } $test[] = '1.0.1.024'; function phpgwapi_upgrade1_0_1_024() { $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_access_log','egw_access_log'); return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.025'; } $test[] = '1.0.1.025'; function phpgwapi_upgrade1_0_1_025() { $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_nextid','egw_nextid'); return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.026'; } $test[] = '1.0.1.026'; function phpgwapi_upgrade1_0_1_026() { $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_history_log','egw_history_log'); return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.027'; } $test[] = '1.0.1.027'; function phpgwapi_upgrade1_0_1_027() { $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_interserv','egw_interserv'); return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.028'; } $test[] = '1.0.1.028'; function phpgwapi_upgrade1_0_1_028() { $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_addressbook','egw_addressbook'); $GLOBALS['egw_setup']->oProc->RenameTable('phpgw_addressbook_extra','egw_addressbook_extra'); return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.0.1.029'; } $test[] = '1.0.1.029'; function phpgwapi_upgrade1_0_1_029() { // convert all positive group id's to negative ones, since 1.2.002 except the account_id itself // this allows duplicate id for users and groups in ldap // This update include the next 2 updates and goes direct to version 1.2.002! $GLOBALS['egw_setup']->db->select($GLOBALS['egw_setup']->config_table,'config_value',array( 'config_name' => 'account_repository', 'config_app' => 'phpgwapi', ),__LINE__,__FILE__); if($GLOBALS['egw_setup']->db->next_record() && $GLOBALS['egw_setup']->db->f('config_value') == 'ldap') { $GLOBALS['egw_setup']->db->select($GLOBALS['egw_setup']->acl_table,'DISTINCT acl_location',array( 'acl_appname' => 'phpgw_group', 'acl_location > 0', ),__LINE__,__FILE__); } else { $GLOBALS['egw_setup']->db->select($GLOBALS['egw_setup']->accounts_table,'account_id',array( 'account_type' => 'g', 'account_id > 0', ),__LINE__,__FILE__); } $groupIDs = array(); while($GLOBALS['egw_setup']->db->next_record()) { $groupIDs[] = $GLOBALS['egw_setup']->db->f(0); } $tables = array(); foreach($GLOBALS['egw_setup']->db->table_names() as $data) { $tables[] = $data['table_name']; } foreach(array( array('egw_acl','acl_location'), array('egw_acl','acl_account'), array('egw_accounts','account_primary_group',"account_type='u'"), array('egw_cal_user','cal_user_id',"cal_user_type='u'"), // adding the old name, as the rename might have not been done (api upgrades run befor app ones) array('phpgw_cal_user','cal_user_id',"cal_user_type='u'"), array('egw_wiki_pages','wiki_readable',true), array('egw_wiki_pages','wiki_writable',true), // adding the old name, as the rename might have not been done (api upgrades run befor app ones) array('phpgw_wiki_pages','wiki_readable',true), array('phpgw_wiki_pages','wiki_writable',true), array('egw_vfs','vfs_owner_id'), array('egw_vfs','vfs_createdby_id'), ) as $data) { $where = false; list($table,$col,$where) = $data; if (!in_array($table,$tables)) continue; // app is not installed if ($col == 'acl_location') // varchar not int! { $set = $col.'='.$GLOBALS['egw_setup']->db->concat("'-'",$col); $in = "$col IN ('".implode("','",$groupIDs)."')"; } else { $set = "$col=-$col"; $in = "$col IN (".implode(',',$groupIDs).')'; } if ($where === true) { $in = ''; $where = '1=1'; } $query = "UPDATE $table SET $set WHERE $in".($in && $where ? ' AND ' : '').$where; //echo "<p>$query</p>\n"; $GLOBALS['egw_setup']->db->query($query,__LINE__,__FILE__); } return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.2.002'; } $test[] = '1.2'; function phpgwapi_upgrade1_2() { // groupid's in egw_vfs.{owner|createdby}_id were not converted $GLOBALS['egw_setup']->db->select($GLOBALS['egw_setup']->config_table,'config_value',array( 'config_name' => 'account_repository', 'config_app' => 'phpgwapi', ),__LINE__,__FILE__); if($GLOBALS['egw_setup']->db->next_record() && $GLOBALS['egw_setup']->db->f('config_value') == 'ldap') { $GLOBALS['egw_setup']->db->select($GLOBALS['egw_setup']->acl_table,'DISTINCT acl_location',array( 'acl_appname' => 'phpgw_group', ),__LINE__,__FILE__); } else { $GLOBALS['egw_setup']->db->select($GLOBALS['egw_setup']->accounts_table,'account_id',array( 'account_type' => 'g', ),__LINE__,__FILE__); } $groupIDs = array(); while($GLOBALS['egw_setup']->db->next_record()) { $groupIDs[] = abs($GLOBALS['egw_setup']->db->f(0)); } $tables = array(); foreach($GLOBALS['egw_setup']->db->table_names() as $data) { $tables[] = $data['table_name']; } foreach(array( array('egw_vfs','vfs_owner_id'), array('egw_vfs','vfs_createdby_id'), ) as $data) { $where = false; list($table,$col,$where) = $data; if (!in_array($table,$tables)) continue; // app is not installed if ($col == 'acl_location') // varchar not int! { $set = $col.'='.$GLOBALS['egw_setup']->db->concat("'-'",$col); $in = "$col IN ('".implode("','",$groupIDs)."')"; } else { $set = "$col=-$col"; $in = "$col IN (".implode(',',$groupIDs).')'; } if ($where === true) { $in = ''; $where = '1=1'; } $query = "UPDATE $table SET $set WHERE $in".($in && $where ? ' AND ' : '').$where; //echo "<p>$query</p>\n"; $GLOBALS['egw_setup']->db->query($query,__LINE__,__FILE__); } return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.2.001'; } $test[] = '1.2.001'; function phpgwapi_upgrade1_2_001() { // convert groupid's in egw_accounts back to positive, as not all DBMS can deal with neg. id's if ($GLOBALS['egw_setup']->db->Type == 'mssql') { $GLOBALS['egw_setup']->db->query("SET identity_update egw_accounts ON",__LINE__,__FILE__); } $GLOBALS['egw_setup']->db->query("UPDATE egw_accounts SET account_id=-account_id WHERE account_type='g' AND account_id < 0",__LINE__,__FILE__); return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.2.002'; } $test[] = '1.2.002'; function phpgwapi_upgrade1_2_002() { // removed 1.2.002 update as it exceeded the max index of 1000Byte under MySQL, 1.2.004 does the right thing now return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.2.003'; } $test[] = '1.2.003'; function phpgwapi_upgrade1_2_003() { // change lenght of dir/name from 255/64 to 233/100, as 64 was definitly to short, // sum has to be <= 333 (1000/3) because of the mysql index restrictions $GLOBALS['egw_setup']->oProc->AlterColumn('egw_vfs','vfs_directory',array( 'type' => 'varchar', 'precision' => '233' )); $GLOBALS['egw_setup']->oProc->AlterColumn('egw_vfs','vfs_name',array( 'type' => 'varchar', 'precision' => '100', 'nullable' => False )); return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.2.004'; } $test[] = '1.2.004'; function phpgwapi_upgrade1_2_004() { $GLOBALS['egw_setup']->oProc->AlterColumn('egw_contentmap','map_guid',array( 'type' => 'varchar', 'precision' => '100', 'nullable' => False )); $GLOBALS['egw_setup']->oProc->AlterColumn('egw_contentmap','map_locuid',array( 'type' => 'varchar', 'precision' => '100', 'nullable' => False )); return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.2.005'; } $test[] = '1.2.005'; function phpgwapi_upgrade1_2_005() { // new version number for 1.2RC7 return $GLOBALS['setup_info']['phpgwapi']['currentver'] = '1.2.007'; } ?>