diff options
author | Karl 'vollmerk' Vollmer <vollmer@ampache.org> | 2007-07-24 04:10:58 +0000 |
---|---|---|
committer | Karl 'vollmerk' Vollmer <vollmer@ampache.org> | 2007-07-24 04:10:58 +0000 |
commit | a74d0b7163c8755e23598997c364bc75a18f943e (patch) | |
tree | c1ad6ca02907d18b78542e79e557e93901afadf7 /lib/class | |
parent | 0f9c1f245c35e533171cda4b433718f24ca8a707 (diff) | |
download | ampache-a74d0b7163c8755e23598997c364bc75a18f943e.tar.gz ampache-a74d0b7163c8755e23598997c364bc75a18f943e.tar.bz2 ampache-a74d0b7163c8755e23598997c364bc75a18f943e.zip |
added dynamic playlist item support, default and genre currently work
Diffstat (limited to 'lib/class')
-rw-r--r-- | lib/class/random.class.php | 169 | ||||
-rw-r--r-- | lib/class/stream.class.php | 22 | ||||
-rw-r--r-- | lib/class/user.class.php | 23 |
3 files changed, 210 insertions, 4 deletions
diff --git a/lib/class/random.class.php b/lib/class/random.class.php new file mode 100644 index 00000000..0a72fdf6 --- /dev/null +++ b/lib/class/random.class.php @@ -0,0 +1,169 @@ +<?php +/* + + Copyright 2001 - 2007 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; version 2 + of the License. + + 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. + +*/ + +/** + * Random Class + * All of the 'random' type events, elements, voodoo done by ampache is done + * by this class, there isn't a table for this class so most of it's functions + * are static + */ +class Random { + + /** + * Constructor + * nothing to see here, move along + */ + private function __construct($id) { + + // Rien a faire + + } // constructor + + /** + * play_url + * This generates a random play url based on the passed type + * and returns it + */ + public static function play_url($type) { + + if (!$type = self::validate_type($type)) { + return false; + } + + if (Config::get('require_session')) { + $session_string = '&sid=' . session_id(); + } + + $web_path = Config::get('web_path'); + + if (Config::get('force_http_play') OR !empty($force_http)) { + $port = Config::get('http_port'); + if (preg_match("/:\d+/",$web_path)) { + $web_path = str_replace("https://", "http://",$web_path); + } + else { + $web_path = str_replace("https://", "http://",$web_path); + } + } + + $uid = $GLOBALS['user']->id; + + $url = $web_path . "/play/index.php?random=1&type=$type&uid=$uid$session_string"; + + return $url; + + } // play_url + + /** + * get_single_song + * This returns a single song pulled based on the passed random method + */ + public static function get_single_song($type) { + + if (!$type = self::validate_type($type)) { + return false; + } + + $method_name = 'get_' . $type; + + if (method_exists('Random',$method_name)) { + $song_ids = self::$method_name(1); + $song_id = array_pop($song_ids); + } + + return $song_id; + + } // get_single_song + + /** + * get_default + * This just randomly picks a song at whim from all catalogs + * nothing special here... + */ + public static function get_default($limit) { + + $results = array(); + + $sql = "SELECT `id` FROM `song` ORDER BY RAND() LIMIT $limit"; + $db_results = Dba::query($sql); + + while ($row = Dba::fetch_assoc($db_results)) { + $results[] = $row['id']; + } + + return $results; + + } // get_default + + /** + * get_genre + * This looks at the last object played by the current user and + * then picks a song of the same genre at random... + */ + public static function get_genre($limit) { + + $results = array(); + + // Get the last genre played by us + $data = $GLOBALS['user']->get_recently_played('1','genre'); + if ($data['0']) { + $where_sql = " WHERE `genre`='" . $data['0'] . "' "; + } + + $sql = "SELECT `id` FROM `song` $where_sql ORDER BY RAND() LIMIT $limit"; + $db_results = Dba::query($sql); + + while ($row = Dba::fetch_assoc($db_results)) { + $results[] = $row['id']; + } + + return $results; + + } // get_genre + + /** + * validiate_type + * this validates the random type, this is a private function + */ + private static function validate_type($type) { + + switch ($type) { + case 'special': + $type = $GLOBALS['user']->prefs['random_method']; + break; + case 'genre': + case 'album': + case 'artist': + case 'rated': + break; + default: + return false; + break; + } // end switch + + return $type; + + } // validate_type + +} //end of random class + +?> diff --git a/lib/class/stream.class.php b/lib/class/stream.class.php index cbfd026d..2f5c4aee 100644 --- a/lib/class/stream.class.php +++ b/lib/class/stream.class.php @@ -103,13 +103,21 @@ class Stream { header("Content-Disposition: filename=playlist.m3u"); header("Content-Type: audio/x-mpegurl;"); + // Flip for the poping! + asort($this->urls); + /* Foreach songs */ foreach ($this->songs as $song_id) { + // If it's a place-holder + if ($song_id == '-1') { + echo array_pop($this->urls) . "\n"; + continue; + } $song = new Song($song_id); if ($song->type == ".flac") { $song->type = ".ogg"; } - if($GLOBALS['user']->prefs['play_type'] == 'downsample') { - $ds = $GLOBALS['user']->prefs['sample_rate']; - } + if ($GLOBALS['user']->prefs['play_type'] == 'downsample') { + $ds = $GLOBALS['user']->prefs['sample_rate']; + } echo "$this->web_path/play/index.php?song=$song_id&uid=$this->user_id&sid=$this->sess&ds=$ds&stupidwinamp=." . $song->type . "\n"; } // end foreach @@ -133,8 +141,16 @@ class Stream { header("Content-Type: audio/x-mpegurl;"); echo "#EXTM3U\n"; + // Flip for the popping + asort($this->urls); + // Foreach the songs in this stream object foreach ($this->songs as $song_id) { + if ($song_id == '-1') { + echo "#EXTINF: URL-Add\n"; + echo array_pop($this->urls) . "\n"; + continue; + } $song = new Song($song_id); $song->format(); diff --git a/lib/class/user.class.php b/lib/class/user.class.php index d6c6ae69..7d76e059 100644 --- a/lib/class/user.class.php +++ b/lib/class/user.class.php @@ -929,6 +929,27 @@ class User { } // get_user_validation /** + * get_recently_played + * This gets the recently played items for this user respecting + * the limit passed + */ + public function get_recently_played($limit,$type='') { + + if (!$type) { $type = 'song'; } + + $sql = "SELECT * FROM `object_count` WHERE `object_type`='$type' AND `user`='$this->id' " . + "ORDER BY `date` DESC LIMIT $limit"; + $db_results = Dba::query($sql); + + while ($row = Dba::fetch_assoc($db_results)) { + $results[] = $row['object_id']; + } + + return $results; + + } // get_recently_played + + /** * get_recent * This returns users by thier last login date */ @@ -1005,7 +1026,7 @@ class User { function is_xmlrpc() { /* If we aren't using XML-RPC return true */ - if (!conf('xml_rpc')) { + if (!Config::get('xml_rpc')) { return false; } |