Files
UNIT3D-Community-Edition/app/Http/Controllers/ForumController.php
HDVinnie f6d3a1fabc (Update) Code Cleanup
- replace unauthorized if else checks with a much cleaner approach using the abort_unless() helper.
2018-11-29 17:41:14 -05:00

837 lines
28 KiB
PHP
Executable File

<?php
/**
* NOTICE OF LICENSE
*
* UNIT3D is open-sourced software licensed under the GNU General Public License v3.0
* The details is bundled with this project in the file LICENSE.txt.
*
* @project UNIT3D
* @license https://www.gnu.org/licenses/agpl-3.0.en.html/ GNU Affero General Public License v3.0
* @author HDVinnie
*/
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Mail;
use App\Forum;
use App\Post;
use App\Topic;
use App\User;
use App\Like;
use App\TopicSubscription;
use App\Achievements\UserMadeFirstPost;
use App\Achievements\UserMade25Posts;
use App\Achievements\UserMade50Posts;
use App\Achievements\UserMade100Posts;
use App\Achievements\UserMade200Posts;
use App\Achievements\UserMade300Posts;
use App\Achievements\UserMade400Posts;
use App\Achievements\UserMade500Posts;
use App\Achievements\UserMade600Posts;
use App\Achievements\UserMade700Posts;
use App\Achievements\UserMade800Posts;
use App\Achievements\UserMade900Posts;
use App\Repositories\ChatRepository;
use App\Repositories\TaggedUserRepository;
use Decoda\Decoda;
use Brian2694\Toastr\Toastr;
class ForumController extends Controller
{
/**
* @var TaggedUserRepository
*/
private $tag;
/**
* @var ChatRepository
*/
private $chat;
/**
* @var Toastr
*/
private $toastr;
/**
* ForumController Constructor
*
* @param TaggedUserRepository $tag
* @param ChatRepository $chat
* @param Toastr $toastr
*/
public function __construct(TaggedUserRepository $tag, ChatRepository $chat, Toastr $toastr)
{
$this->tag = $tag;
$this->chat = $chat;
$this->toastr = $toastr;
}
/**
* Search For Topics
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
*/
public function search(Request $request)
{
$user = auth()->user();
$results = Topic::where([
['name', 'like', '%' . $request->input('name') . '%'],
])->latest()->paginate(25);
$results->setPath('?name=' . $request->input('name'));
return view('forum.results', ['results' => $results, 'user' => $user]);
}
/**
* Show All Forums
*
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
*/
public function index()
{
$categories = Forum::oldest('position')->get();
// Total Forums Count
$num_forums = Forum::count();
// Total Posts Count
$num_posts = Post::count();
// Total Topics Count
$num_topics = Topic::count();
return view('forum.index', [
'categories' => $categories,
'num_posts' => $num_posts,
'num_forums' => $num_forums,
'num_topics' => $num_topics
]);
}
/**
* Show The Forum Category
*
* @param $slug
* @param $id
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
*/
public function category($slug, $id)
{
$category = Forum::findOrFail($id);
if ($category->getPermission()->show_forum != true) {
return redirect()->route('forum_index')
->with($this->toastr->error('You Do Not Have Access To This Category!', 'Whoops!', ['options']));
}
return view('forum.category', ['c' => $category]);
}
/**
* Show Forums And Topics Inside
*
* @param $slug
* @param $id
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
*/
public function display($slug, $id)
{
// Find the topic
$forum = Forum::findOrFail($id);
// Check if this is a category or forum
if ($forum->parent_id == 0) {
return redirect()->route('forum_category', ['slug' => $forum->slug, 'id' => $forum->id]);
}
// Check if the user has permission to view the forum
$category = Forum::findOrFail($forum->parent_id);
if ($category->getPermission()->show_forum != true) {
return redirect()->route('forum_index')
->with($this->toastr->error('You Do Not Have Access To This Forum!', 'Whoops!', ['options']));
}
// Fetch topics->posts in descending order
$topics = $forum->topics()->latest('pinned')->latest('last_reply_at')->latest()->paginate(25);
return view('forum.display', [
'forum' => $forum,
'topics' => $topics,
'category' => $category
]);
}
/**
* Show The Topic
*
* @param $slug
* @param $id
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
*/
public function topic($slug, $id)
{
// Find the topic
$topic = Topic::findOrFail($id);
// Get the forum of the topic
$forum = $topic->forum;
// Get The category of the forum
$category = $forum->getCategory();
// Get all posts
$posts = $topic->posts()->paginate(25);
// First post
$firstPost = Post::where('topic_id', $topic->id)->first();
// The user can post a topic here ?
if ($category->getPermission()->read_topic != true) {
// Redirect him to the forum index
return redirect()->route('forum_index')
->with($this->toastr->error('You Do Not Have Access To Read This Topic!', 'Whoops!', ['options']));
}
// Increment view
$topic->views++;
$topic->save();
return view('forum.topic', [
'topic' => $topic,
'forum' => $forum,
'category' => $category,
'posts' => $posts,
'firstPost' => $firstPost
]);
}
/**
* Add A Post To A Topic
*
* @param \Illuminate\Http\Request $request
* @param $slug
* @param $id
* @return Illuminate\Http\RedirectResponse
*/
public function reply(Request $request, $slug, $id)
{
$user = auth()->user();
$topic = Topic::findOrFail($id);
$forum = $topic->forum;
$category = $forum->getCategory();
// The user has the right to create a topic here?
if (!$category->getPermission()->reply_topic || ($topic->state == "close" && !auth()->user()->group->is_modo)) {
return redirect()->route('forum_index')
->with($this->toastr->error('You Cannot Reply To This Topic!', 'Whoops!', ['options']));
}
$post = new Post();
$post->content = $request->input('content');
$post->user_id = $user->id;
$post->topic_id = $topic->id;
$v = validator($post->toArray(), [
'content' => 'required|min:1',
'user_id' => 'required',
'topic_id' => 'required'
]);
if ($v->fails()) {
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->error($v->errors()->toJson(), 'Whoops!', ['options']));
} else {
$post->save();
$appurl = config('app.url');
$href = "{$appurl}/forums/topic/{$topic->slug}.{$topic->id}?page={$post->getPageNumber()}#post-{$post->id}";
$message = "{$user->username} has tagged you in a forum post. You can view it [url=$href] HERE [/url]";
if ($this->tag->hasTags($request->input('content'))) {
//$this->tag->setDebug(true);
if ($this->tag->contains($request->input('content'), '@here') && $user->group->is_modo) {
$users = collect([]);
$topic->posts()->get()->each(function ($p, $v) use ($users) {
$users->push($p->user);
});
$this->tag->messageUsers(
$users,
"You are being notified by staff!",
$message
);
} else {
$this->tag->messageTaggedUsers(
$request->input('content'),
"You have been tagged by {$user->username}",
$message
);
}
}
// Save last post user data to topic table
$topic->last_post_user_id = $user->id;
$topic->last_post_user_username = $user->username;
// Count post in topic
$topic->num_post = Post::where('topic_id', $topic->id)->count();
// Update time
$topic->last_reply_at = $post->created_at;
// Save
$topic->save();
// Count posts
$forum->num_post = $forum->getPostCount($forum->id);
// Count topics
$forum->num_topic = $forum->getTopicCount($forum->id);
// Save last post user data to the forum table
$forum->last_post_user_id = $user->id;
$forum->last_post_user_username = $user->username;
// Save last topic data to the forum table
$forum->last_topic_id = $topic->id;
$forum->last_topic_name = $topic->name;
// Save
$forum->save();
// Post To Chatbox
$appurl = config('app.url');
$postUrl = "{$appurl}/forums/topic/{$topic->slug}.{$topic->id}?page={$post->getPageNumber()}#post-{$post->id}";
$profileUrl = "{$appurl}/{$user->username}.{$user->id}";
$this->chat->systemMessage(":robot: [b][color=#fb9776]System[/color][/b] : [url=$profileUrl]{$user->username}[/url] has left a reply on topic [url={$postUrl}]{$topic->name}[/url]");
// Notify All Subscribers Of New Reply
$topic->notifySubscribers($post);
//Achievements
$user->unlock(new UserMadeFirstPost(), 1);
$user->addProgress(new UserMade25Posts(), 1);
$user->addProgress(new UserMade50Posts(), 1);
$user->addProgress(new UserMade100Posts(), 1);
$user->addProgress(new UserMade200Posts(), 1);
$user->addProgress(new UserMade300Posts(), 1);
$user->addProgress(new UserMade400Posts(), 1);
$user->addProgress(new UserMade500Posts(), 1);
$user->addProgress(new UserMade600Posts(), 1);
$user->addProgress(new UserMade700Posts(), 1);
$user->addProgress(new UserMade800Posts(), 1);
$user->addProgress(new UserMade900Posts(), 1);
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->success('Post Successfully Posted', 'Yay!', ['options']));
}
}
/**
* Topic Add Form
*
* @param \Illuminate\Http\Request $request
* @param $slug
* @param $id
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
*/
public function addForm(Request $request, $slug, $id)
{
$forum = Forum::findOrFail($id);
$category = $forum->getCategory();
// The user has the right to create a topic here?
if ($category->getPermission()->start_topic != true) {
return redirect()->route('forum_index')
->with($this->toastr->error('You Cannot Start A New Topic Here!', 'Whoops!', ['options']));
}
return view('forum.new_topic', [
'forum' => $forum,
'category' => $category,
'title' => $request->input('title')
]);
}
/**
* Create A New Topic In The Forum
*
* @param \Illuminate\Http\Request $request
* @param $slug
* @param $id
* @return Illuminate\Http\RedirectResponse
*/
public function newTopic(Request $request, $slug, $id)
{
$user = auth()->user();
$forum = Forum::findOrFail($id);
$category = $forum->getCategory();
// The user has the right to create a topic here?
if ($category->getPermission()->start_topic != true) {
return redirect()->route('forum_index')
->with($this->toastr->error('You Cannot Start A New Topic Here!', 'Whoops!', ['options']));
}
// Create The Topic
$topic = new Topic();
$topic->name = $request->input('title');
$topic->slug = str_slug($request->input('title'));
$topic->state = 'open';
$topic->first_post_user_id = $topic->last_post_user_id = $user->id;
$topic->first_post_user_username = $topic->last_post_user_username = $user->username;
$topic->views = 0;
$topic->pinned = false;
$topic->forum_id = $forum->id;
$v = validator($topic->toArray(), [
'name' => 'required',
'slug' => 'required',
'state' => 'required',
'num_post' => '',
'first_post_user_id' => 'required',
'first_post_user_username' => 'required',
'last_post_user_id' => '',
'last_post_user_username' => '',
'views' => '',
'pinned' => '',
'forum_id' => 'required'
]);
if ($v->fails()) {
return redirect()->route('forum_index')
->with($this->toastr->error($v->errors()->toJson(), 'Whoops!', ['options']));
} else {
$topic->save();
$post = new Post();
$post->content = $request->input('content');
$post->user_id = $user->id;
$post->topic_id = $topic->id;
$v = validator($post->toArray(), [
'content' => 'required',
'user_id' => 'required',
'topic_id' => 'required'
]);
if ($v->fails()) {
return redirect()->route('forum_index')
->with($this->toastr->error($v->errors()->toJson(), 'Whoops!', ['options']));
} else {
$post->save();
$topic->num_post = 1;
$topic->last_reply_at = $post->created_at;
$topic->save();
$forum->num_topic = $forum->getTopicCount($forum->id);
$forum->num_post = $forum->getPostCount($forum->id);
$forum->last_topic_id = $topic->id;
$forum->last_topic_name = $topic->name;
$forum->last_topic_slug = $topic->slug;
$forum->last_post_user_id = $user->id;
$forum->last_post_user_username = $user->username;
$forum->save();
// Post To ShoutBox
$appurl = config('app.url');
$topicUrl = "{$appurl}/forums/topic/{$topic->slug}.{$topic->id}";
$profileUrl = "{$appurl}/{$user->username}.{$user->id}";
$this->chat->systemMessage(":robot: [b][color=#fb9776]System[/color][/b] : [url={$profileUrl}]{$user->username}[/url] has created a new topic [url={$topicUrl}]{$topic->name}[/url]");
//Achievements
$user->unlock(new UserMadeFirstPost(), 1);
$user->addProgress(new UserMade25Posts(), 1);
$user->addProgress(new UserMade50Posts(), 1);
$user->addProgress(new UserMade100Posts(), 1);
$user->addProgress(new UserMade200Posts(), 1);
$user->addProgress(new UserMade300Posts(), 1);
$user->addProgress(new UserMade400Posts(), 1);
$user->addProgress(new UserMade500Posts(), 1);
$user->addProgress(new UserMade600Posts(), 1);
$user->addProgress(new UserMade700Posts(), 1);
$user->addProgress(new UserMade800Posts(), 1);
$user->addProgress(new UserMade900Posts(), 1);
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->success('Topic Created Successfully!', 'Yay!', ['options']));
}
}
}
/**
* Topic Edit Form
*
* @param $slug
* @param $id
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
*/
public function editForm($slug, $id)
{
$topic = Topic::findOrFail($id);
$categories = Forum::where('parent_id', '!=', 0)->get();
return view('forum.edit_topic', ['topic' => $topic, 'categories' => $categories]);
}
/**
* Edit Topic In The Forum
*
* @param \Illuminate\Http\Request $request
* @param $slug
* @param $id
* @return Illuminate\Http\RedirectResponse
*/
public function editTopic(Request $request, $slug, $id)
{
$user = auth()->user();
$topic = Topic::findOrFail($id);
abort_unless($user->group->is_modo, 403);
$name = $request->input('name');
$forum_id = $request->input('forum_id');
$topic->name = $name;
$topic->forum_id = $forum_id;
$topic->save();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->success('Topic Successfully Edited', 'Yay!', ['options']));
}
/**
* Edit Post Form
*
* @param $slug
* @param $id
* @param $postId
* @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
*/
public function postEditForm($slug, $id, $postId)
{
$topic = Topic::findOrFail($id);
$forum = $topic->forum;
$category = $forum->getCategory();
$post = Post::findOrFail($postId);
return view('forum.post_edit', [
'topic' => $topic,
'forum' => $forum,
'post' => $post,
'category' => $category,
]);
}
/**
* Edit A Post In A Topic
*
* @param \Illuminate\Http\Request $request
* @param $slug
* @param $id
* @param $postId
* @return Illuminate\Http\RedirectResponse
*/
public function postEdit(Request $request, $slug, $id, $postId)
{
$user = auth()->user();
$topic = Topic::findOrFail($id);
$post = Post::findOrFail($postId);
if ($user->group->is_modo == false) {
if ($post->user_id != $user->id) {
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->error('You Cannot Edit This!', 'Whoops!', ['options']));
}
}
$post->content = $request->input('content');
$post->save();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->success('Post Successfully Edited!', 'Yay!', ['options']));
}
/**
* Delete A Post
*
* @param $slug
* @param $id
* @param $postId
* @return Illuminate\Http\RedirectResponse
*/
public function postDelete($slug, $id, $postId)
{
$user = auth()->user();
$topic = Topic::findOrFail($id);
$post = Post::findOrFail($postId);
if ($user->group->is_modo == false) {
if ($post->user_id != $user->id) {
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->error('You Cannot Delete This!', 'Whoops!', ['options']));
}
}
$post->delete();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->success('This Post Is Now Deleted!', 'Success', ['options']));
}
/**
* Close The Topic
*
* @param $slug
* @param $id
* @return Illuminate\Http\RedirectResponse
*/
public function closeTopic($slug, $id)
{
$topic = Topic::findOrFail($id);
$topic->state = "close";
$topic->save();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->error('This Topic Is Now Closed!', 'Warning', ['options']));
}
/**
* Open The Topic
*
* @param $slug
* @param $id
* @return Illuminate\Http\RedirectResponse
*/
public function openTopic($slug, $id)
{
$topic = Topic::findOrFail($id);
$topic->state = "open";
$topic->save();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->success('This Topic Is Now Open!', 'Success', ['options']));
}
/**
* Delete The Topic and The Posts
*
* @param $slug
* @param $id
* @return Illuminate\Http\RedirectResponse
*/
public function deleteTopic($slug, $id)
{
$user = auth()->user();
$topic = Topic::findOrFail($id);
if ($user->group->is_modo == true) {
$posts = $topic->posts();
$posts->delete();
$topic->delete();
return redirect()->route('forum_display', ['slug' => $topic->forum->slug, 'id' => $topic->forum->id])
->with($this->toastr->error('This Topic Is Now Deleted!', 'Warning', ['options']));
} else {
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->error('You Do Not Have Access To Perform This Function!', 'Warning', ['options']));
}
}
/**
* Pin The Topic
*
* @param $slug
* @param $id
* @return Illuminate\Http\RedirectResponse
*/
public function pinTopic($slug, $id)
{
$topic = Topic::findOrFail($id);
$topic->pinned = 1;
$topic->save();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->success('This Topic Is Now Pinned!', 'Success', ['options']));
}
/**
* Unpin The Topic
*
* @param $slug
* @param $id
* @return Illuminate\Http\RedirectResponse
*/
public function unpinTopic($slug, $id)
{
$topic = Topic::findOrFail($id);
$topic->pinned = 0;
$topic->save();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->success('This Topic Is Now Unpinned!', 'Success', ['options']));
}
/**
* Forum Tag System
*
* @param $slug
* @param $id
* @return Illuminate\Http\RedirectResponse
*/
public function approvedTopic($slug, $id)
{
$topic = Topic::findOrFail($id);
if ($topic->approved == 0) {
$topic->approved = "1";
} else {
$topic->approved = "0";
}
$topic->save();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->info('Label Change Has Been Applied', 'Info', ['options']));
}
public function deniedTopic($slug, $id)
{
$topic = Topic::findOrFail($id);
if ($topic->denied == 0) {
$topic->denied = "1";
} else {
$topic->denied = "0";
}
$topic->save();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->info('Label Change Has Been Applied', 'Info', ['options']));
}
public function solvedTopic($slug, $id)
{
$topic = Topic::findOrFail($id);
if ($topic->solved == 0) {
$topic->solved = "1";
} else {
$topic->solved = "0";
}
$topic->save();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->info('Label Change Has Been Applied', 'Info', ['options']));
}
public function invalidTopic($slug, $id)
{
$topic = Topic::findOrFail($id);
if ($topic->invalid == 0) {
$topic->invalid = "1";
} else {
$topic->invalid = "0";
}
$topic->save();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->info('Label Change Has Been Applied', 'Info', ['options']));
}
public function bugTopic($slug, $id)
{
$topic = Topic::findOrFail($id);
if ($topic->bug == 0) {
$topic->bug = "1";
} else {
$topic->bug = "0";
}
$topic->save();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->info('Label Change Has Been Applied', 'Info', ['options']));
}
public function suggestionTopic($slug, $id)
{
$topic = Topic::findOrFail($id);
if ($topic->suggestion == 0) {
$topic->suggestion = "1";
} else {
$topic->suggestion = "0";
}
$topic->save();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->info('Label Change Has Been Applied', 'Info', ['options']));
}
public function implementedTopic($slug, $id)
{
$topic = Topic::findOrFail($id);
if ($topic->implemented == 0) {
$topic->implemented = "1";
} else {
$topic->implemented = "0";
}
$topic->save();
return redirect()->route('forum_topic', ['slug' => $topic->slug, 'id' => $topic->id])
->with($this->toastr->info('Label Change Has Been Applied', 'Info', ['options']));
}
/**
* Like A Post
*
* @param $postId
* @return Illuminate\Http\RedirectResponse
*/
public function likePost($postId)
{
$post = Post::findOrFail($postId);
$user = auth()->user();
$like = $user->likes()->where('post_id', $post->id)->where('like', 1)->first();
$dislike = $user->likes()->where('post_id', $post->id)->where('dislike', 1)->first();
if ($like || $dislike) {
return redirect()->route('forum_topic', ['slug' => $post->topic->slug, 'id' => $post->topic->id])
->with($this->toastr->error('You have already liked/disliked this post!', 'Bro', ['options']));
} elseif ($user->id == $post->user_id) {
return redirect()->route('forum_topic', ['slug' => $post->topic->slug, 'id' => $post->topic->id])
->with($this->toastr->error('You cannot like your own post!', 'Umm', ['options']));
} else {
$new = new Like();
$new->user_id = $user->id;
$new->post_id = $post->id;
$new->like = 1;
$new->save();
return redirect()->route('forum_topic', ['slug' => $post->topic->slug, 'id' => $post->topic->id])
->with($this->toastr->success('Like Successfully Applied!', 'Yay', ['options']));
}
}
/**
* Dislike A Post
*
* @param $postId
* @return Illuminate\Http\RedirectResponse
*/
public function dislikePost($postId)
{
$post = Post::findOrFail($postId);
$user = auth()->user();
$like = $user->likes()->where('post_id', $post->id)->where('like', 1)->first();
$dislike = $user->likes()->where('post_id', $post->id)->where('dislike', 1)->first();
if ($like || $dislike) {
return redirect()->route('forum_topic', ['slug' => $post->topic->slug, 'id' => $post->topic->id])
->with($this->toastr->error('You have already liked/disliked this post!', 'Bro', ['options']));
} elseif ($user->id == $post->user_id) {
return redirect()->route('forum_topic', ['slug' => $post->topic->slug, 'id' => $post->topic->id])
->with($this->toastr->error('You cannot like your own post!', 'Umm', ['options']));
} else {
$new = new Like();
$new->user_id = $user->id;
$new->post_id = $post->id;
$new->dislike = 1;
$new->save();
return redirect()->route('forum_topic', ['slug' => $post->topic->slug, 'id' => $post->topic->id])
->with($this->toastr->success('Dislike Successfully Applied!', 'Yay', ['options']));
}
}
}