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

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
?>