This commit is contained in:
Parziphal 2013-11-08 11:37:29 -05:00
parent c9027c3dca
commit 0545bde1a0
20 changed files with 37 additions and 29 deletions

View File

@ -73,7 +73,6 @@ class DmailController extends ApplicationController
public function markAllRead() public function markAllRead()
{ {
vpe('a');
if ($this->params()->commit == "Yes") { if ($this->params()->commit == "Yes") {
foreach (Dmail::where("to_id = ? and has_seen = false", $this->current_user->id)->take() as $dmail) foreach (Dmail::where("to_id = ? and has_seen = false", $this->current_user->id)->take() as $dmail)
$dmail->updateAttribute('has_seen', true); $dmail->updateAttribute('has_seen', true);

View File

@ -132,7 +132,6 @@ class ForumController extends ApplicationController
public function show() public function show()
{ {
$this->forum_post = ForumPost::find($this->params()->id); $this->forum_post = ForumPost::find($this->params()->id);
$this->set_title($this->forum_post->title);
$this->children = ForumPost::where("parent_id = ?", $this->params()->id)->order("id")->paginate($this->page_number(), 30); $this->children = ForumPost::where("parent_id = ?", $this->params()->id)->order("id")->paginate($this->page_number(), 30);
if (!$this->current_user->is_anonymous() && $this->current_user->last_forum_topic_read_at < $this->forum_post->updated_at && $this->forum_post->updated_at < (time() - 3)) { if (!$this->current_user->is_anonymous() && $this->current_user->last_forum_topic_read_at < $this->forum_post->updated_at && $this->forum_post->updated_at < (time() - 3)) {

View File

@ -1139,7 +1139,7 @@ class PostController extends ApplicationController
'after' => [ 'after' => [
'save_tags_to_cookie' => ['only' => ['update', 'create']] 'save_tags_to_cookie' => ['only' => ['update', 'create']]
], ],
# iTODO: # iTODO :
'around' => [ 'around' => [
// 'cache_action' => ['only' => ['index', 'atom', 'piclens']] // 'cache_action' => ['only' => ['index', 'atom', 'piclens']]
] ]

View File

@ -69,6 +69,7 @@ class WikiController extends ApplicationController
public function preview() public function preview()
{ {
$this->setLayout(false);
$this->render(['inline' => '<?= $this->format_text($this->params()->body) ?>']); $this->render(['inline' => '<?= $this->format_text($this->params()->body) ?>']);
} }

View File

@ -71,17 +71,17 @@ class Dmail extends Rails\ActiveRecord\Base
} }
} }
protected function setToName($name) public function setToName($name)
{ {
if (!$user = User::where(['name' => $name])->first()) if (!$user = User::where(['name' => $name])->first())
return; return;
$this->to_id = $user->id; $this->to_id = $user->id;
} }
protected function setFromName($name) public function setFromName($name)
{ {
if (!$user = User::where(['name' => $name])->first()) if (!$user = User::where(['name' => $name])->first())
return; return;
$this->from_id = $user->id; $this->from_id = $user->id;
} }
} }

View File

@ -61,11 +61,11 @@ class Note extends Rails\ActiveRecord\Base
protected function callbacks() protected function callbacks()
{ {
return array_merge_recursive([ return [
'after_save' => [ 'after_save' => [
'update_post' 'update_post'
] ]
], $this->versioning_callbacks(), $this->versioningCallbacks()); ];
} }
protected function validations() protected function validations()

View File

@ -362,11 +362,11 @@ class Pool extends Rails\ActiveRecord\Base
protected function callbacks() protected function callbacks()
{ {
return array_merge_recursive([ return [
'before_destroy' => ['destroy_pool_posts'], 'before_destroy' => ['destroy_pool_posts'],
'after_save' => ['expire_cache'], 'after_save' => ['expire_cache'],
'before_validation' => ['normalize_name'], 'before_validation' => ['normalize_name'],
'after_undo' => ['update_pool_links'] 'after_undo' => ['update_pool_links']
], $this->versioning_callbacks()); ];
} }
} }

View File

@ -42,10 +42,10 @@ class PoolPost extends Rails\ActiveRecord\Base
protected function callbacks() protected function callbacks()
{ {
return array_merge_recursive([ return [
'before_create' => ['set_active_changed'], # MI 'before_create' => ['set_active_changed'], # MI
'after_save' => ['expire_cache'] 'after_save' => ['expire_cache']
], $this->versioning_callbacks()); ];
} }
public function can_change(User $user, $attribute) public function can_change(User $user, $attribute)

View File

@ -228,7 +228,7 @@ class Post extends Rails\ActiveRecord\Base
protected function callbacks() protected function callbacks()
{ {
return array_merge_recursive([ return [
'before_save' => ['commit_tags', 'filter_parent_id'], 'before_save' => ['commit_tags', 'filter_parent_id'],
'before_create' => ['set_index_timestamp'], 'before_create' => ['set_index_timestamp'],
'after_create' => ['after_creation'], 'after_create' => ['after_creation'],
@ -241,7 +241,7 @@ class Post extends Rails\ActiveRecord\Base
'validate_content_type', 'generate_hash', 'set_image_dimensions', 'validate_content_type', 'generate_hash', 'set_image_dimensions',
'set_image_status', 'check_pending_count', 'generate_sample', 'set_image_status', 'check_pending_count', 'generate_sample',
'generate_jpeg', 'generate_preview', 'move_file'] 'generate_jpeg', 'generate_preview', 'move_file']
], $this->versioning_callbacks()); ];
} }
protected function associations() protected function associations()
@ -303,6 +303,7 @@ class Post extends Rails\ActiveRecord\Base
$this->commit_tags(); $this->commit_tags();
$sql = "UPDATE posts SET cached_tags = ? WHERE id = ?"; $sql = "UPDATE posts SET cached_tags = ? WHERE id = ?";
self::connection()->executeSql($sql, $this->cached_tags, $this->id); self::connection()->executeSql($sql, $this->cached_tags, $this->id);
$this->save();
} }
} }

View File

@ -199,6 +199,7 @@ trait PostSqlMethods
} }
if (is_string($q['user'])) { if (is_string($q['user'])) {
$joins[] = "JOIN users u ON p.user_id = u.id";
$conds[] = "lower(u.name) = lower(?)"; $conds[] = "lower(u.name) = lower(?)";
$cond_params[] = $q['user']; $cond_params[] = $q['user'];
} }

View File

@ -83,7 +83,7 @@ trait PostStatusMethods
$this->set_flag_detail($this->status_reason, null); $this->set_flag_detail($this->status_reason, null);
} }
protected function setIsHeld($hold) public function setIsHeld($hold)
{ {
# Hack because the data comes in as a string: # Hack because the data comes in as a string:
if ($hold === "false") if ($hold === "false")
@ -104,6 +104,8 @@ trait PostStatusMethods
$was_held = $this->is_held; $was_held = $this->is_held;
$this->attributes['is_held'] = $hold;
# When a post is unheld, bump it. # When a post is unheld, bump it.
if ($was_held && !$hold) { if ($was_held && !$hold) {
$this->touch_index_timestamp(); $this->touch_index_timestamp();

View File

@ -313,6 +313,7 @@ trait PostTagMethods
// $this->tags = implode(' ', array_unique(TagImplication::with_implied(TagAlias::to_aliased($this->new_tags)))); // $this->tags = implode(' ', array_unique(TagImplication::with_implied(TagAlias::to_aliased($this->new_tags))));
$this->new_tags = TagAlias::to_aliased($this->new_tags); $this->new_tags = TagAlias::to_aliased($this->new_tags);
$this->new_tags = array_unique(TagImplication::with_implied($this->new_tags)); $this->new_tags = array_unique(TagImplication::with_implied($this->new_tags));
sort($this->new_tags);
// $this->tags = implode(' ', $this->tags()); // $this->tags = implode(' ', $this->tags());
# TODO: be more selective in deleting from the join table # TODO: be more selective in deleting from the join table

View File

@ -571,9 +571,9 @@ class Tag extends Rails\ActiveRecord\Base
static public function mass_edit($start_tags, $result_tags, $updater_id, $updater_ip_addr) static public function mass_edit($start_tags, $result_tags, $updater_id, $updater_ip_addr)
{ {
foreach (Post::find_by_tags($start_tags) as $p) { foreach (Post::find_by_tags($start_tags) as $p) {
$start = TagAlias::to_aliased(Tag::scan_tags($start_tags)); $start = TagAlias::to_aliased(Tag::scan_tags($start_tags));
$result = TagAlias::to_aliased(Tag::scan_tags($result_tags)); $result = TagAlias::to_aliased(Tag::scan_tags($result_tags));
$tags = array_merge(array_diff(array_keys($p->tags()), $start), $result); $tags = array_merge(array_diff($p->tags(), $start), $result);
$tags = implode(' ', $tags); $tags = implode(' ', $tags);
$p->updateAttributes(array('updater_user_id' => $updater_id, 'updater_ip_addr' => $updater_ip_addr, 'tags' => $tags)); $p->updateAttributes(array('updater_user_id' => $updater_id, 'updater_ip_addr' => $updater_ip_addr, 'tags' => $tags));
} }
@ -631,13 +631,13 @@ class Tag extends Rails\ActiveRecord\Base
protected function callbacks() protected function callbacks()
{ {
return array_merge_recursive([ return [
'after_save' => [ 'after_save' => [
'update_cache' 'update_cache'
], ],
'after_create' => [ 'after_create' => [
'update_cache_on_create' 'update_cache_on_create'
] ]
], $this->versioning_callbacks()); ];
} }
} }

View File

@ -9,7 +9,7 @@ trait CacheMethods
protected function update_cache() protected function update_cache()
{ {
# iTODO: hash keys # iTODO: hash keys
Rails::cache()->write('tag_type_' . $this->name, self::type_name_from_value($this->tag_type)); Rails::cache()->write('tag_type.' . $this->name, self::type_name_from_value($this->tag_type));
# Expire the tag cache if a tag's type changes. # Expire the tag cache if a tag's type changes.
if ($this->tag_type != $this->tagTypeWas()) { if ($this->tag_type != $this->tagTypeWas()) {

View File

@ -125,10 +125,10 @@ class WikiPage extends Rails\ActiveRecord\Base
protected function callbacks() protected function callbacks()
{ {
return array_merge_recursive([ return [
'before_save' => ['normalize_title'], 'before_save' => ['normalize_title'],
'before_validation_on_update' => ['ensure_changed'] 'before_validation_on_update' => ['ensure_changed']
], $this->versioningCallbacks()); ];
} }
protected function associations() protected function associations()
@ -159,8 +159,8 @@ class WikiPage extends Rails\ActiveRecord\Base
]; ];
} }
protected function versioningRelation($relation) protected function versioningRelation()
{ {
return $relation->order("updated_at DESC"); return self::order("updated_at DESC");
} }
} }

View File

@ -1,3 +1,4 @@
<?php $this->provide('title', $this->t('.title')) ?>
<?= $this->partial("comment/comments", array('comments' => array($this->comment), 'post_id' => $this->comment->post_id, 'hide' => false)) ?> <?= $this->partial("comment/comments", array('comments' => array($this->comment), 'post_id' => $this->comment->post_id, 'hide' => false)) ?>
<div style="clear: both;"> <div style="clear: both;">

View File

@ -1,3 +1,4 @@
<?php $this->provide('title', $this->forum_post->title) ?>
<?php if ($this->forum_post->is_locked) : ?> <?php if ($this->forum_post->is_locked) : ?>
<div class="status-notice"> <div class="status-notice">
<p><?= $this->t('.locked') ?></p> <p><?= $this->t('.locked') ?></p>

View File

@ -19,7 +19,7 @@
<!-- <td><?= $post->flag_detail->is_resolved ? 'Yes' : 'No' ?></td> --> <!-- <td><?= $post->flag_detail->is_resolved ? 'Yes' : 'No' ?></td> -->
<td><?= $this->linkTo($post->id, ['action' => 'show', 'id' => $post->id]) ?></td> <td><?= $this->linkTo($post->id, ['action' => 'show', 'id' => $post->id]) ?></td>
<td><?= $this->linkTo($this->h($post->author()), ['user#show', 'id' => $post->user_id]) ?></td> <td><?= $this->linkTo($this->h($post->author()), ['user#show', 'id' => $post->user_id]) ?></td>
<td><?= $this->h($post->tags()) ?></td> <td><?= $this->h($post->cached_tags) ?></td>
<td><?= $this->h($post->flag_detail->reason) ?></td> <td><?= $this->h($post->flag_detail->reason) ?></td>
<?php if (current_user()->is_mod_or_higher()) : ?> <?php if (current_user()->is_mod_or_higher()) : ?>
<td><?= $this->linkTo($this->h($post->flag_detail->author()), ['user#show', 'id' => $post->flag_detail->user_id]) ?></td> <td><?= $this->linkTo($this->h($post->flag_detail->author()), ['user#show', 'id' => $post->flag_detail->user_id]) ?></td>

View File

@ -34,7 +34,9 @@ class DText
# Parse inline tags as a whole. # Parse inline tags as a whole.
$result = self::parseinline($result); $result = self::parseinline($result);
return $result; # htmLawed ensures valid html output.
require_once Rails::root() . '/vendor/htmLawed/htmLawed.php';
return htmLawed($result);
} }
static public function parseinline($str) static public function parseinline($str)
@ -126,7 +128,7 @@ class DText
$state[] = "1"; $state[] = "1";
$html .= '<ul>'; $html .= '<ul>';
} else { } else {
$n = substr_count(preg_match('/^\*+\s+/', $str) ? $str : '', '*'); $n = substr_count((preg_match('/^\*+\s+/', $str, $m) ? $m[0] : ''), '*');
$last = (int)end($state); $last = (int)end($state);
if ($n < $last) { if ($n < $last) {
$html .= str_repeat('</ul>', $last - $n); $html .= str_repeat('</ul>', $last - $n);
@ -135,7 +137,7 @@ class DText
} elseif ($n > $last) { } elseif ($n > $last) {
$html .= '<ul>'; $html .= '<ul>';
array_pop($state); array_pop($state);
$state[] = (string)(end($state) + 1); $state[] = (string)($last + 1);
} }
if (!preg_match('/^\*+\s+/', $str)) { if (!preg_match('/^\*+\s+/', $str)) {
array_pop($state); array_pop($state);

View File

@ -140,7 +140,7 @@ trait VersioningTrait
self::connection()->executeSql($sql, static::tableName(), $this->id); self::connection()->executeSql($sql, static::tableName(), $this->id);
} }
public function versioning_callbacks() public function moeVersioningCallbacks()
{ {
return [ return [
'after_save' => [ 'after_save' => [