summaryrefslogtreecommitdiffstats
path: root/lib/class/tmp_playlist.class.php
diff options
context:
space:
mode:
authorPaul Arthur <paul.arthur@flowerysong.com>2013-01-25 21:47:39 -0500
committerPaul Arthur <paul.arthur@flowerysong.com>2013-01-25 21:48:51 -0500
commit57483216e47f46a74590fe98dea6dc36b1312b5a (patch)
tree3c5ea89e567fb2532632eea1016039720c7165d8 /lib/class/tmp_playlist.class.php
parent1069d54c85149ff1cb51563d6a1fc471695f8b47 (diff)
downloadampache-57483216e47f46a74590fe98dea6dc36b1312b5a.tar.gz
ampache-57483216e47f46a74590fe98dea6dc36b1312b5a.tar.bz2
ampache-57483216e47f46a74590fe98dea6dc36b1312b5a.zip
Rename tmpPlaylist to Tmp_Playlist
Diffstat (limited to 'lib/class/tmp_playlist.class.php')
-rw-r--r--lib/class/tmp_playlist.class.php374
1 files changed, 374 insertions, 0 deletions
diff --git a/lib/class/tmp_playlist.class.php b/lib/class/tmp_playlist.class.php
new file mode 100644
index 00000000..129a8d1a
--- /dev/null
+++ b/lib/class/tmp_playlist.class.php
@@ -0,0 +1,374 @@
+<?php
+/* vim:set tabstop=8 softtabstop=8 shiftwidth=8 noexpandtab: */
+/**
+ *
+ * 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.
+ *
+ */
+
+/**
+ * TempPlaylist Class
+ *
+ * This class handles the temporary playlists in Ampache. It handles the
+ * tmp_playlist and tmp_playlist_data tables, and sneaks out at night to
+ * visit user_vote from time to time.
+ *
+ */
+class Tmp_Playlist extends database_object {
+
+ /* Variables from the Datbase */
+ public $id;
+ public $session;
+ public $type;
+ public $object_type;
+ public $base_playlist;
+
+ /* Generated Elements */
+ public $items = array();
+
+ /**
+ * Constructor
+ * This takes a playlist_id as an optional argument and gathers the
+ * information. If no playlist_id is passed or the requested one isn't
+ * found, return false.
+ */
+ public function __construct($playlist_id='') {
+
+ if (!$playlist_id) { return false; }
+
+ $this->id = intval($playlist_id);
+ $info = $this->_get_info();
+
+ foreach ($info as $key=>$value) {
+ $this->$key = $value;
+ }
+
+ return true;
+
+ } // __construct
+
+ /**
+ * _get_info
+ * This is an internal (private) function that gathers the information
+ * for this object from the playlist_id that was passed in.
+ */
+ private function _get_info() {
+
+ $sql = "SELECT * FROM `tmp_playlist` WHERE `id`='" . Dba::escape($this->id) . "'";
+ $db_results = Dba::read($sql);
+
+ $results = Dba::fetch_assoc($db_results);
+
+ return $results;
+
+ } // _get_info
+
+ /**
+ * get_from_session
+ * This returns a playlist object based on the session that is passed to
+ * us. This is used by the load_playlist on user for the most part.
+ */
+ public static function get_from_session($session_id) {
+
+ $session_id = Dba::escape($session_id);
+
+ $sql = "SELECT `id` FROM `tmp_playlist` WHERE `session`='$session_id'";
+ $db_results = Dba::read($sql);
+
+ $results = Dba::fetch_row($db_results);
+
+ if (!$results['0']) {
+ $results['0'] = Tmp_Playlist::create(array(
+ 'session_id' => $session_id,
+ 'type' => 'user',
+ 'object_type' => 'song'
+ ));
+ }
+
+ $playlist = new Tmp_Playlist($results['0']);
+
+ return $playlist;
+
+ } // get_from_session
+
+ /**
+ * get_from_userid
+ * This returns a tmp playlist object based on a userid passed
+ * this is used for the user profiles page
+ */
+ public static function get_from_userid($user_id) {
+
+ // This is a little stupid, but because we don't have the
+ // user_id in the session or in the tmp_playlist table we have
+ // to do it this way.
+ $client = new User($user_id);
+ $username = Dba::escape($client->username);
+
+ $sql = "SELECT `tmp_playlist`.`id` FROM `tmp_playlist` " .
+ "LEFT JOIN `session` ON " .
+ "`session`.`id`=`tmp_playlist`.`session` " .
+ "WHERE `session`.`username`='$username' " .
+ "ORDER BY `session`.`expire` DESC";
+ $db_results = Dba::read($sql);
+
+ $data = Dba::fetch_assoc($db_results);
+
+ return $data['id'];
+
+ } // get_from_userid
+
+ /**
+ * get_items
+ * Returns an array of all object_ids currently in this Tmp_Playlist.
+ */
+ public function get_items() {
+
+ $id = Dba::escape($this->id);
+
+ /* Select all objects from this playlist */
+ $sql = "SELECT `object_type`, `id`, `object_id` " .
+ "FROM `tmp_playlist_data` " .
+ "WHERE `tmp_playlist`='$id' ORDER BY `id` ASC";
+ $db_results = Dba::read($sql);
+
+ /* Define the array */
+ $items = array();
+
+ while ($results = Dba::fetch_assoc($db_results)) {
+ $key = $results['id'];
+ $items[$key] = array(
+ 'object_type' => $results['object_type'],
+ 'object_id' => $results['object_id']
+ );
+ }
+
+ return $items;
+
+ } // get_items
+
+ /**
+ * get_next_object
+ * This returns the next object in the tmp_playlist.
+ */
+ public function get_next_object() {
+
+ $id = Dba::escape($this->id);
+
+ $sql = "SELECT `object_id` FROM `tmp_playlist_data` " .
+ "WHERE `tmp_playlist`='$id' ORDER BY `id` LIMIT 1";
+ $db_results = Dba::read($sql);
+
+ $results = Dba::fetch_assoc($db_results);
+
+ return $results['object_id'];
+
+ } // get_next_object
+
+ /**
+ * count_items
+ * This returns a count of the total number of tracks that are in this
+ * tmp playlist
+ */
+ public function count_items() {
+
+ $id = Dba::escape($this->id);
+
+ $sql = "SELECT COUNT(`id`) FROM `tmp_playlist_data` WHERE " .
+ "`tmp_playlist`='$id'";
+ $db_results = Dba::read($sql);
+
+ $results = Dba::fetch_row($db_results);
+
+ return $results['0'];
+
+ } // count_items
+
+ /**
+ * clear
+ * This clears all the objects out of a single playlist
+ */
+ public function clear() {
+
+ $id = Dba::escape($this->id);
+
+ $sql = "DELETE FROM `tmp_playlist_data` WHERE " .
+ "`tmp_playlist`='$id'";
+ $db_results = Dba::write($sql);
+
+ return true;
+
+ } // clear
+
+ /**
+ * create
+ * This function initializes a new Tmp_Playlist. It is associated with
+ * the current session rather than a user, as you could have the same
+ * user logged in from multiple locations.
+ */
+ public static function create($data) {
+
+ $sessid = Dba::escape($data['session_id']);
+ $type = Dba::escape($data['type']);
+ $object_type = Dba::escape($data['object_type']);
+
+ $sql = "INSERT INTO `tmp_playlist` " .
+ "(`session`,`type`,`object_type`) " .
+ " VALUES ('$sessid','$type','$object_type')";
+ $db_results = Dba::write($sql);
+
+ $id = Dba::insert_id();
+
+ /* Clean any other playlists associated with this session */
+ self::session_clean($sessid, $id);
+
+ return $id;
+
+ } // create
+
+ /**
+ * update_playlist
+ * This updates the base_playlist on this tmp_playlist
+ */
+ public function update_playlist($playlist_id) {
+
+ $playlist_id = Dba::escape($playlist_id);
+ $id = Dba::escape($this->id);
+
+ $sql = "UPDATE `tmp_playlist` SET " .
+ "`base_playlist`='$playlist_id' WHERE `id`='$id'";
+ $db_results = Dba::write($sql);
+
+ return true;
+
+ } // update_playlist
+
+ /**
+ * session_clean
+ * This deletes any other tmp_playlists associated with this
+ * session
+ */
+ public static function session_clean($sessid, $id) {
+
+ $sessid = Dba::escape($sessid);
+ $id = Dba::escape($id);
+
+ $sql = "DELETE FROM `tmp_playlist` WHERE `session`='$sessid' " .
+ "AND `id` != '$id'";
+ $db_results = Dba::write($sql);
+
+ /* Remove associated tracks */
+ self::prune_tracks();
+
+ return true;
+
+ } // session_clean
+
+ /**
+ * gc
+ * This cleans up old data
+ */
+ public static function gc() {
+ self::prune_playlists();
+ self::prune_tracks();
+ Dba::write("DELETE FROM `tmp_playlist_data` USING `tmp_playlist_data` LEFT JOIN `song` ON `tmp_playlist_data`.`object_id` = `song`.`id` WHERE `song`.`id` IS NULL");
+ }
+
+ /**
+ * prune_playlists
+ * This deletes any playlists that don't have an associated session
+ */
+ public static function prune_playlists() {
+
+ /* Just delete if no matching session row */
+ $sql = "DELETE FROM `tmp_playlist` USING `tmp_playlist` " .
+ "LEFT JOIN `session` " .
+ "ON `session`.`id`=`tmp_playlist`.`session` " .
+ "WHERE `session`.`id` IS NULL " .
+ "AND `tmp_playlist`.`type` != 'vote'";
+ $db_results = Dba::write($sql);
+
+ return true;
+
+ } // prune_playlists
+
+ /**
+ * prune_tracks
+ * This prunes tracks that don't have playlists or don't have votes
+ */
+ public static function prune_tracks() {
+
+ // This prune is always run and clears data for playlists that
+ // don't exist anymore
+ $sql = "DELETE FROM `tmp_playlist_data` USING " .
+ "`tmp_playlist_data` LEFT JOIN `tmp_playlist` ON " .
+ "`tmp_playlist_data`.`tmp_playlist`=`tmp_playlist`.`id` " .
+ "WHERE `tmp_playlist`.`id` IS NULL";
+ $db_results = Dba::write($sql);
+
+ } // prune_tracks
+
+ /**
+ * add_object
+ * This adds the object of $this->object_type to this tmp playlist
+ * it takes an optional type, default is song
+ */
+ public function add_object($object_id,$object_type) {
+
+ $object_id = Dba::escape($object_id);
+ $playlist_id = Dba::escape($this->id);
+ $object_type = $object_type ? Dba::escape($object_type) : 'song';
+
+ $sql = "INSERT INTO `tmp_playlist_data` " .
+ "(`object_id`,`tmp_playlist`,`object_type`) " .
+ " VALUES ('$object_id','$playlist_id','$object_type')";
+ $db_results = Dba::write($sql);
+
+ return true;
+
+ } // add_object
+
+ /**
+ * vote_active
+ * This checks to see if this playlist is a voting playlist
+ * and if it is active
+ */
+ public function vote_active() {
+
+ /* Going to do a little more here later */
+ if ($this->type == 'vote') { return true; }
+
+ return false;
+
+ } // vote_active
+
+ /**
+ * delete_track
+ * This deletes a track from the tmpplaylist
+ */
+ public function delete_track($id) {
+
+ $id = Dba::escape($id);
+
+ /* delete the track its self */
+ $sql = "DELETE FROM `tmp_playlist_data` WHERE `id`='$id'";
+ $db_results = Dba::write($sql);
+
+ return true;
+
+ } // delete_track
+
+} // class Tmp_Playlist