]>
Commit | Line | Data |
---|---|---|
6fc14d53 A |
1 | <?php |
2 | ||
3 | /** | |
4 | * Class Router | |
5 | * | |
6 | * (only displayable pages here) | |
7 | */ | |
8 | class Router | |
9 | { | |
28f26524 A |
10 | public static $AJAX_THUMB_UPDATE = 'ajax_thumb_update'; |
11 | ||
6fc14d53 A |
12 | public static $PAGE_LOGIN = 'login'; |
13 | ||
14 | public static $PAGE_PICWALL = 'picwall'; | |
15 | ||
16 | public static $PAGE_TAGCLOUD = 'tagcloud'; | |
17 | ||
aa4797ba A |
18 | public static $PAGE_TAGLIST = 'taglist'; |
19 | ||
38603b24 A |
20 | public static $PAGE_DAILY = 'daily'; |
21 | ||
8395d0b7 A |
22 | public static $PAGE_FEED_ATOM = 'atom'; |
23 | ||
24 | public static $PAGE_FEED_RSS = 'rss'; | |
25 | ||
6fc14d53 A |
26 | public static $PAGE_TOOLS = 'tools'; |
27 | ||
28 | public static $PAGE_CHANGEPASSWORD = 'changepasswd'; | |
29 | ||
30 | public static $PAGE_CONFIGURE = 'configure'; | |
31 | ||
32 | public static $PAGE_CHANGETAG = 'changetag'; | |
33 | ||
34 | public static $PAGE_ADDLINK = 'addlink'; | |
35 | ||
36 | public static $PAGE_EDITLINK = 'edit_link'; | |
37 | ||
f4ebd5fe A |
38 | public static $PAGE_DELETELINK = 'delete_link'; |
39 | ||
4154c25b A |
40 | public static $PAGE_PINLINK = 'pin'; |
41 | ||
6fc14d53 A |
42 | public static $PAGE_EXPORT = 'export'; |
43 | ||
44 | public static $PAGE_IMPORT = 'import'; | |
45 | ||
8f8113b9 A |
46 | public static $PAGE_OPENSEARCH = 'opensearch'; |
47 | ||
6fc14d53 A |
48 | public static $PAGE_LINKLIST = 'linklist'; |
49 | ||
dea0ba28 A |
50 | public static $PAGE_PLUGINSADMIN = 'pluginadmin'; |
51 | ||
52 | public static $PAGE_SAVE_PLUGINSADMIN = 'save_pluginadmin'; | |
53 | ||
28f26524 A |
54 | public static $PAGE_THUMBS_UPDATE = 'thumbs_update'; |
55 | ||
986a5210 A |
56 | public static $GET_TOKEN = 'token'; |
57 | ||
6fc14d53 A |
58 | /** |
59 | * Reproducing renderPage() if hell, to avoid regression. | |
60 | * | |
61 | * This highlights how bad this needs to be rewrite, | |
62 | * but let's focus on plugins for now. | |
63 | * | |
64 | * @param string $query $_SERVER['QUERY_STRING']. | |
65 | * @param array $get $_SERVER['GET']. | |
66 | * @param bool $loggedIn true if authenticated user. | |
67 | * | |
82e36802 | 68 | * @return string page found. |
6fc14d53 A |
69 | */ |
70 | public static function findPage($query, $get, $loggedIn) | |
71 | { | |
72 | $loggedIn = ($loggedIn === true) ? true : false; | |
73 | ||
74 | if (empty($query) && !isset($get['edit_link']) && !isset($get['post'])) { | |
75 | return self::$PAGE_LINKLIST; | |
76 | } | |
77 | ||
5046bcb6 | 78 | if (startsWith($query, 'do='. self::$PAGE_LOGIN) && $loggedIn === false) { |
6fc14d53 A |
79 | return self::$PAGE_LOGIN; |
80 | } | |
81 | ||
5046bcb6 | 82 | if (startsWith($query, 'do='. self::$PAGE_PICWALL)) { |
6fc14d53 A |
83 | return self::$PAGE_PICWALL; |
84 | } | |
85 | ||
5046bcb6 | 86 | if (startsWith($query, 'do='. self::$PAGE_TAGCLOUD)) { |
6fc14d53 A |
87 | return self::$PAGE_TAGCLOUD; |
88 | } | |
89 | ||
aa4797ba A |
90 | if (startsWith($query, 'do='. self::$PAGE_TAGLIST)) { |
91 | return self::$PAGE_TAGLIST; | |
92 | } | |
93 | ||
5046bcb6 | 94 | if (startsWith($query, 'do='. self::$PAGE_OPENSEARCH)) { |
8f8113b9 A |
95 | return self::$PAGE_OPENSEARCH; |
96 | } | |
97 | ||
38603b24 A |
98 | if (startsWith($query, 'do='. self::$PAGE_DAILY)) { |
99 | return self::$PAGE_DAILY; | |
100 | } | |
101 | ||
8395d0b7 A |
102 | if (startsWith($query, 'do='. self::$PAGE_FEED_ATOM)) { |
103 | return self::$PAGE_FEED_ATOM; | |
104 | } | |
105 | ||
106 | if (startsWith($query, 'do='. self::$PAGE_FEED_RSS)) { | |
107 | return self::$PAGE_FEED_RSS; | |
108 | } | |
109 | ||
28f26524 A |
110 | if (startsWith($query, 'do='. self::$PAGE_THUMBS_UPDATE)) { |
111 | return self::$PAGE_THUMBS_UPDATE; | |
112 | } | |
113 | ||
114 | if (startsWith($query, 'do='. self::$AJAX_THUMB_UPDATE)) { | |
115 | return self::$AJAX_THUMB_UPDATE; | |
116 | } | |
117 | ||
6fc14d53 A |
118 | // At this point, only loggedin pages. |
119 | if (!$loggedIn) { | |
120 | return self::$PAGE_LINKLIST; | |
121 | } | |
122 | ||
5046bcb6 | 123 | if (startsWith($query, 'do='. self::$PAGE_TOOLS)) { |
6fc14d53 A |
124 | return self::$PAGE_TOOLS; |
125 | } | |
126 | ||
5046bcb6 | 127 | if (startsWith($query, 'do='. self::$PAGE_CHANGEPASSWORD)) { |
6fc14d53 A |
128 | return self::$PAGE_CHANGEPASSWORD; |
129 | } | |
130 | ||
5046bcb6 | 131 | if (startsWith($query, 'do='. self::$PAGE_CONFIGURE)) { |
6fc14d53 A |
132 | return self::$PAGE_CONFIGURE; |
133 | } | |
134 | ||
5046bcb6 | 135 | if (startsWith($query, 'do='. self::$PAGE_CHANGETAG)) { |
6fc14d53 A |
136 | return self::$PAGE_CHANGETAG; |
137 | } | |
138 | ||
5046bcb6 | 139 | if (startsWith($query, 'do='. self::$PAGE_ADDLINK)) { |
6fc14d53 A |
140 | return self::$PAGE_ADDLINK; |
141 | } | |
142 | ||
143 | if (isset($get['edit_link']) || isset($get['post'])) { | |
144 | return self::$PAGE_EDITLINK; | |
145 | } | |
146 | ||
f4ebd5fe A |
147 | if (isset($get['delete_link'])) { |
148 | return self::$PAGE_DELETELINK; | |
149 | } | |
150 | ||
4154c25b A |
151 | if (startsWith($query, 'do='. self::$PAGE_PINLINK)) { |
152 | return self::$PAGE_PINLINK; | |
153 | } | |
154 | ||
5046bcb6 | 155 | if (startsWith($query, 'do='. self::$PAGE_EXPORT)) { |
6fc14d53 A |
156 | return self::$PAGE_EXPORT; |
157 | } | |
158 | ||
5046bcb6 | 159 | if (startsWith($query, 'do='. self::$PAGE_IMPORT)) { |
6fc14d53 A |
160 | return self::$PAGE_IMPORT; |
161 | } | |
162 | ||
5046bcb6 | 163 | if (startsWith($query, 'do='. self::$PAGE_PLUGINSADMIN)) { |
dea0ba28 A |
164 | return self::$PAGE_PLUGINSADMIN; |
165 | } | |
166 | ||
5046bcb6 | 167 | if (startsWith($query, 'do='. self::$PAGE_SAVE_PLUGINSADMIN)) { |
dea0ba28 A |
168 | return self::$PAGE_SAVE_PLUGINSADMIN; |
169 | } | |
170 | ||
986a5210 A |
171 | if (startsWith($query, 'do='. self::$GET_TOKEN)) { |
172 | return self::$GET_TOKEN; | |
173 | } | |
174 | ||
6fc14d53 A |
175 | return self::$PAGE_LINKLIST; |
176 | } | |
db6dec0d | 177 | } |