1
0
Fork 0
mirror of https://github.com/Yetangitu/ampache synced 2025-10-04 18:29:40 +02:00
ampache/server/ajax.server.php

357 lines
13 KiB
PHP

<?php
/* vim:set softtabstop=4 shiftwidth=4 expandtab: */
/**
*
* LICENSE: GNU General Public License, version 2 (GPLv2)
* Copyright 2001 - 2013 Ampache.org
*
* 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.
*
*/
/* Because this is accessed via Ajax we are going to allow the session_id
* as part of the get request
*/
// Set that this is an ajax include
define('AJAX_INCLUDE','1');
require_once '../lib/init.php';
xoutput_headers();
$page = isset($_REQUEST['page']) ? $_REQUEST['page'] : null;
debug_event('ajax.server.php', 'Called for page: {'.$page.'}', '5');
switch ($page) {
case 'stats':
require_once AmpConfig::get('prefix') . '/server/stats.ajax.php';
exit;
break;
case 'browse':
require_once AmpConfig::get('prefix') . '/server/browse.ajax.php';
exit;
break;
case 'random':
require_once AmpConfig::get('prefix') . '/server/random.ajax.php';
exit;
break;
case 'playlist':
require_once AmpConfig::get('prefix') . '/server/playlist.ajax.php';
exit;
break;
case 'localplay':
require_once AmpConfig::get('prefix') . '/server/localplay.ajax.php';
exit;
break;
case 'tag':
require_once AmpConfig::get('prefix') . '/server/tag.ajax.php';
exit;
break;
case 'stream':
require_once AmpConfig::get('prefix') . '/server/stream.ajax.php';
exit;
break;
case 'song':
require_once AmpConfig::get('prefix') . '/server/song.ajax.php';
exit;
break;
case 'democratic':
require_once AmpConfig::get('prefix') . '/server/democratic.ajax.php';
exit;
break;
case 'index':
require_once AmpConfig::get('prefix') . '/server/index.ajax.php';
exit;
case 'catalog':
require_once AmpConfig::get('prefix') . '/server/catalog.ajax.php';
exit;
break;
case 'search':
require_once AmpConfig::get('prefix') . '/server/search.ajax.php';
exit;
break;
case 'player':
require_once AmpConfig::get('prefix') . '/server/player.ajax.php';
exit;
break;
default:
// A taste of compatibility
break;
} // end switch on page
switch ($_REQUEST['action']) {
case 'refresh_rightbar':
$results['rightbar'] = UI::ajax_include('rightbar.inc.php');
break;
/* Controls the editing of objects */
case 'edit_object':
debug_event('ajax_server', "Editing object...", '5');
// Scrub the data
foreach ($_POST as $key => $data) {
$_POST[$key] = unhtmlentities(scrub_in($data));
debug_event('ajax_server', $key.'='.$_POST[$key], '5');
}
$level = '50';
if ($_POST['type'] == 'playlist_row' || $_POST['type'] == 'playlist_title') {
$playlist = new Playlist($_POST['id']);
if ($GLOBALS['user']->id == $playlist->user) {
$level = '25';
}
}
if ($_POST['type'] == 'smartplaylist_row' ||
$_POST['type'] == 'smartplaylist_title') {
$playlist = new Search('song', $_POST['id']);
if ($GLOBALS['user']->id == $playlist->user) {
$level = '25';
}
}
// Make sure we've got them rights
if (!Access::check('interface', $level) || AmpConfig::get('demo_mode')) {
$results['rfc3514'] = '0x1';
break;
}
$new_id = '';
switch ($_POST['type']) {
case 'album_row':
$key = 'album_' . $_POST['id'];
$album = new Album($_POST['id']);
$songs = $album->get_songs();
$new_id = $album->update($_POST);
if ($new_id != $_POST['id']) {
$album = new Album($new_id);
}
$album->format();
break;
case 'artist_row':
$key = 'artist_' . $_POST['id'];
$artist = new Artist($_POST['id']);
$songs = $artist->get_songs();
$new_id = $artist->update($_POST);
if ($new_id != $_POST['id']) {
$artist = new Artist($new_id);
}
$artist->format();
break;
case 'song_row':
$key = 'song_' . $_POST['id'];
$song = new Song($_POST['id']);
$song->update($_POST);
$song->format();
break;
case 'playlist_row':
case 'playlist_title':
$key = 'playlist_row_' . $_POST['id'];
$playlist->update($_POST);
$playlist->format();
$count = $playlist->get_song_count();
break;
case 'smartplaylist_row':
case 'smartplaylist_title':
$key = 'smartplaylist_row_' . $_POST['id'];
$playlist->name = $_POST['name'];
$playlist->type = $_POST['pl_type'];
$playlist->update();
$playlist->format();
break;
case 'live_stream_row':
$key = 'live_stream_' . $_POST['id'];
Radio::update($_POST);
$radio = new Radio($_POST['id']);
$radio->format();
break;
case 'channel_row':
$key = 'channel_row_' . $_POST['id'];
$channel = new Channel($_POST['id']);
$channel->update($_POST);
break;
case 'broadcast_row':
$key = 'broadcast_row_' . $_POST['id'];
$broadcast = new Broadcast($_POST['id']);
$broadcast->update($_POST);
break;
case 'tag_row':
$tag = new Tag($_POST['id']);
$tag->update($_POST['name']);
break;
default:
$key = 'rfc3514';
echo xoutput_from_array(array($key=>'0x1'));
exit;
break;
} // end switch on type
$results['id'] = $new_id;
break;
case 'current_playlist':
switch ($_REQUEST['type']) {
case 'delete':
$GLOBALS['user']->playlist->delete_track($_REQUEST['id']);
break;
} // end switch
$results['rightbar'] = UI::ajax_include('rightbar.inc.php');
break;
// Handle the users basketcases...
case 'basket':
switch ($_REQUEST['type']) {
case 'album':
foreach ($_REQUEST['id'] as $i) {
$object = new $_REQUEST['type']($i);
$songs = $object->get_songs();
foreach ($songs as $song_id) {
$GLOBALS['user']->playlist->add_object($song_id, 'song');
}
}
break;
case 'artist':
case 'tag':
$object = new $_REQUEST['type']($_REQUEST['id']);
$songs = $object->get_songs();
foreach ($songs as $song_id) {
$GLOBALS['user']->playlist->add_object($song_id,'song');
}
break;
case 'browse_set':
$browse = new Browse($_REQUEST['browse_id']);
$objects = $browse->get_saved();
foreach ($objects as $object_id) {
$GLOBALS['user']->playlist->add_object($object_id,'song');
}
break;
case 'album_random':
$data = explode('_',$_REQUEST['type']);
$type = $data['0'];
foreach ($_REQUEST['id'] as $i) {
$object = new $type($i);
$songs = $object->get_random_songs();
foreach ($songs as $song_id) {
$GLOBALS['user']->playlist->add_object($song_id, 'song');
}
}
break;
case 'artist_random':
case 'tag_random':
$data = explode('_',$_REQUEST['type']);
$type = $data['0'];
$object = new $type($_REQUEST['id']);
$songs = $object->get_random_songs();
foreach ($songs as $song_id) {
$GLOBALS['user']->playlist->add_object($song_id,'song');
}
break;
case 'playlist':
$playlist = new Playlist($_REQUEST['id']);
$items = $playlist->get_items();
foreach ($items as $item) {
$GLOBALS['user']->playlist->add_object($item['object_id'], $item['object_type']);
}
break;
case 'playlist_random':
$playlist = new Playlist($_REQUEST['id']);
$items = $playlist->get_random_items();
foreach ($items as $item) {
$GLOBALS['user']->playlist->add_object($item['object_id'], $item['object_type']);
}
break;
case 'smartplaylist':
$playlist = new Search('song', $_REQUEST['id']);
$items = $playlist->get_items();
foreach ($items as $item) {
$GLOBALS['user']->playlist->add_object($item['object_id'],$item['object_type']);
}
break;
case 'clear_all':
$GLOBALS['user']->playlist->clear();
break;
case 'live_stream':
$object = new Radio($_REQUEST['id']);
// Confirm its a valid ID
if ($object->name) {
$GLOBALS['user']->playlist->add_object($object->id,'radio');
}
break;
case 'dynamic':
$random_id = Random::get_type_id($_REQUEST['random_type']);
$GLOBALS['user']->playlist->add_object($random_id,'random');
break;
case 'video':
$GLOBALS['user']->playlist->add_object($_REQUEST['id'],'video');
break;
case 'album_preview':
$songs = Song_preview::get_song_previews($_REQUEST['mbid']);
foreach ($songs as $song) {
if (!empty($song->file)) {
$GLOBALS['user']->playlist->add_object($song->id, 'song_preview');
}
}
break;
case 'song_preview':
$GLOBALS['user']->playlist->add_object($_REQUEST['id'],'song_preview');
break;
case 'song':
default:
$GLOBALS['user']->playlist->add_object($_REQUEST['id'],'song');
break;
} // end switch
$results['rightbar'] = UI::ajax_include('rightbar.inc.php');
break;
/* Setting ratings */
case 'set_rating':
ob_start();
$rating = new Rating($_GET['object_id'], $_GET['rating_type']);
$rating->set_rating($_GET['rating']);
Rating::show($_GET['object_id'], $_GET['rating_type']);
$key = "rating_" . $_GET['object_id'] . "_" . $_GET['rating_type'];
$results[$key] = ob_get_contents();
ob_end_clean();
break;
/* Setting userflags */
case 'set_userflag':
ob_start();
$userflag = new Userflag($_GET['object_id'], $_GET['userflag_type']);
$userflag->set_flag($_GET['userflag']);
Userflag::show($_GET['object_id'], $_GET['userflag_type']);
$key = "userflag_" . $_GET['object_id'] . "_" . $_GET['userflag_type'];
$results[$key] = ob_get_contents();
ob_end_clean();
break;
case 'action_buttons':
ob_start();
if (AmpConfig::get('ratings')) {
echo " <div id='rating_" . $_GET['object_id'] . "_" . $_GET['object_type'] . "'>";
Rating::show($_GET['object_id'], $_GET['object_type']);
echo "</div> |";
}
if (AmpConfig::get('userflags')) {
echo " <div id='userflag_" . $_GET['object_id'] . "_" . $_GET['object_type'] . "'>";
Userflag::show($_GET['object_id'], $_GET['object_type']);
echo "</div>";
}
$results['action_buttons'] = ob_get_contents();
ob_end_clean();
break;
default:
$results['rfc3514'] = '0x1';
break;
} // end switch action
// Go ahead and do the echo
echo xoutput_from_array($results);