mirror of
https://codeberg.org/streams/streams.git
synced 2024-09-20 01:15:13 +00:00
chat expiration (default 2 hours) - but can be set on a per-chatroom basis
This commit is contained in:
parent
49f07bd90f
commit
a1d40431f2
4 changed files with 22 additions and 5 deletions
2
boot.php
2
boot.php
|
@ -46,7 +46,7 @@ define ( 'RED_PLATFORM', 'Red Matrix' );
|
|||
define ( 'RED_VERSION', trim(file_get_contents('version.inc')) . 'R');
|
||||
define ( 'ZOT_REVISION', 1 );
|
||||
|
||||
define ( 'DB_UPDATE_VERSION', 1094 );
|
||||
define ( 'DB_UPDATE_VERSION', 1095 );
|
||||
|
||||
define ( 'EOL', '<br />' . "\r\n" );
|
||||
define ( 'ATOM_TIME', 'Y-m-d\TH:i:s\Z' );
|
||||
|
|
|
@ -31,16 +31,19 @@ function chatroom_create($channel,$arr) {
|
|||
return $ret;
|
||||
}
|
||||
|
||||
if(! array_key_exists('expire',$arr))
|
||||
$arr['expire'] = 120; // minutes, e.g. 2 hours
|
||||
|
||||
$created = datetime_convert();
|
||||
|
||||
$x = q("insert into chatroom ( cr_aid, cr_uid, cr_name, cr_created, cr_edited, allow_cid, allow_gid, deny_cid, deny_gid )
|
||||
values ( %d, %d , '%s', '%s', '%s', '%s', '%s', '%s', '%s' ) ",
|
||||
$x = q("insert into chatroom ( cr_aid, cr_uid, cr_name, cr_created, cr_edited, cr_expire, allow_cid, allow_gid, deny_cid, deny_gid )
|
||||
values ( %d, %d , '%s', '%s', '%s', %d, '%s', '%s', '%s', '%s' ) ",
|
||||
intval($channel['channel_account_id']),
|
||||
intval($channel['channel_id']),
|
||||
dbesc($name),
|
||||
dbesc($created),
|
||||
dbesc($created),
|
||||
intval($arr['expire']),
|
||||
dbesc($arr['allow_cid']),
|
||||
dbesc($arr['allow_gid']),
|
||||
dbesc($arr['deny_cid']),
|
||||
|
@ -111,6 +114,9 @@ function chatroom_enter($observer_xchan,$room_id,$status,$client) {
|
|||
return false;
|
||||
}
|
||||
|
||||
if(intval($x[0]['cr_expire']))
|
||||
$r = q("delete from chat where created < UTC_TIMESTAMP() - INTERVAL " . intval($x[0]['cr_expire']) . " MINUTE and chat_room = " . intval($x[0]['cr_id']));
|
||||
|
||||
$r = q("select * from chatpresence where cp_xchan = '%s' and cp_room = %d limit 1",
|
||||
dbesc($observer_xchan),
|
||||
intval($room_id)
|
||||
|
|
|
@ -247,6 +247,7 @@ CREATE TABLE IF NOT EXISTS `chatroom` (
|
|||
`cr_name` char(255) NOT NULL DEFAULT '',
|
||||
`cr_created` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
||||
`cr_edited` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
||||
`cr_expire` int(10) unsigned NOT NULL DEFAULT '0',
|
||||
`allow_cid` mediumtext NOT NULL,
|
||||
`allow_gid` mediumtext NOT NULL,
|
||||
`deny_cid` mediumtext NOT NULL,
|
||||
|
@ -256,7 +257,8 @@ CREATE TABLE IF NOT EXISTS `chatroom` (
|
|||
KEY `cr_uid` (`cr_uid`),
|
||||
KEY `cr_name` (`cr_name`),
|
||||
KEY `cr_created` (`cr_created`),
|
||||
KEY `cr_edited` (`cr_edited`)
|
||||
KEY `cr_edited` (`cr_edited`),
|
||||
KEY `cr_expire` (`cr_expire`)
|
||||
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
|
||||
|
||||
CREATE TABLE IF NOT EXISTS `clients` (
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
<?php
|
||||
|
||||
define( 'UPDATE_VERSION' , 1094 );
|
||||
define( 'UPDATE_VERSION' , 1095 );
|
||||
|
||||
/**
|
||||
*
|
||||
|
@ -1060,3 +1060,12 @@ function update_r1093() {
|
|||
return UPDATE_SUCCESS;
|
||||
return UPDATE_FAILED;
|
||||
}
|
||||
|
||||
function update_r1094() {
|
||||
$r = q("ALTER TABLE `chatroom` ADD `cr_expire` INT UNSIGNED NOT NULL DEFAULT '0' AFTER `cr_edited` ,
|
||||
ADD INDEX ( `cr_expire` )");
|
||||
if($r)
|
||||
return UPDATE_SUCCESS;
|
||||
return UPDATE_FAILED;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue