You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
94 lines
2.8 KiB
PHP
94 lines
2.8 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Models\Setting;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Cache;
|
|
use Illuminate\Support\Facades\DB;
|
|
|
|
class SettingController extends Controller
|
|
{
|
|
public function index()
|
|
{
|
|
$setting = Setting::all();
|
|
|
|
return inertia('Setting/Index', [
|
|
'setting' => $setting,
|
|
'midtrans_notification_url' => route('api.midtrans.notification'),
|
|
]);
|
|
}
|
|
|
|
public function update(Request $request)
|
|
{
|
|
$request->validate([
|
|
'OPEN_WEBSITE_NAME' => 'required|string',
|
|
'AFFILATE_ENABLED' => 'required|in:0,1',
|
|
'AFFILATE_POIN_AMOUNT' => 'required|numeric',
|
|
'MIDTRANS_SERVER_KEY' => 'required|string',
|
|
'MIDTRANS_CLIENT_KEY' => 'required|string',
|
|
'MIDTRANS_MERCHANT_ID' => 'required|string',
|
|
'MIDTRANS_ENABLED' => 'required|in:0,1',
|
|
'midtrans_logo_file' => 'nullable|image',
|
|
]);
|
|
|
|
DB::beginTransaction();
|
|
foreach ($request->except(['midtrans_logo_file']) as $key => $value) {
|
|
Setting::where('key', $key)->update(['value' => $value]);
|
|
}
|
|
|
|
if ($request->hasFile('midtrans_logo_file')) {
|
|
$file = $request->file('midtrans_logo_file');
|
|
$file->store('uploads', 'public');
|
|
Setting::where('key', 'MIDTRANS_LOGO')->update(['value' => $file->hashName('uploads')]);
|
|
}
|
|
|
|
Cache::flush();
|
|
|
|
DB::commit();
|
|
|
|
session()->flash('message', ['type' => 'success', 'message' => 'Setting has beed saved']);
|
|
}
|
|
|
|
public function payment()
|
|
{
|
|
$setting = Setting::all();
|
|
|
|
return inertia('Setting/Payment', [
|
|
'setting' => $setting,
|
|
'midtrans_notification_url' => route('api.midtrans.notification'),
|
|
|
|
]);
|
|
}
|
|
|
|
|
|
public function updatePayment(Request $request)
|
|
{
|
|
$request->validate([
|
|
'MIDTRANS_SERVER_KEY' => 'required|string',
|
|
'MIDTRANS_CLIENT_KEY' => 'required|string',
|
|
'MIDTRANS_MERCHANT_ID' => 'required|string',
|
|
'MIDTRANS_ADMIN_FEE' => 'required|numeric',
|
|
'MIDTRANS_ENABLED' => 'required|in:0,1',
|
|
'midtrans_logo_file' => 'nullable|image',
|
|
]);
|
|
|
|
DB::beginTransaction();
|
|
foreach ($request->except(['midtrans_logo_file']) as $key => $value) {
|
|
Setting::where('key', $key)->update(['value' => $value]);
|
|
}
|
|
|
|
if ($request->hasFile('midtrans_logo_file')) {
|
|
$file = $request->file('midtrans_logo_file');
|
|
$file->store('uploads', 'public');
|
|
Setting::where('key', 'MIDTRANS_LOGO')->update(['value' => $file->hashName('uploads')]);
|
|
}
|
|
|
|
Cache::flush();
|
|
|
|
DB::commit();
|
|
|
|
session()->flash('message', ['type' => 'success', 'message' => 'Setting has beed saved']);
|
|
}
|
|
}
|