gunid removed from delAudioClipFromPlaylist too, deleted audioClip is

identified by local ID.
This commit is contained in:
tomas 2005-02-19 01:05:44 +00:00
parent 570ff5b626
commit 179d3a39c5
1 changed files with 17 additions and 13 deletions

View File

@ -23,7 +23,7 @@
Author : $Author: tomas $ Author : $Author: tomas $
Version : $Revision: 1.38 $ Version : $Revision: 1.39 $
Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/storageServer/var/GreenBox.php,v $ Location : $Source: /home/paul/cvs2svn-livesupport/newcvsrepo/livesupport/modules/storageServer/var/GreenBox.php,v $
------------------------------------------------------------------------------*/ ------------------------------------------------------------------------------*/
@ -35,7 +35,7 @@ require_once "BasicStor.php";
* LiveSupport file storage module * LiveSupport file storage module
* *
* @author $Author: tomas $ * @author $Author: tomas $
* @version $Revision: 1.38 $ * @version $Revision: 1.39 $
* @see BasicStor * @see BasicStor
*/ */
class GreenBox extends BasicStor{ class GreenBox extends BasicStor{
@ -576,12 +576,14 @@ class GreenBox extends BasicStor{
* Remove audioclip from playlist * Remove audioclip from playlist
* *
* @param token string, playlist access token * @param token string, playlist access token
* @param plElGunid string, global unique ID of deleted playlistElement * @param acId int, local id of deleted audioClip
* @param sessid string, session ID * @param sessid string, session ID
* @return boolean * @return boolean
*/ */
function delAudioClipFromPlaylist($token, $plElGunid, $sessid) function delAudioClipFromPlaylist($token, $acId, $sessid)
{ {
$acGunid = $this->_gunidFromId($acId);
if(PEAR::isError($acGunid)) return $acGunid;
$plGunid = $this->_gunidFromToken($token, 'download'); $plGunid = $this->_gunidFromToken($token, 'download');
if(PEAR::isError($plGunid)) return $plGunid; if(PEAR::isError($plGunid)) return $plGunid;
if(is_null($plGunid)){ if(is_null($plGunid)){
@ -612,16 +614,17 @@ class GreenBox extends BasicStor{
if(PEAR::isError($plElArr)){ return $plElArr; } if(PEAR::isError($plElArr)){ return $plElArr; }
$found = FALSE; $found = FALSE;
foreach($plElArr as $el){ foreach($plElArr as $el){
$plElGunidArr = $pl->md->getMetadataEl('id', $el['mid']); $acArr = $pl->md->getMetadataEl('audioClip', $el['mid']);
if(PEAR::isError($plElGunidArr)){ return $plElGunidArr; } if(PEAR::isError($acArr)){ return $acArr; }
$storedAcMid = $acArr[0]['mid'];
$acGunidArr = $pl->md->getMetadataEl('id', $storedAcMid);
if(PEAR::isError($acGunidArr)){ return $acGunidArr; }
// select playlist element to remove // select playlist element to remove
if($plElGunidArr[0]['value'] == $plElGunid){ if($acGunidArr[0]['value'] == $acGunid){
$acArr = $pl->md->getMetadataEl('audioClip', $el['mid']); $acLenArr = $pl->md->getMetadataEl('playlength', $storedAcMid);
if(PEAR::isError($acArr)){ return $acArr; }
$acLenArr = $pl->md->getMetadataEl('playlength', $acArr[0]['mid']);
if(PEAR::isError($acLenArr)){ return $acLenArr; } if(PEAR::isError($acLenArr)){ return $acLenArr; }
$acLen = $acLenArr[0]['value']; $acLen = $acLenArr[0]['value'];
$acTokArr = $pl->md->getMetadataEl('accessToken', $acArr[0]['mid']); $acTokArr = $pl->md->getMetadataEl('accessToken', $storedAcMid);
if(PEAR::isError($acTokArr)){ return $acTokArr; } if(PEAR::isError($acTokArr)){ return $acTokArr; }
$acToken = $acTokArr[0]['value']; $acToken = $acTokArr[0]['value'];
// remove playlist element: // remove playlist element:
@ -880,11 +883,12 @@ class GreenBox extends BasicStor{
} }
/** /**
* Check if file exists in the storage and * Check if file gunid exists in the storage and
* user have permission to read it * user have permission to read it
* *
* @param sessid string, session id
* @param gunid string * @param gunid string
* @param ftype string, internal file type * @param ftype string, internal file type, optional
* @return string/err * @return string/err
*/ */
function existsFile($sessid, $gunid, $ftype=NULL) function existsFile($sessid, $gunid, $ftype=NULL)