0
+ − 1
<?php
+ − 2
/*
+ − 3
Plugin Name: Special page-related pages
+ − 4
Plugin URI: http://enanocms.org/
+ − 5
Description: Provides the page Special:CreatePage, which can be used to create new pages. Also adds the About Enano and GNU General Public License pages.
+ − 6
Author: Dan Fuhry
85
7c68a18a27be
AJAX comments are now paginated; plugin manager can now show system plugins; typo in installer corrected; links in oxygen/stpatty/admin footers changed to "About Enano" page; 1.0.1 release candidate
Dan
diff
changeset
+ − 7
Version: 1.0.1
0
+ − 8
Author URI: http://enanocms.org/
+ − 9
*/
+ − 10
+ − 11
/*
+ − 12
* Enano - an open-source CMS capable of wiki functions, Drupal-like sidebar blocks, and everything in between
+ − 13
* Version 1.0 release candidate 2
+ − 14
* Copyright (C) 2006-2007 Dan Fuhry
+ − 15
*
+ − 16
* This program is Free Software; you can redistribute and/or modify it under the terms of the GNU General Public License
+ − 17
* as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
+ − 18
*
+ − 19
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied
+ − 20
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for details.
+ − 21
*/
+ − 22
+ − 23
global $db, $session, $paths, $template, $plugins; // Common objects
+ − 24
+ − 25
$plugins->attachHook('base_classes_initted', '
+ − 26
global $paths;
+ − 27
$paths->add_page(Array(
+ − 28
\'name\'=>\'Create page\',
+ − 29
\'urlname\'=>\'CreatePage\',
+ − 30
\'namespace\'=>\'Special\',
+ − 31
\'special\'=>0,\'visible\'=>1,\'comments_on\'=>0,\'protected\'=>1,\'delvotes\'=>0,\'delvote_ips\'=>\'\',
+ − 32
));
+ − 33
+ − 34
$paths->add_page(Array(
+ − 35
\'name\'=>\'All pages\',
+ − 36
\'urlname\'=>\'AllPages\',
+ − 37
\'namespace\'=>\'Special\',
+ − 38
\'special\'=>0,\'visible\'=>1,\'comments_on\'=>0,\'protected\'=>1,\'delvotes\'=>0,\'delvote_ips\'=>\'\',
+ − 39
));
+ − 40
+ − 41
$paths->add_page(Array(
+ − 42
\'name\'=>\'List of special pages\',
+ − 43
\'urlname\'=>\'SpecialPages\',
+ − 44
\'namespace\'=>\'Special\',
+ − 45
\'special\'=>0,\'visible\'=>1,\'comments_on\'=>0,\'protected\'=>1,\'delvotes\'=>0,\'delvote_ips\'=>\'\',
+ − 46
));
+ − 47
+ − 48
$paths->add_page(Array(
+ − 49
\'name\'=>\'About Enano\',
+ − 50
\'urlname\'=>\'About_Enano\',
+ − 51
\'namespace\'=>\'Special\',
+ − 52
\'special\'=>0,\'visible\'=>1,\'comments_on\'=>0,\'protected\'=>1,\'delvotes\'=>0,\'delvote_ips\'=>\'\',
+ − 53
));
+ − 54
+ − 55
$paths->add_page(Array(
+ − 56
\'name\'=>\'GNU General Public License\',
+ − 57
\'urlname\'=>\'GNU_General_Public_License\',
+ − 58
\'namespace\'=>\'Special\',
+ − 59
\'special\'=>0,\'visible\'=>1,\'comments_on\'=>0,\'protected\'=>1,\'delvotes\'=>0,\'delvote_ips\'=>\'\',
+ − 60
));
83
+ − 61
+ − 62
$paths->add_page(Array(
+ − 63
\'name\'=>\'Tag cloud\',
+ − 64
\'urlname\'=>\'TagCloud\',
+ − 65
\'namespace\'=>\'Special\',
+ − 66
\'special\'=>0,\'visible\'=>1,\'comments_on\'=>0,\'protected\'=>1,\'delvotes\'=>0,\'delvote_ips\'=>\'\',
+ − 67
));
0
+ − 68
');
+ − 69
+ − 70
// function names are IMPORTANT!!! The name pattern is: page_<namespace ID>_<page URLname, without namespace>
+ − 71
22
+ − 72
function page_Special_CreatePage()
+ − 73
{
0
+ − 74
global $db, $session, $paths, $template, $plugins; // Common objects
+ − 75
if ( isset($_POST['do']) )
+ − 76
{
+ − 77
$p = $_POST['pagename'];
+ − 78
$k = array_keys($paths->nslist);
+ − 79
for ( $i = 0; $i < sizeof( $paths->nslist ); $i++ )
+ − 80
{
+ − 81
$ln = strlen( $paths->nslist[$k[$i]] );
+ − 82
if ( substr($p, 0, $ln) == $paths->nslist[$k[$i]] )
+ − 83
{
+ − 84
$namespace = $k[$i];
+ − 85
}
+ − 86
}
+ − 87
if ( $namespace == 'Special' || ( $namespace == 'System' && $session->user_level < USER_LEVEL_ADMIN ) || $namespace == 'Admin')
+ − 88
{
+ − 89
$template->header();
+ − 90
+ − 91
echo '<h3>The page could not be created.</h3><p>The name "'.$p.'" is invalid.</p>';
+ − 92
+ − 93
$template->footer();
+ − 94
$db->close();
+ − 95
+ − 96
exit;
+ − 97
}
+ − 98
$name = $db->escape(str_replace('_', ' ', $p));
22
+ − 99
$urlname = str_replace(' ', '_', $p);
0
+ − 100
$namespace = $_POST['namespace'];
+ − 101
if ( $namespace == 'Special' || ( $namespace == 'System' && $session->user_level < USER_LEVEL_ADMIN ) || $namespace == 'Admin')
+ − 102
{
+ − 103
$template->header();
+ − 104
+ − 105
echo '<h3>The page could not be created.</h3><p>The name "'.$paths->nslist[$namespace].$p.'" is invalid.</p>';
+ − 106
+ − 107
$template->footer();
+ − 108
$db->close();
+ − 109
+ − 110
exit;
+ − 111
}
+ − 112
+ − 113
$tn = $paths->nslist[$_POST['namespace']] . $urlname;
+ − 114
if ( isset($paths->pages[$tn]) )
+ − 115
{
+ − 116
die_friendly('Error creating page', '<p>The page already exists.</p>');
+ − 117
}
+ − 118
+ − 119
if ( $paths->nslist[$namespace] == substr($urlname, 0, strlen($paths->nslist[$namespace]) ) )
+ − 120
{
+ − 121
$urlname = substr($urlname, strlen($paths->nslist[$namespace]), strlen($urlname));
+ − 122
}
+ − 123
+ − 124
$k = array_keys( $paths->nslist );
+ − 125
if(!in_array($_POST['namespace'], $k))
+ − 126
{
+ − 127
$db->_die('An SQL injection attempt was caught at '.dirname(__FILE__).':'.__LINE__.'.');
+ − 128
}
+ − 129
112
+ − 130
$ips = array(
+ − 131
'ip' => array(),
+ − 132
'u' => array()
+ − 133
);
+ − 134
$ips = $db->escape(serialize($ips));
+ − 135
22
+ − 136
$urlname = sanitize_page_id($urlname);
+ − 137
$urlname = $db->escape($urlname);
+ − 138
0
+ − 139
$perms = $session->fetch_page_acl($urlname, $namespace);
+ − 140
if ( !$perms->get_permissions('create_page') )
+ − 141
die_friendly('Error creating page', '<p>An access control rule is preventing you from creating pages.</p>');
+ − 142
+ − 143
$q = $db->sql_query('INSERT INTO '.table_prefix.'logs(time_id,date_string,log_type,action,author,page_id,namespace) VALUES('.time().', \''.date('d M Y h:i a').'\', \'page\', \'create\', \''.$session->username.'\', \''.$urlname.'\', \''.$_POST['namespace'].'\');');
+ − 144
if ( !$q )
+ − 145
{
+ − 146
$db->_die('The page log could not be updated.');
+ − 147
}
+ − 148
112
+ − 149
$q = $db->sql_query('INSERT INTO '.table_prefix.'pages(name,urlname,namespace,delvote_ips) VALUES(\''.$name.'\', \''.$urlname.'\', \''.$_POST['namespace'].'\',\'' . $ips . '\');');
0
+ − 150
if ( !$q )
+ − 151
{
+ − 152
$db->_die('The page entry could not be inserted.');
+ − 153
}
+ − 154
$q = $db->sql_query('INSERT INTO '.table_prefix.'page_text(page_id,namespace,page_text) VALUES(\''.$urlname.'\', \''.$_POST['namespace'].'\', \''.$db->escape('Please edit this page! <nowiki><script type="text/javascript">ajaxEditor();</script></nowiki>').'\');');
+ − 155
if ( !$q )
+ − 156
{
+ − 157
$db->_die('The page text entry could not be inserted.');
+ − 158
}
+ − 159
22
+ − 160
header('Location: '.makeUrlNS($_POST['namespace'], sanitize_page_id($p)));
0
+ − 161
exit;
+ − 162
}
+ − 163
$template->header();
+ − 164
if ( !$session->get_permissions('create_page') )
+ − 165
{
+ − 166
echo 'Wiki mode is disabled, only admins can create pages.';
+ − 167
+ − 168
$template->footer();
+ − 169
$db->close();
+ − 170
+ − 171
exit;
+ − 172
}
+ − 173
echo RenderMan::render('Using the form below you can create a page.');
+ − 174
?>
+ − 175
<form action="" method="post">
+ − 176
<p>
+ − 177
<select name="namespace">
+ − 178
<?php
+ − 179
$k = array_keys($paths->nslist);
+ − 180
for ( $i = 0; $i < sizeof($k); $i++ )
+ − 181
{
+ − 182
if ( $paths->nslist[$k[$i]] == '' )
+ − 183
{
+ − 184
$s = '[No prefix]';
+ − 185
}
+ − 186
else
+ − 187
{
+ − 188
$s = $paths->nslist[$k[$i]];
+ − 189
}
+ − 190
if ( ( $k[$i] != 'System' || $session->user_level >= USER_LEVEL_ADMIN ) && $k[$i] != 'Admin' && $k[$i] != 'Special')
+ − 191
{
+ − 192
echo '<option value="'.$k[$i].'">'.$s.'</option>';
+ − 193
}
+ − 194
}
+ − 195
?>
+ − 196
</select> <input type="text" name="pagename" /></p>
+ − 197
<p><input type="submit" name="do" value="Create Page" /></p>
+ − 198
</form>
+ − 199
<?php
+ − 200
$template->footer();
+ − 201
}
+ − 202
116
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 203
function PagelistingFormatter($id, $row)
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 204
{
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 205
global $db, $session, $paths, $template, $plugins; // Common objects
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 206
static $rowtracker = 0;
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 207
static $tdclass = 'row2';
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 208
static $per_row = 2;
117
+ − 209
static $first = true;
116
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 210
$return = '';
117
+ − 211
if ( $id === false && $row === false )
116
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 212
{
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 213
$rowtracker = 0;
117
+ − 214
$first = true;
116
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 215
return false;
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 216
}
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 217
$rowtracker++;
117
+ − 218
if ( $rowtracker == $per_row || $first )
116
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 219
{
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 220
$rowtracker = 0;
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 221
$tdclass = ( $tdclass == 'row2' ) ? 'row1' : 'row2';
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 222
}
117
+ − 223
if ( $rowtracker == 0 && !$first )
+ − 224
$return .= "</tr>\n<tr>";
+ − 225
+ − 226
$first = false;
116
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 227
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 228
preg_match('/^ns=(' . implode('|', array_keys($paths->nslist)) . ');pid=(.*?)$/i', $id, $match);
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 229
$namespace =& $match[1];
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 230
$page_id =& $match[2];
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 231
$page_id = sanitize_page_id($page_id);
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 232
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 233
$url = makeUrlNS($namespace, $page_id);
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 234
$url = htmlspecialchars($url);
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 235
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 236
$link = '<a href="' . $url . '">' . htmlspecialchars($row['name']) . '</a>';
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 237
$td = '<td class="' . $tdclass . '" style="width: 50%;">' . $link . '</td>';
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 238
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 239
$return .= $td;
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 240
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 241
return $return;
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 242
}
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 243
0
+ − 244
function page_Special_AllPages()
+ − 245
{
+ − 246
// This should be an easy one
+ − 247
global $db, $session, $paths, $template, $plugins; // Common objects
+ − 248
$template->header();
+ − 249
$sz = sizeof( $paths->pages ) / 2;
116
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 250
echo '<p>Below is a list of all of the pages on this website.</p>';
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 251
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 252
$q = $db->sql_query('SELECT COUNT(urlname) FROM '.table_prefix.'pages WHERE visible!=0;');
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 253
if ( !$q )
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 254
$db->_die();
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 255
$row = $db->fetchrow_num();
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 256
$count = $row[0];
117
+ − 257
+ − 258
switch($count % 4)
+ − 259
{
+ − 260
case 0:
+ − 261
case 2:
+ − 262
// even number of results; do nothing
+ − 263
$last_cell = '';
+ − 264
break;
+ − 265
case 1:
+ − 266
// odd number of results and odd number of rows, use row1
+ − 267
$last_cell = '<td class="row1"></td>';
+ − 268
break;
+ − 269
case 3:
+ − 270
// odd number of results and even number of rows, use row2
+ − 271
$last_cell = '<td class="row2"></td>';
+ − 272
break;
+ − 273
}
+ − 274
116
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 275
$db->free_result();
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 276
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 277
$q = $db->sql_unbuffered_query('SELECT CONCAT("ns=",namespace,";pid=",urlname) AS identifier, name FROM '.table_prefix.'pages WHERE visible!=0 ORDER BY name ASC;');
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 278
if ( !$q )
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 279
$db->_die();
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 280
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 281
$offset = ( isset($_GET['offset']) ) ? intval($_GET['offset']) : 0;
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 282
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 283
// reset formatter
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 284
PagelistingFormatter(false, false);
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 285
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 286
$result = paginate(
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 287
$q, // result resource
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 288
'{identifier}', // formatting template
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 289
$count, // # of results
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 290
makeUrlNS('Special', 'AllPages', 'offset=%s'), // result URL
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 291
$offset, // start offset
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 292
40, // results per page
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 293
array( 'identifier' => 'PagelistingFormatter' ), // hooks
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 294
'<div class="tblholder">
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 295
<table border="0" cellspacing="1" cellpadding="4">
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 296
<tr>', // print at start
117
+ − 297
' ' . $last_cell . '</tr>
116
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 298
</table>
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 299
</div>' // print at end
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 300
);
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 301
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 302
echo $result;
77c75179bb95
Made most special pages "visible"; fixup for non-existent special page redirect in paths.php; rewrote Special:AllPages to have pagination (WiP, Special:SpecialPages is possibly next, depending on whether paginate_array works or not)
Dan
diff
changeset
+ − 303
0
+ − 304
$template->footer();
+ − 305
}
+ − 306
+ − 307
function page_Special_SpecialPages()
+ − 308
{
+ − 309
// This should be an easy one
+ − 310
global $db, $session, $paths, $template, $plugins; // Common objects
+ − 311
$template->header();
+ − 312
$sz = sizeof($paths->pages) / 2;
+ − 313
echo '<p>Below is a list of all of the special pages on this website.</p><div class="tblholder"><table border="0" width="100%" cellspacing="1" cellpadding="4">';
+ − 314
$cclass='row1';
+ − 315
for ( $i = 0; $i < $sz; $i = $i)
+ − 316
{
+ − 317
if ( $cclass == 'row1' )
+ − 318
{
+ − 319
$cclass = 'row3';
+ − 320
}
+ − 321
else if ( $cclass == 'row3')
+ − 322
{
+ − 323
$cclass='row1';
+ − 324
}
+ − 325
echo '<tr>';
+ − 326
for ( $j = 0; $j < 2; $j = $j )
+ − 327
{
+ − 328
if ( $i < $sz && $paths->pages[$i]['namespace'] == 'Special' && $paths->pages[$i]['visible'] == 1)
+ − 329
{
+ − 330
echo '<td style="width: 50%" class="'.$cclass.'"><a href="'.makeUrl($paths->pages[$i]['urlname']).'">';
+ − 331
echo $paths->pages[$i]['name'].'</a></td>';
+ − 332
$j++;
+ − 333
}
+ − 334
else if ( $i >= $sz )
+ − 335
{
+ − 336
echo '<td style="width: 50%" class="row2"></td>';
+ − 337
$j++;
+ − 338
}
+ − 339
$i++;
+ − 340
}
+ − 341
echo '</tr>';
+ − 342
}
+ − 343
echo '</table></div>';
+ − 344
$template->footer();
+ − 345
}
+ − 346
+ − 347
function page_Special_About_Enano()
+ − 348
{
+ − 349
global $db, $session, $paths, $template, $plugins; // Common objects
+ − 350
$platform = 'Unknown';
+ − 351
$uname = @file_get_contents('/proc/sys/kernel/ostype');
+ − 352
if($uname == "Linux\n")
+ − 353
$platform = 'Linux';
+ − 354
else if(file_exists('/hurd/pfinet')) // I have a little experience with GNU/Hurd :-) http://hurdvm.enanocms.org/
+ − 355
$platform = 'GNU/Hurd';
+ − 356
else if(file_exists('C:\Windows\system32\ntoskrnl.exe'))
+ − 357
$platform = 'Windows NT';
+ − 358
else if(file_exists('C:\Windows\system\krnl386.exe'))
+ − 359
$platform = 'Windows 9x/DOS';
+ − 360
else if(file_exists('/bin/bash'))
+ − 361
$platform = 'Other GNU/Mac OS X';
+ − 362
else if(is_dir('/bin'))
+ − 363
$platform = 'Other POSIX';
+ − 364
$template->header();
+ − 365
?>
+ − 366
<br />
+ − 367
<div class="tblholder">
+ − 368
<table border="0" cellspacing="1" cellpadding="4">
+ − 369
<tr><th colspan="2" style="text-align: left;">About the Enano Content Management System</th></tr>
23
+ − 370
<tr><td colspan="2" class="row3"><p>This website is powered by <a href="http://enanocms.org/">Enano</a>, the lightweight and open source
38
+ − 371
CMS that everyone can use. Enano is copyright © 2006-2007 Dan Fuhry. For legal information, along with a list of libraries that Enano
23
+ − 372
uses, please see <a href="http://enanocms.org/Legal_information">Legal Information</a>.</p>
0
+ − 373
<p>The developers and maintainers of Enano strongly believe that software should not only be free to use, but free to be modified,
+ − 374
distributed, and used to create derivative works. For more information about Free Software, check out the
+ − 375
<a href="http://en.wikipedia.org/wiki/Free_Software" onclick="window.open(this.href); return false;">Wikipedia page</a> or
+ − 376
the <a href="http://www.fsf.org/" onclick="window.open(this.href); return false;">Free Software Foundation's</a> homepage.</p>
+ − 377
<p>This program is Free Software; you can redistribute it and/or modify it under the terms of the GNU General Public License
+ − 378
as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.</p>
+ − 379
<p>This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied
+ − 380
warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for details.</p>
+ − 381
<p>You should have received <a href="<?php echo makeUrlNS('Special', 'GNU_General_Public_License'); ?>">a copy of
+ − 382
the GNU General Public License</a> along with this program; if not, write to:</p>
+ − 383
<p style="margin-left 2em;">Free Software Foundation, Inc.,<br />
+ − 384
51 Franklin Street, Fifth Floor<br />
+ − 385
Boston, MA 02110-1301, USA</p>
129
0b5244001799
Rebranded as 1.0.1.1; fixed category page drawing bug; updated link to GPL in the about page to the GPLv2
Dan
diff
changeset
+ − 386
<p>Alternatively, you can <a href="http://www.gnu.org/licenses/old-licenses/gpl-2.0.html">read it online</a>.</p>
0
+ − 387
</td></tr>
+ − 388
<tr>
+ − 389
<td class="row2" colspan="2">
53
+ − 390
<table border="0" style="margin: 0 auto; background: none; width: 100%;" cellpadding="5">
0
+ − 391
<tr>
53
+ − 392
<td style="text-align: center;">
87
570f68c3fe36
Redid stupid fading button code and fixed several RC2 bugs in the upgrade schema; 1.0.1 release candidate
Dan
diff
changeset
+ − 393
<?php echo $template->fading_button; ?>
0
+ − 394
</td>
+ − 395
<td style="text-align: center;">
+ − 396
<a href="http://www.php.net/" onclick="window.open(this.href); return false;" style="background: none; padding: 0;">
+ − 397
<img alt="Written in PHP" src="<?php echo scriptPath; ?>/images/about-powered-php.png" style="border-width: 0px;" width="88" height="31" />
+ − 398
</a>
+ − 399
</td>
+ − 400
<td style="text-align: center;">
+ − 401
<a href="http://www.mysql.com/" onclick="window.open(this.href); return false;" style="background: none; padding: 0;">
+ − 402
<img alt="Database engine powered by MySQL" src="<?php echo scriptPath; ?>/images/about-powered-mysql.png" style="border-width: 0px;" width="88" height="31" />
+ − 403
</a>
+ − 404
</td>
+ − 405
</tr>
+ − 406
</table>
+ − 407
</td>
+ − 408
</tr>
132
0ae1b281a884
[sync only] Minor display change in Special:About_Enano; added initial PHP function for password strength testing
Dan
diff
changeset
+ − 409
<tr><td style="width: 100px;" class="row1"><a href="http://enanocms.org">Enano</a> version:</td><td class="row1"><?php echo enano_version(true) . ' (' . enano_codename() . ')'; ?></td></tr>
0
+ − 410
<tr><td style="width: 100px;" class="row2">Web server:</td><td class="row2"><?php if(isset($_SERVER['SERVER_SOFTWARE'])) echo $_SERVER['SERVER_SOFTWARE']; else echo 'Unable to determine web server software.'; ?></td></tr>
+ − 411
<tr><td style="width: 100px;" class="row1">Server platform:</td><td class="row1"><?php echo $platform; ?></td></tr>
+ − 412
<tr><td style="width: 100px;" class="row2"><a href="http://www.php.net/">PHP</a> version:</td><td class="row2"><?php echo PHP_VERSION; ?></td></tr>
+ − 413
<tr><td style="width: 100px;" class="row1"><a href="http://www.mysql.com/">MySQL</a> version:</td><td class="row1"><?php echo mysql_get_server_info($db->_conn); ?></td></tr>
+ − 414
</table>
+ − 415
</div>
+ − 416
<?php
+ − 417
$template->footer();
+ − 418
}
+ − 419
+ − 420
function page_Special_GNU_General_Public_License()
+ − 421
{
+ − 422
global $db, $session, $paths, $template, $plugins; // Common objects
+ − 423
$template->header();
+ − 424
if(file_exists(ENANO_ROOT.'/GPL'))
+ − 425
{
+ − 426
echo '<p>The following text represents the license that the <a href="'.makeUrlNS('Special', 'About_Enano').'">Enano</a> content management system is under. To make it easier to read, the text has been wiki-formatted; in no other way has it been changed.</p>';
73
0a74676a2f2f
Made the move to Loch Ness, and got some basic page grouping functionality working. TODO: fix some UI issues in Javascript ACL editor and change non-JS ACL editor to work with page groups too
Dan
diff
changeset
+ − 427
echo RenderMan::render( file_get_contents ( ENANO_ROOT . '/GPL' ) );
0
+ − 428
}
+ − 429
else
+ − 430
{
36
+ − 431
echo '<p>It appears that the file "GPL" is missing from your Enano installation. You may find a wiki-formatted copy of the GPL at: <a href="http://enanocms.org/GPL">http://enanocms.org/GPL</a>.</p>';
0
+ − 432
}
+ − 433
$template->footer();
+ − 434
}
+ − 435
83
+ − 436
function page_Special_TagCloud()
+ − 437
{
+ − 438
global $db, $session, $paths, $template, $plugins; // Common objects
+ − 439
+ − 440
$template->header();
+ − 441
+ − 442
if ( $tag = $paths->getParam(0) )
+ − 443
{
+ − 444
$tag = sanitize_tag($tag);
+ − 445
$q = $db->sql_query('SELECT page_id, namespace FROM '.table_prefix.'tags WHERE tag_name=\'' . $db->escape($tag) . '\';');
+ − 446
if ( !$q )
+ − 447
$db->_die();
+ − 448
if ( $row = $db->fetchrow() )
+ − 449
{
+ − 450
echo '<div class="tblholder">
+ − 451
<table border="0" cellspacing="1" cellpadding="4">';
+ − 452
echo '<tr><th colspan="2">Pages tagged "' . htmlspecialchars($tag) . '"</th></tr>';
+ − 453
echo '<tr>';
+ − 454
$i = 0;
+ − 455
$td_class = 'row1';
+ − 456
do
+ − 457
{
+ − 458
if ( $i % 2 == 0 && $i > 1 )
+ − 459
{
+ − 460
$td_class = ( $td_class == 'row2' ) ? 'row1' : 'row2';
+ − 461
echo '</tr><tr>';
+ − 462
}
+ − 463
$i++;
+ − 464
$title = get_page_title_ns($row['page_id'], $row['namespace']);
+ − 465
if ( $row['namespace'] != 'Article' && isset($paths->nslist[$row['namespace']]) )
+ − 466
$title = $paths->nslist[$row['namespace']] . $title;
+ − 467
$url = makeUrlNS($row['namespace'], $row['page_id']);
+ − 468
$class = ( isPage( $paths->nslist[$row['namespace']] . $row['page_id'] ) ) ? '' : ' class="wikilink-nonexistent"';
+ − 469
$link = '<a href="' . htmlspecialchars($url) . '"' . $class . '>' . htmlspecialchars($title) . '</a>';
+ − 470
echo "<td class=\"$td_class\" style=\"width: 50%;\">$link</td>";
+ − 471
// " workaround for jEdit highlighting bug
+ − 472
}
+ − 473
while ( $row = $db->fetchrow() );
+ − 474
while ( $i % 2 > 0 )
+ − 475
{
+ − 476
$i++;
+ − 477
echo "<td class=\"$td_class\" style=\"width: 50%;\"></td>";
+ − 478
}
+ − 479
// " workaround for jEdit highlighting bug
+ − 480
echo '<tr>
+ − 481
<th colspan="2" class="subhead"><a href="' . makeUrlNS('Special', 'TagCloud') . '" style="color: white;">« Return to tag cloud</a></th>
+ − 482
</tr>';
+ − 483
echo '</table>';
+ − 484
echo '</div>';
+ − 485
}
+ − 486
}
+ − 487
else
+ − 488
{
+ − 489
$cloud = new TagCloud();
+ − 490
+ − 491
$q = $db->sql_query('SELECT tag_name FROM '.table_prefix.'tags;');
+ − 492
if ( !$q )
+ − 493
$db->_die();
+ − 494
if ( $db->numrows() < 1 )
+ − 495
{
+ − 496
echo '<p>No pages are tagged yet.</p>';
+ − 497
}
+ − 498
else
+ − 499
{
+ − 500
echo '<h3>Summary of page tagging</h3>';
+ − 501
while ( $row = $db->fetchrow() )
+ − 502
{
+ − 503
$cloud->add_word($row['tag_name']);
+ − 504
}
+ − 505
echo $cloud->make_html('normal');
+ − 506
echo '<p>Hover your mouse over a tag to see how many pages have the tag. Click on a tag to see a list of the pages that have it.</p>';
+ − 507
}
+ − 508
}
+ − 509
+ − 510
$template->footer();
+ − 511
}
+ − 512
+ − 513
// tag cloud sidebar block
+ − 514
function sidebar_add_tag_cloud()
+ − 515
{
+ − 516
global $db, $session, $paths, $template, $plugins; // Common objects
+ − 517
$cloud = new TagCloud();
+ − 518
+ − 519
$q = $db->sql_query('SELECT tag_name FROM '.table_prefix.'tags;');
+ − 520
if ( !$q )
+ − 521
$db->_die();
+ − 522
if ( $db->numrows() < 1 )
+ − 523
{
+ − 524
$sb_html = 'No pages are tagged yet.';
+ − 525
}
+ − 526
else
+ − 527
{
+ − 528
while ( $row = $db->fetchrow() )
+ − 529
{
+ − 530
$cloud->add_word($row['tag_name']);
+ − 531
}
+ − 532
$sb_html = $cloud->make_html('small', 'justify') . '<br /><a style="text-align: center;" href="' . makeUrlNS('Special', 'TagCloud') . '">Larger version</a>';
+ − 533
}
+ − 534
$template->sidebar_widget('Tag cloud', "<div style='padding: 5px;'>$sb_html</div>");
+ − 535
}
+ − 536
+ − 537
$plugins->attachHook('compile_template', 'sidebar_add_tag_cloud();');
+ − 538
0
+ − 539
?>