mirror of
https://github.com/Yetangitu/ampache
synced 2025-10-03 17:59:21 +02:00

Still has tentacles and should have been integrated into the existing API/Browse implementation better, but it's functional.
108 lines
3.1 KiB
PHP
108 lines
3.1 KiB
PHP
<?php
|
|
/* vim:set tabstop=8 softtabstop=8 shiftwidth=8 noexpandtab: */
|
|
/**
|
|
* Batch
|
|
*
|
|
* PHP version 5
|
|
*
|
|
* LICENSE: GNU General Public License, version 2 (GPLv2)
|
|
* Copyright (c) 2001 - 2011 Ampache.org All Rights Reserved
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License v2
|
|
* as published by the Free Software Foundation.
|
|
*
|
|
* 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.
|
|
*
|
|
* @category Batch
|
|
* @package Files
|
|
* @author Karl Vollmer <vollmer@ampache.org>
|
|
* @copyright 2001 - 2011 Ampache.org
|
|
* @license http://opensource.org/licenses/gpl-2.0 GPLv2
|
|
* @version PHP 5.2
|
|
* @link http://www.ampache.org/
|
|
* @since File available since Release 1.0
|
|
*/
|
|
|
|
require_once 'lib/init.php';
|
|
ob_end_clean();
|
|
|
|
//test that batch download is permitted
|
|
if (!Access::check_function('batch_download')) {
|
|
access_denied();
|
|
exit;
|
|
}
|
|
|
|
/* Drop the normal Time limit constraints, this can take a while */
|
|
set_time_limit(0);
|
|
|
|
switch ($_REQUEST['action']) {
|
|
case 'tmp_playlist':
|
|
$media_ids = $GLOBALS['user']->playlist->get_items();
|
|
$name = $GLOBALS['user']->username . ' - Playlist';
|
|
break;
|
|
case 'playlist':
|
|
$playlist = new Playlist($_REQUEST['id']);
|
|
$media_ids = $playlist->get_songs();
|
|
$name = $playlist->name;
|
|
break;
|
|
case 'smartplaylist':
|
|
$search = new Search('song', $_REQUEST['id']);
|
|
$sql = $search->to_sql();
|
|
$sql = $sql['base'] . ' ' . $sql['table_sql'] . ' WHERE ' .
|
|
$sql['where_sql'];
|
|
$db_results = Dba::read($sql);
|
|
$media_ids = array();
|
|
while ($row = Dba::fetch_assoc($db_results)) {
|
|
$media_ids[] = $row['id'];
|
|
}
|
|
$name = $search->name;
|
|
break;
|
|
case 'album':
|
|
$album = new Album($_REQUEST['id']);
|
|
$media_ids = $album->get_songs();
|
|
$name = $album->name;
|
|
break;
|
|
case 'artist':
|
|
$artist = new Artist($_REQUEST['id']);
|
|
$media_ids = $artist->get_songs();
|
|
$name = $artist->name;
|
|
break;
|
|
case 'browse':
|
|
$id = scrub_in($_REQUEST['browse_id']);
|
|
$browse = new Browse($id);
|
|
$browse_media_ids = $browse->get_saved();
|
|
$media_ids = array();
|
|
foreach ($browse_media_ids as $media_id) {
|
|
switch ($_REQUEST['type']) {
|
|
case 'album':
|
|
$album = new Album($media_id);
|
|
$media_ids = array_merge($media_ids, $album->get_songs());
|
|
break;
|
|
case 'song':
|
|
$media_ids[] = $media_id;
|
|
break;
|
|
case 'video':
|
|
$media_ids[] = array('Video', $media_id);
|
|
break;
|
|
} // switch on type
|
|
} // foreach media_id
|
|
$name = 'Batch-' . date("dmY",time());
|
|
default:
|
|
// Rien a faire
|
|
break;
|
|
} // action switch
|
|
|
|
// Take whatever we've got and send the zip
|
|
$song_files = get_song_files($media_ids);
|
|
set_memory_limit($song_files['1']+32);
|
|
send_zip($name,$song_files['0']);
|
|
exit;
|
|
?>
|