Linting: These actually were bugs.
This commit is contained in:
parent
d4ac6ca451
commit
158819cb28
@ -9,9 +9,15 @@
|
||||
*/
|
||||
|
||||
class WikiUpdateEvent extends Event {
|
||||
var $user;
|
||||
var $wikipage;
|
||||
/** @var \User */
|
||||
public $user;
|
||||
/** @var \WikiPage */
|
||||
public $wikipage;
|
||||
|
||||
/**
|
||||
* @param User $user
|
||||
* @param WikiPage $wikipage
|
||||
*/
|
||||
public function __construct(User $user, WikiPage $wikipage) {
|
||||
$this->user = $user;
|
||||
$this->wikipage = $wikipage;
|
||||
@ -22,32 +28,52 @@ class WikiUpdateException extends SCoreException {
|
||||
}
|
||||
|
||||
class WikiPage {
|
||||
var $id;
|
||||
/** @var int|string */
|
||||
public $id;
|
||||
|
||||
var $owner_id;
|
||||
var $owner_ip;
|
||||
var $date;
|
||||
var $title;
|
||||
|
||||
/** @var string */
|
||||
public $title;
|
||||
|
||||
var $revision;
|
||||
var $locked;
|
||||
var $body;
|
||||
|
||||
public function __construct($row) {
|
||||
assert(!empty($row));
|
||||
/** @var bool */
|
||||
public $locked;
|
||||
|
||||
$this->id = $row['id'];
|
||||
$this->owner_id = $row['owner_id'];
|
||||
$this->owner_ip = $row['owner_ip'];
|
||||
$this->date = $row['date'];
|
||||
$this->title = $row['title'];
|
||||
$this->revision = $row['revision'];
|
||||
$this->locked = ($row['locked'] == 'Y');
|
||||
$this->body = $row['body'];
|
||||
/** @var string */
|
||||
public $body;
|
||||
|
||||
/**
|
||||
* @param mixed $row
|
||||
*/
|
||||
public function __construct($row=null) {
|
||||
//assert(!empty($row));
|
||||
|
||||
if (!is_null($row)) {
|
||||
$this->id = $row['id'];
|
||||
$this->owner_id = $row['owner_id'];
|
||||
$this->owner_ip = $row['owner_ip'];
|
||||
$this->date = $row['date'];
|
||||
$this->title = $row['title'];
|
||||
$this->revision = $row['revision'];
|
||||
$this->locked = ($row['locked'] == 'Y');
|
||||
$this->body = $row['body'];
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @return null|User
|
||||
*/
|
||||
public function get_owner() {
|
||||
return User::by_id($this->owner_id);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return bool
|
||||
*/
|
||||
public function is_locked() {
|
||||
return $this->locked;
|
||||
}
|
||||
@ -55,8 +81,7 @@ class WikiPage {
|
||||
|
||||
class Wiki extends Extension {
|
||||
public function onInitExt(InitExtEvent $event) {
|
||||
global $database;
|
||||
global $config;
|
||||
global $database, $config;
|
||||
|
||||
if($config->get_int("ext_wiki_version", 0) < 1) {
|
||||
$database->create_table("wiki_pages", "
|
||||
@ -105,7 +130,7 @@ class Wiki extends Extension {
|
||||
|
||||
if($this->can_edit($user, $this->get_page($title))) {
|
||||
$wikipage = $this->get_page($title);
|
||||
$wikipage->rev = $rev;
|
||||
$wikipage->revision = $rev;
|
||||
$wikipage->body = $body;
|
||||
$wikipage->locked = $lock;
|
||||
try {
|
||||
@ -160,7 +185,7 @@ class Wiki extends Extension {
|
||||
$database->Execute("
|
||||
INSERT INTO wiki_pages(owner_id, owner_ip, date, title, revision, locked, body)
|
||||
VALUES (?, ?, now(), ?, ?, ?, ?)", array($event->user->id, $_SERVER['REMOTE_ADDR'],
|
||||
$wpage->title, $wpage->rev, $wpage->locked?'Y':'N', $wpage->body));
|
||||
$wpage->title, $wpage->revision, $wpage->locked?'Y':'N', $wpage->body));
|
||||
}
|
||||
catch(Exception $e) {
|
||||
throw new WikiUpdateException("Somebody else edited that page at the same time :-(");
|
||||
@ -168,13 +193,13 @@ class Wiki extends Extension {
|
||||
}
|
||||
|
||||
/**
|
||||
* See if the given user is allowed to edit the given page
|
||||
* See if the given user is allowed to edit the given page.
|
||||
*
|
||||
* @retval boolean
|
||||
* @param User $user
|
||||
* @param WikiPage $page
|
||||
* @return bool
|
||||
*/
|
||||
public static function can_edit(User $user, WikiPage $page) {
|
||||
global $config;
|
||||
|
||||
// admins can edit everything
|
||||
if($user->is_admin()) return true;
|
||||
|
||||
@ -187,6 +212,11 @@ class Wiki extends Extension {
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $title
|
||||
* @param int|null $revision
|
||||
* @return WikiPage
|
||||
*/
|
||||
private function get_page($title, $revision=-1) {
|
||||
global $database;
|
||||
// first try and get the actual page
|
||||
|
@ -1,14 +1,16 @@
|
||||
<?php
|
||||
|
||||
class WikiTheme extends Themelet {
|
||||
/*
|
||||
* Show a page
|
||||
/**
|
||||
* Show a page.
|
||||
*
|
||||
* $page = the shimmie page object
|
||||
* $wiki_page = the wiki page, has ->title and ->body
|
||||
* $nav_page = a wiki page object with navigation, has ->body
|
||||
* @param Page $page The shimmie page object
|
||||
* @param WikiPage $wiki_page The wiki page, has ->title and ->body
|
||||
* @param WikiPage|null $nav_page A wiki page object with navigation, has ->body
|
||||
*/
|
||||
public function display_page(Page $page, WikiPage $wiki_page, $nav_page) { // $nav_page = WikiPage or null
|
||||
public function display_page(Page $page, WikiPage $wiki_page, $nav_page) {
|
||||
global $user;
|
||||
|
||||
if(is_null($nav_page)) {
|
||||
$nav_page = new WikiPage();
|
||||
$nav_page->body = "";
|
||||
@ -18,7 +20,6 @@ class WikiTheme extends Themelet {
|
||||
send_event($tfe);
|
||||
|
||||
// only the admin can edit the sidebar
|
||||
global $user;
|
||||
if($user->is_admin()) {
|
||||
$tfe->formatted .= "<p>(<a href='".make_link("wiki/wiki:sidebar", "edit=on")."'>Edit</a>)";
|
||||
}
|
||||
@ -61,12 +62,13 @@ class WikiTheme extends Themelet {
|
||||
}
|
||||
|
||||
protected function create_display_html(WikiPage $page) {
|
||||
global $user;
|
||||
|
||||
$owner = $page->get_owner();
|
||||
|
||||
$tfe = new TextFormattingEvent($page->body);
|
||||
send_event($tfe);
|
||||
|
||||
global $user;
|
||||
$edit = "<table><tr>";
|
||||
$edit .= Wiki::can_edit($user, $page) ?
|
||||
"
|
||||
|
Loading…
x
Reference in New Issue
Block a user