/
SettingController.php
128 lines (116 loc) · 3.54 KB
/
SettingController.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
<?php
namespace SEO\Http\Controllers;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
use SEO\Http\Requests\Settings\Edit;
use SEO\Http\Requests\Settings\Index;
use SEO\Http\Requests\Settings\Store;
use SEO\Http\Requests\Settings\Update;
use SEO\Models\MetaTag;
use SEO\Models\Setting;
use SEO\Services\HtaccessFile;
use SEO\Services\RobotTxt;
use SEO\Services\SiteMap;
/**
* Description of SettingController
*
* @author Tuhin Bepari <digitaldreams40@gmail.com>
*/
class SettingController extends Controller
{
/**
* Display a listing of the resource.
*
* @param Index $request
* @return Response
*/
public function index(Index $request)
{
return view('seo::pages.settings.index', [
'records' => Setting::paginate(10),
'model' => new Setting(),
'sitemaps' => (new SiteMap())->all(),
'metaTags'=>[]
]
);
}
/**
* Show the form for editing the specified resource.
*
* @param Edit $request
* @param Setting $setting
* @return Response
*/
public function edit(Edit $request, Setting $setting)
{
return view('seo::pages.settings.edit', [
'model' => $setting,
]);
}
/**
* Update a existing resource in storage.
*
* @param Update $request
* @param Setting $setting
* @return Response
*/
public function update(Update $request, Setting $setting)
{
$setting->fill($request->all());
if ($setting->save()) {
session()->flash(config('seo.flash_message'), 'Setting successfully updated');
return redirect()->route('seo::settings.index');
} else {
session()->flash(config('seo.flash_error'), 'Something is wrong while updating Setting');
}
return redirect()->back();
}
/**
* Update a existing resource in storage.
*
* @param Store $request
* @param Setting $setting
* @return Response
*/
public function store(Store $request)
{
$settings = $request->get('settings', []);
foreach ($settings as $key => $fields) {
Setting::where('key', $key)->update($fields);
}
$fields = $request->file('settings', []);
$files = Setting::upload($fields);
foreach ($files as $key => $fileFields) {
Setting::where('key', $key)->update($fileFields);
}
session()->flash(config('seo.flash_message'), 'Setting successfully updated');
return redirect()->back();
}
/**
* Update robot.txt file
*
* @param Request $request
* @return \Illuminate\Http\RedirectResponse
*/
public function robotTxt(Request $request)
{
$robotValue = $request->get('robot_txt');
$robotTxt = new RobotTxt();
$robotTxt->save($robotValue);
return redirect()->back()->with(config('seo.flash_message'), 'Robot.txt file updated successfully');
}
/**
* Update robot.txt file
*
* @param Request $request
* @return void
*/
public function htaccess(Request $request)
{
$htaccessValue = $request->get('htaccess');
$htaccess = new HtaccessFile();
$htaccess->save($htaccessValue);
return redirect()->back()->with(config('seo.flash_message'), '.htaccess file updated successfully');
}
}