Page Menu
Home
Phorge
Search
Configure Global Search
Log In
Files
F117750043
cleandb.sh
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Flag For Later
Award Token
Authored By
Unknown
Size
2 KB
Referenced Files
None
Subscribers
None
cleandb.sh
View Options
#!/usr/bin/env php
<?php
/*
+-----------------------------------------------------------------------+
|
bin/cleandb.sh
|
|
|
|
This file is part of the Roundcube Webmail client
|
|
Copyright
(
C
)
2010
, The Roundcube Dev Team
|
|
|
|
Licensed under the GNU General Public License version
3
or
|
|
any later version with exceptions
for
skins
&
plugins.
|
|
See the README file
for
a full license statement.
|
|
|
|
PURPOSE:
|
|
Finally remove all db records marked as deleted some
time
ago
|
|
|
+-----------------------------------------------------------------------+
|
Author: Thomas Bruederli <roundcube@gmail.com>
|
+-----------------------------------------------------------------------+
*/
define
(
'INSTALL_PATH'
, realpath
(
dirname
(
__FILE__
)
.
'/..'
)
.
'/'
)
;
require INSTALL_PATH.
'program/include/clisetup.php'
;
// mapping
for
table
name
=
> primary key
$primary_keys
=
array
(
'contacts'
=
>
"contact_id"
,
'contactgroups'
=
>
"contactgroup_id"
,
)
;
// connect to DB
$RCMAIL
=
rcmail::get_instance
()
;
$db
=
$RCMAIL
->get_dbh
()
;
$db
->db_connect
(
'w'
)
;
if
(
!
$db
->is_connected
()
||
$db
->is_error
())
die
(
"No DB connection\n"
)
;
if
(
!empty
(
$_SERVER
[
'argv'
][
1
]))
$days
=
intval
(
$_SERVER
[
'argv'
][
1
])
;
else
$days
=
7
;
// remove all deleted records older than two days
$threshold
=
date
(
'Y-m-d 00:00:00'
, time
()
-
$days
*
86400
)
;
foreach
(
array
(
'contacts'
,
'contactgroups'
,
'identities'
)
as
$table
)
{
$sqltable
=
get_table_name
(
$table
)
;
// also delete linked records
// could be skipped
for
databases which respect foreign key constraints
if
(
$db
->db_provider
==
'sqlite'
&&
(
$table
==
'contacts'
||
$table
==
'contactgroups'
)
)
{
$pk
=
$primary_keys
[
$table
]
;
$memberstable
=
get_table_name
(
'contactgroupmembers'
)
;
$db
->query
(
"DELETE FROM
$memberstable
"
.
" WHERE
$pk
IN ("
.
"SELECT
$pk
FROM
$sqltable
"
.
" WHERE del=1 AND changed < ?"
.
")"
,
$threshold
)
;
echo
$db
->affected_rows
()
.
" records deleted from '
$memberstable
'\n"
;
}
// delete outdated records
$db
->query
(
"DELETE FROM
$sqltable
WHERE del=1 AND changed < ?"
,
$threshold
)
;
echo
$db
->affected_rows
()
.
" records deleted from '
$table
'\n"
;
}
?>
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Sat, Apr 4, 2:00 AM (1 w, 2 d ago)
Storage Engine
local-disk
Storage Format
Raw Data
Storage Handle
09/d3/55e650893637a5551923feb65f6e
Default Alt Text
cleandb.sh (2 KB)
Attached To
Mode
R113 roundcubemail
Attached
Detach File
Event Timeline