_helper->getHelper('AjaxContext'); $ajaxContext->addActionContext('new', 'json') ->addActionContext('save', 'json') ->addActionContext('edit', '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"); $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 saveAction() { $request = $this->getRequest(); $user = Application_Model_User::getCurrentUser(); $hasPermission = $user->isUserType(array(UTYPE_ADMIN, UTYPE_PROGRAM_MANAGER, UTYPE_HOST)); if (!$hasPermission) { header("Status: 401 Not Authorized"); return; } $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 ($parameters['id'] != -1) { $webstream = CcWebstreamQuery::create()->findPK($parameters['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()) { 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 = "