id = intval($id); if (!$this->id) { return false; } $info = $this->_get_info(); // Set the vars foreach ($info as $key=>$value) { $this->$key = $value; } } // constructor /** * _get_info * Private function for getting the information for this object from the database */ private function _get_info() { $id = Dba::escape($this->id); $sql = "SELECT * FROM `live_stream` WHERE `id`='$id'"; $db_results = Dba::query($sql); $results = Dba::fetch_assoc($db_results); return $results; } // _get_info /** * format * This takes the normal data from the database and makes it pretty * for the users, the new variables are put in f_??? and f_???_link */ public function format() { // Default link used on the rightbar $this->f_link = "url\">$this->name"; $this->f_name_link = "site_url\">$this->name"; $this->f_callsign = scrub_out($this->call_sign); $this->f_frequency = scrub_out($this->frequency); return true; } // format /** * get_url * This returns the URL for this live stream */ public function get_url() { } // get_url /** * update * This is a static function that takes a key'd array for input * it depends on a ID element to determine which radio element it * should be updating */ public static function update($data) { // Verify the incoming data if (!$data['id']) { Error::add('general','Missing ID'); } if (!$data['name']) { Error::add('general','Name Required'); } if (!preg_match("/^https?:\/\/.+/",$data['url'])) { Error::add('general','Invalid URL must be https:// or http://'); } if (Error::occurred()) { return false; } // Setup the data $name = Dba::escape($data['name']); $site_url = Dba::escape($data['site_url']); $url = Dba::escape($data['url']); $frequency = Dba::escape($data['frequency']); $call_sign = Dba::escape($data['call_sign']); $id = Dba::escape($data['id']); $sql = "UPDATE `live_stream` SET `name`='$name',`site_url`='$site_url',`url`='$url'" . ",`frequency`='$frequency',`call_sign`='$call_sign' WHERE `id`='$id'"; $db_results = Dba::query($sql); return $db_results; } // update /** * create * This is a static function that takes a key'd array for input * and if everything is good creates the object. */ public static function create($data) { // Make sure we've got a name if (!strlen($data['name'])) { Error::add('name','Name Required'); } if (!preg_match("/^https?:\/\/.+/",$data['url'])) { Error::add('url','Invalid URL must be http:// or https://'); } // Make sure it's a real catalog $catalog = new Catalog($data['catalog']); if (!$catalog->name) { Error::add('catalog','Invalid Catalog'); } if (Error::occurred()) { return false; } // Clean up the input $name = Dba::escape($data['name']); $site_url = Dba::escape($data['site_url']); $url = Dba::escape($data['url']); $catalog = $catalog->id; $frequency = Dba::escape($data['frequency']); $call_sign = Dba::escape($data['call_sign']); // If we've made it this far everything must be ok... I hope $sql = "INSERT INTO `live_stream` (`name`,`site_url`,`url`,`catalog`,`frequency`,`call_sign`) " . "VALUES ('$name','$site_url','$url','$catalog','$frequency','$call_sign')"; $db_results = Dba::query($sql); return $db_results; } // create /** * delete * This deletes the current object from the database */ public function delete() { $id = Dba::escape($this->id); $sql = "DELETE FROM `live_stream` WHERE `id`='$id'"; $db_results = Dba::query($sql); return true; } // delete } //end of radio class ?>