mirror of
https://github.com/Yetangitu/ampache
synced 2025-10-04 18:29:40 +02:00
137 lines
3.8 KiB
PHP
137 lines
3.8 KiB
PHP
<?php
|
|
/*
|
|
|
|
Copyright (c) 2001 - 2006 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
|
|
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.
|
|
|
|
*/
|
|
|
|
/**
|
|
* This is accessed remotly to allow outside scripts access to ampache information
|
|
* as such it needs to verify the session id that is passed
|
|
*/
|
|
|
|
define('NO_SESSION','1');
|
|
require_once('../lib/init.php');
|
|
|
|
/**
|
|
* Verify the existance of the Session they passed in we do allow them to
|
|
* login via this interface so we do have an exception for action=login
|
|
*/
|
|
if (!session_exists($_REQUEST['sessid']) AND $_REQUEST['action'] !== 'login') { exit(); }
|
|
|
|
$GLOBALS['user'] = new User($_REQUEST['user_id']);
|
|
$action = scrub_in($_REQUEST['action']);
|
|
|
|
/* Set the correct headers */
|
|
header("Content-type: text/xml; charset=utf-8");
|
|
|
|
switch ($action) {
|
|
/* Returns an array of artist information */
|
|
case 'get_artists':
|
|
$sql = "SELECT id FROM artist ORDER BY name";
|
|
$db_results = mysql_query($sql,dbh());
|
|
|
|
while ($r = mysql_fetch_assoc($db_results)) {
|
|
$artist = new Artist($r['id']);
|
|
$artist->format_artist();
|
|
$results[] = array('id'=>$artist->id,'name'=>$artist->full_name);
|
|
} // end while results
|
|
|
|
$xml_doc = xml_from_array($results);
|
|
echo $xml_doc;
|
|
break;
|
|
case 'get_albums':
|
|
$sql = "SELECT id FROM album ORDER BY name";
|
|
$db_results = mysql_query($sql,dbh());
|
|
|
|
while ($r = mysql_fetch_assoc($db_results)) {
|
|
$album = new Album($r['id']);
|
|
$results[] = array('id'=>$r['id'],'year'=>$album->year,'name'=>$album->name);
|
|
} // end while results
|
|
|
|
$xml_doc = xml_from_array($results);
|
|
echo $xml_doc;
|
|
break;
|
|
case 'get_genres':
|
|
$sql = "SELECT id FROM genre ORDER BY name";
|
|
$db_results = mysql_query($sql,dbh());
|
|
|
|
while ($r = mysql_fetch_assoc($db_results)) {
|
|
$genre = new Genre($r['id']);
|
|
$results[] = array('id'=>$r['id'],'name'=>$genre->name);
|
|
}
|
|
|
|
$xml_doc = xml_from_array($results);
|
|
echo $xml_doc;
|
|
break;
|
|
/* Return results of a quick search */
|
|
case 'search':
|
|
/* We need search string */
|
|
$_REQUEST['s_all'] = $_REQUEST['search_string'];
|
|
if (strlen($_REQUEST['s_all']) < 1) { break; }
|
|
$data = run_search($_REQUEST);
|
|
|
|
/* Unfortuantly these are song objects, which are not good for
|
|
* xml.. turn it into an array
|
|
*/
|
|
foreach ($data as $song) {
|
|
$genre = $song->get_genre_name();
|
|
$artist = $song->get_artist_name();
|
|
$album = $song->get_album_name();
|
|
$results[] = array('id'=>$song->id,
|
|
'title'=>$song->title,
|
|
'genre'=>$genre,
|
|
'artist'=>$artist,
|
|
'album'=>$album);
|
|
} // end foreach song
|
|
|
|
$xml_doc = xml_from_array($results);
|
|
echo $xml_doc;
|
|
|
|
break;
|
|
/* This takes a object_id/object_type and returns the correct PLAY url for it */
|
|
case 'play_url':
|
|
/* We need the type and id */
|
|
$object_type = scrub_in($_REQUEST['object_type']);
|
|
$object_id = scrub_in($_REQUEST['object_id']);
|
|
|
|
switch ($object_type) {
|
|
case 'song':
|
|
$song = new Song($object_id);
|
|
$url = $song->get_url($_REQUEST['sessid']);
|
|
$results[] = $url;
|
|
break;
|
|
default:
|
|
// Rien a faire
|
|
break;
|
|
} // end switch on object_type
|
|
|
|
$xml_doc = xml_from_array($results);
|
|
echo $xml_doc;
|
|
|
|
break;
|
|
/* This allows you to login via the xml mojo */
|
|
case 'login':
|
|
|
|
|
|
break;
|
|
default:
|
|
// Rien a faire
|
|
break;
|
|
} // end switch action
|
|
?>
|