Exists($name, $type)) { $message = $GLOBALS['handlers']['default']->ErrorMessage('PageNotFound', array('page' => $name)); if(!$message['title']) $message['title'] = $name; return $message; } $res = DBQuery('SELECT handler, data FROM pages WHERE name = ? AND type = ?', array($name, $type)); if(!$this->HasAccess($name, $type)) { $message = $GLOBALS['handlers'][$res->fields[0]]->ErrorMessage('Forbidden', array('page' => $name)); if(!$message['title']) $message['title'] = $name; return $message; } parse_str($res->fields[1], $data); $data = array_map('stripslashes', $data); $data['_page'] = $name; return $GLOBALS['handlers'][$res->fields[0]]->Get($data); } function Edit($name, $type) { if(!$this->Exists($name, $type)) { $message = $GLOBALS['handlers']['default']->ErrorMessage('PageNotFound', array('page' => $name)); if(!$message['title']) $message['title'] = $name; return $message; } $res = DBQuery('SELECT handler, data FROM pages WHERE name = ? AND type = ?', array($name, $type)); if(!$GLOBALS['user']->IsAdmin()) { $message = $GLOBALS['handlers'][$res->fields[0]]->ErrorMessage('Forbidden', array('page' => $name)); if(!$message['title']) $message['title'] = $name; return $message; } parse_str($res->fields[1], $data); $data = array_map('stripslashes', $data); $data['_page'] = $name; return $GLOBALS['handlers'][$res->fields[0]]->Edit($data); } function Exists($name, $type) { $res = DBQuery('SELECT id FROM pages WHERE name = ? AND type = ?', array($name, $type)); return ($res->RecordCount() > 0); } function HasAccess($name, $type) { $res = DBQuery('SELECT access FROM pages WHERE name = ? AND type = ?', array($name, $type)); return ($GLOBALS['user']->IsAdmin() || ($res->fields[0] & (1 << $GLOBALS['user']->GetGid())) != 0); } } $pages = new Pages; } ?>