1
0
Fork 0
mirror of https://github.com/Yetangitu/ampache synced 2025-10-06 03:49:56 +02:00
ampache/bin/quarantine_migration.php.inc
2005-08-12 00:42:52 +00:00

165 lines
3.7 KiB
PHP

<?php
/*
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.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
created by RosenSama 2005
call: php quarantine_migration.php
*/
$no_session='1';
require_once('../modules/init.php');
usage();
// grab list of files from table
$sql = "SELECT id, file, user,action FROM upload WHERE action != 'quarantine'";
$db_results = mysql_query($sql, dbh());
$files = array();
$files['add'] = array();
$files['delete'] = array();
while ($results = mysql_fetch_assoc($db_results)) {
$action = $results['action'];
$files[$action][] = $results;
} // end while
/* Make sure we have write access to the upload dir */
$upload_dir = conf('upload_dir');
if (!@is_writeable($upload_dir)) {
cli_out("\n" . _("Error: Unable to write to") . $upload_dir);
exit;
}
$catalog_id = find_upload_catalog($upload_dir);
if (!$catalog_id) {
cli_out(_("Error: Upload directory not inside a catalog"));
exit;
} // we must have a valid upload dir
$catalog = new Catalog($catalog_id);
/* Itterate through the files we need to move */
$adds = &$files['add'];
foreach ($adds as $data) {
/* Make sure that the target filename doesn't exist */
$command = "mv " . $data['file'] . " " . $upload_dir;
$command = escapeshellcmd($command);
exec($command,$return,$error);
if (!$error) {
cli_out("\n" . _("Moved") . " " . $data['file']);
$new_filename = $upload_dir . "/" . basename($data['file']);
cli_out(_("Adding") . " " . $new_filename . " " . _("to database"));
$catalog->add_file($new_filename);
$sql = "DELETE FROM upload WHERE id='" . $data['id'] . "'";
$db_results = mysql_query($sql, dbh());
}
else {
cli_out(_("Move Failed") . " " . $data['file']);
}
} // end foreach
/* Itterate through the files we need to delete */
$deletes = &$files['delete'];
foreach ($deletes as $data) {
unlink($data['file']);
cli_out(_("Deleted") . " " . $data['file']);
$sql = "DELETE FROM upload WHERE id='" . $data['id'] . "'";
$db_results = mysql_query($sql, dbh());
} // end foreach
exit();
/*!
@function usage()
@discussion echo the help for this script
*/
function usage( ) {
$text = _( "
************* WARNING *************
This script will move, and
potentially delete uploaded files.
************* WARNING *************
All files marked for add will be moved to the upload directory. All files
marked for deletion will be deleted. This script must be run as a user with
sufficient rights to perform the above two functions.
\n" );
echo $text;
$text = _( "Continue? (Y/N):" );
echo $text;
// grab a character ignoring whitespace
do {
$input= fgetc( STDIN );
} while ( trim( $input ) == '' );
if(strcmp($input,"y") != 0 ) {
exit;
}
} // usage()
/*!
@function cli_out()
@discussion util for error formatting
@param $text the message to be output
@param $mode to STDERR (0) or STDOUT (1, default)
*/
function cli_out( $text, $mode = 1 ) {
switch( $mode ) {
case 0:
$dest = STDERR;
$pre = _( "Error: " );
$post = _( "!\n" );
break;
case 1:
default:
$dest = STDOUT;
$pre = "";
$post = "\n";
}
fwrite( $dest, $pre . $text . $post );
} // error_out
?>