pixelfed/app/Http/Controllers/PageController.php
2022-08-15 23:39:33 -06:00

120 lines
2.9 KiB
PHP

<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Auth, Cache;
use App\Page;
use App\Services\ConfigCacheService;
class PageController extends Controller
{
public function __construct()
{
$this->middleware(['auth', 'admin']);
}
protected function cacheKeys() {
return [
'/site/about' => 'site:about',
'/site/privacy' => 'site:privacy',
'/site/terms' => 'site:terms',
'/site/kb/community-guidelines' => 'site:help:community-guidelines',
'/site/legal-notice' => 'site:legal-notice'
];
}
protected function authCheck($admin_only = false)
{
$auth = $admin_only ?
Auth::check() && Auth::user()->is_admin == true :
Auth::check();
if($auth == false) {
abort(403);
}
}
public function edit(Request $request)
{
$this->authCheck(true);
$this->validate($request, [
'page' => 'required|string'
]);
$slug = urldecode($request->page);
if(in_array($slug, array_keys($this->cacheKeys())) == false) {
return redirect(route('admin.settings.pages'));
}
$page = Page::firstOrCreate(['slug' => $slug]);
return view('admin.pages.edit', compact('page'));
}
public function store(Request $request)
{
$this->validate($request, [
'slug' => 'required|string',
'content' => 'required|string',
'title' => 'nullable|string',
'active' => 'required|boolean'
]);
$slug = urldecode($request->input('slug'));
$page = Page::firstOrCreate(['slug' => $slug]);
$page->content = $request->input('content');
$page->title = $request->input('title');
$page->active = (bool) $request->input('active');
$page->save();
$keys = $this->cacheKeys();
$key = $keys[$page->slug];
Cache::forget($key);
if($page->slug === '/site/legal-notice') {
ConfigCacheService::put('instance.has_legal_notice', $page->active);
}
return response()->json(['msg' => 200]);
}
public function delete(Request $request)
{
$this->validate($request, [
'id' => 'required|integer|min:1|exists:pages,id'
]);
$page = Page::findOrFail($request->input('id'));
$keys = $this->cacheKeys();
$key = $keys[$page->slug];
$page->delete();
Cache::forget($key);
return redirect(route('admin.settings.pages'));
}
public function generatePage(Request $request)
{
$this->validate($request, [
'page' => 'required|string|in:about,terms,privacy,community_guidelines,legal_notice',
]);
$page = $request->input('page');
switch ($page) {
case 'about':
Page::firstOrCreate(['slug' => '/site/about']);
break;
case 'privacy':
Page::firstOrCreate(['slug' => '/site/privacy']);
break;
case 'terms':
Page::firstOrCreate(['slug' => '/site/terms']);
break;
case 'community_guidelines':
Page::firstOrCreate(['slug' => '/site/kb/community-guidelines']);
break;
case 'legal_notice':
Page::firstOrCreate(['slug' => '/site/legal-notice']);
break;
}
return redirect(route('admin.settings.pages'));
}
}