123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- <?php
- /**
- * Class Router
- *
- * (only displayable pages here)
- */
- class Router
- {
- public static $PAGE_LOGIN = 'login';
- public static $PAGE_PICWALL = 'picwall';
- public static $PAGE_TAGCLOUD = 'tagcloud';
- public static $PAGE_DAILY = 'daily';
- public static $PAGE_FEED_ATOM = 'atom';
- public static $PAGE_FEED_RSS = 'rss';
- public static $PAGE_TOOLS = 'tools';
- public static $PAGE_CHANGEPASSWORD = 'changepasswd';
- public static $PAGE_CONFIGURE = 'configure';
- public static $PAGE_CHANGETAG = 'changetag';
- public static $PAGE_ADDLINK = 'addlink';
- public static $PAGE_EDITLINK = 'edit_link';
- public static $PAGE_DELETELINK = 'delete_link';
- public static $PAGE_EXPORT = 'export';
- public static $PAGE_IMPORT = 'import';
- public static $PAGE_OPENSEARCH = 'opensearch';
- public static $PAGE_LINKLIST = 'linklist';
- public static $PAGE_PLUGINSADMIN = 'pluginadmin';
- public static $PAGE_SAVE_PLUGINSADMIN = 'save_pluginadmin';
- /**
- * Reproducing renderPage() if hell, to avoid regression.
- *
- * This highlights how bad this needs to be rewrite,
- * but let's focus on plugins for now.
- *
- * @param string $query $_SERVER['QUERY_STRING'].
- * @param array $get $_SERVER['GET'].
- * @param bool $loggedIn true if authenticated user.
- *
- * @return string page found.
- */
- public static function findPage($query, $get, $loggedIn)
- {
- $loggedIn = ($loggedIn === true) ? true : false;
- if (empty($query) && !isset($get['edit_link']) && !isset($get['post'])) {
- return self::$PAGE_LINKLIST;
- }
- if (startsWith($query, 'do='. self::$PAGE_LOGIN) && $loggedIn === false) {
- return self::$PAGE_LOGIN;
- }
- if (startsWith($query, 'do='. self::$PAGE_PICWALL)) {
- return self::$PAGE_PICWALL;
- }
- if (startsWith($query, 'do='. self::$PAGE_TAGCLOUD)) {
- return self::$PAGE_TAGCLOUD;
- }
- if (startsWith($query, 'do='. self::$PAGE_OPENSEARCH)) {
- return self::$PAGE_OPENSEARCH;
- }
- if (startsWith($query, 'do='. self::$PAGE_DAILY)) {
- return self::$PAGE_DAILY;
- }
- if (startsWith($query, 'do='. self::$PAGE_FEED_ATOM)) {
- return self::$PAGE_FEED_ATOM;
- }
- if (startsWith($query, 'do='. self::$PAGE_FEED_RSS)) {
- return self::$PAGE_FEED_RSS;
- }
- // At this point, only loggedin pages.
- if (!$loggedIn) {
- return self::$PAGE_LINKLIST;
- }
- if (startsWith($query, 'do='. self::$PAGE_TOOLS)) {
- return self::$PAGE_TOOLS;
- }
- if (startsWith($query, 'do='. self::$PAGE_CHANGEPASSWORD)) {
- return self::$PAGE_CHANGEPASSWORD;
- }
- if (startsWith($query, 'do='. self::$PAGE_CONFIGURE)) {
- return self::$PAGE_CONFIGURE;
- }
- if (startsWith($query, 'do='. self::$PAGE_CHANGETAG)) {
- return self::$PAGE_CHANGETAG;
- }
- if (startsWith($query, 'do='. self::$PAGE_ADDLINK)) {
- return self::$PAGE_ADDLINK;
- }
- if (isset($get['edit_link']) || isset($get['post'])) {
- return self::$PAGE_EDITLINK;
- }
- if (isset($get['delete_link'])) {
- return self::$PAGE_DELETELINK;
- }
- if (startsWith($query, 'do='. self::$PAGE_EXPORT)) {
- return self::$PAGE_EXPORT;
- }
- if (startsWith($query, 'do='. self::$PAGE_IMPORT)) {
- return self::$PAGE_IMPORT;
- }
- if (startsWith($query, 'do='. self::$PAGE_PLUGINSADMIN)) {
- return self::$PAGE_PLUGINSADMIN;
- }
- if (startsWith($query, 'do='. self::$PAGE_SAVE_PLUGINSADMIN)) {
- return self::$PAGE_SAVE_PLUGINSADMIN;
- }
- return self::$PAGE_LINKLIST;
- }
- }
|