egroupware_official/notifications/setup/tables_update.inc.php
2020-06-28 10:04:21 +02:00

185 lines
4.8 KiB
PHP

<?php
/**
* EGroupware - Setup
* http://www.egroupware.org
* Created by eTemplates DB-Tools written by ralfbecker@outdoor-training.de
*
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
* @package notifications
* @subpackage setup
*/
function notifications_upgrade0_5()
{
$GLOBALS['egw_setup']->oProc->AlterColumn('egw_notificationpopup','account_id',array(
'type' => 'int',
'precision' => '20',
'nullable' => False
));
return $GLOBALS['setup_info']['notifications']['currentver'] = '0.6';
}
function notifications_upgrade0_6()
{
return $GLOBALS['setup_info']['notifications']['currentver'] = '1.4';
}
function notifications_upgrade1_4()
{
return $GLOBALS['setup_info']['notifications']['currentver'] = '1.6';
}
function notifications_upgrade1_6()
{
return $GLOBALS['setup_info']['notifications']['currentver'] = '1.8';
}
function notifications_upgrade1_8()
{
$GLOBALS['egw_setup']->oProc->DropColumn('egw_notificationpopup',array(
'fd' => array(
'account_id' => array('type' => 'int','precision' => '20','nullable' => False),
'message' => array('type' => 'longtext')
),
'pk' => array(),
'fk' => array(),
'ix' => array('account_id'),
'uc' => array()
),'session_id');
return $GLOBALS['setup_info']['notifications']['currentver'] = '1.9.001';
}
/**
* Empty notificaton table, as it can contain thousands of old entries, not delivered before
*/
function notifications_upgrade1_9_001()
{
// empty notificationpopup table, as it can contain thousands of old entries, not delivered before
$GLOBALS['egw_setup']->db->query('DELETE FROM egw_notificationpopup');
return $GLOBALS['setup_info']['notifications']['currentver'] = '1.9.002';
}
/**
* Add primary key to easy identify notifications in ajax request, a automatic timestamp and table prefix
*/
function notifications_upgrade1_9_002()
{
$GLOBALS['egw_setup']->oProc->RefreshTable('egw_notificationpopup',array(
'fd' => array(
'notify_id' => array('type' => 'auto','nullable' => False,'comment' => 'primary key'),
'account_id' => array('type' => 'int','precision' => '20','nullable' => False,'comment' => 'user to notify'),
'notify_message' => array('type' => 'text','comment' => 'notification message'),
'notify_created' => array('type' => 'timestamp','default' => 'current_timestamp','comment' => 'creation time of notification')
),
'pk' => array('notify_id'),
'fk' => array(),
'ix' => array('account_id','notify_created'),
'uc' => array()
),array(
'notify_message' => 'message',
));
return $GLOBALS['setup_info']['notifications']['currentver'] = '1.9.003';
}
function notifications_upgrade1_9_003()
{
$GLOBALS['egw_setup']->oProc->AddColumn('egw_notificationpopup','notify_type',array(
'type' => 'varchar',
'precision' => '32',
'comment' => 'notification type'
));
return $GLOBALS['setup_info']['notifications']['currentver'] = '1.9.004';
}
function notifications_upgrade1_9_004()
{
return $GLOBALS['setup_info']['notifications']['currentver'] = '14.1';
}
function notifications_upgrade14_1()
{
$GLOBALS['egw_setup']->oProc->AlterColumn('egw_notificationpopup','notify_message',array(
'type' => 'varchar',
'precision' => '16384',
'comment' => 'notification message'
));
$GLOBALS['egw_setup']->oProc->AlterColumn('egw_notificationpopup','notify_type',array(
'type' => 'ascii',
'precision' => '32',
'comment' => 'notification type'
));
return $GLOBALS['setup_info']['notifications']['currentver'] = '14.3';
}
function notifications_upgrade14_3()
{
return $GLOBALS['setup_info']['notifications']['currentver'] = '16.1';
}
function notifications_upgrade16_1()
{
$GLOBALS['egw_setup']->oProc->AddColumn('egw_notificationpopup','notify_status',array(
'type' => 'varchar',
'precision' => '32',
'comment' => 'notification status'
));
return $GLOBALS['setup_info']['notifications']['currentver'] = '17.1';
}
function notifications_upgrade17_1()
{
$GLOBALS['egw_setup']->oProc->AddColumn('egw_notificationpopup','notify_data',array(
'type' => 'varchar',
'precision' => '4096',
'comment' => 'notification actions'
));
return $GLOBALS['setup_info']['notifications']['currentver'] = '17.1.001';
}
/**
* Change notify_message column type from Varchar to Text, this field is a dynamic field.
*
* @return string
*/
function notifications_upgrade17_1_001()
{
$GLOBALS['egw_setup']->oProc->AlterColumn('egw_notificationpopup','notify_message',array(
'type' => 'text',
'comment' => 'notification message'
));
return $GLOBALS['setup_info']['notifications']['currentver'] = '17.1.002';
}
/**
* Bump version to 19.1
*
* @return string
*/
function notifications_upgrade17_1_002()
{
return $GLOBALS['setup_info']['notifications']['currentver'] = '19.1';
}
/**
* Bump version to 20.1
*
* @return string
*/
function notifications_upgrade19_1()
{
return $GLOBALS['setup_info']['notifications']['currentver'] = '20.1';
}