_helper->getHelper('AjaxContext'); $ajaxContext->addActionContext('new', 'json') ->addActionContext('save', 'json') ->addActionContext('edit', 'json') ->addActionContext('delete', 'json') ->initContext(); //TODO //$this->pl_sess = new Zend_Session_Namespace(UI_PLAYLIST_SESSNAME); } public function newAction() { $webstream = new CcWebstream(); //we're not saving this primary key in the DB so it's OK $webstream->setDbId(-1); $webstream->setDbName("Untitled Webstream"); $webstream->setDbDescription(""); $webstream->setDbUrl("http://"); $webstream->setDbLength("00:00:00"); $webstream->setDbName("Untitled Webstream"); Application_Model_Library::changePlaylist($obj->getId(), $type); $this->view->ws = new Application_Model_Webstream($webstream); $this->view->action = "new"; $this->view->html = $this->view->render('webstream/webstream.phtml'); } public function editAction() { $request = $this->getRequest(); $id = $request->getParam("id"); if (is_null($id)) { throw new Exception("Missing parameter 'id'"); } $webstream = CcWebstreamQuery::create()->findPK($id); $this->view->ws = new Application_Model_Webstream($webstream); $this->view->action = "edit"; $this->view->html = $this->view->render('webstream/webstream.phtml'); } public function deleteAction() { $request = $this->getRequest(); $id = $request->getParam("ids"); if (!$this->isAuthorized($id)) { header("Status: 401 Not Authorized"); return; } $type = "stream"; Application_Model_Library::changePlaylist(null, $type); $webstream = CcWebstreamQuery::create()->findPK($id)->delete(); $this->view->ws = null; $this->view->action = "delete"; $this->view->html = $this->view->render('webstream/webstream.phtml'); } public function isAuthorized($id) { $hasPermission = false; if ($user->isUserType(array(UTYPE_ADMIN, UTYPE_PROGRAM_MANAGER))) { $hasPermission = true; } if ($user->isUserType(UTYPE_HOST)) { if ($id != -1) { $webstream = CcWebstreamQuery::create()->findPK($id); //we are updating a playlist. Ensure that if the user is a host/dj, that he has the correct permission. $user = Application_Model_User::getCurrentUser(); if ($webstream->getDbCreatorId() == $user->getId()) { $hasPermission = true; } } } return $hasPermission; } public function saveAction() { $request = $this->getRequest(); $user = Application_Model_User::getCurrentUser(); $hasPermission = $user->isUserType(array(UTYPE_ADMIN, UTYPE_PROGRAM_MANAGER, UTYPE_HOST)); $id = $request->getParam("id"); $parameters = array(); $parameters['id'] = trim($request->getParam("id")); $parameters['length'] = trim($request->getParam("length")); $parameters['name'] = trim($request->getParam("name")); $parameters['description'] = trim($request->getParam("description")); $parameters['url'] = trim($request->getParam("url")); if (!$this->isAuthorized($id)) { header("Status: 401 Not Authorized"); return; } list($analysis, $mime, $di) = Application_Model_Webstream::analyzeFormData($parameters); try { if (Application_Model_Webstream::isValid($analysis)) { $streamId = Application_Model_Webstream::save($parameters, $mime, $di); $this->view->statusMessage = "