74 lines
2.0 KiB
PHP
74 lines
2.0 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Models\Labels;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Cache;
|
|
use Illuminate\Support\Facades\DB;
|
|
use Illuminate\Support\Str;
|
|
|
|
class LabelsController extends Controller
|
|
{
|
|
|
|
public function index()
|
|
{
|
|
$labels = Labels::all();
|
|
return view('labels.index', compact(['labels']));
|
|
}
|
|
|
|
public function create()
|
|
{
|
|
return view('labels.create');
|
|
}
|
|
|
|
public function store(Request $request)
|
|
{
|
|
$request->validate([
|
|
'label' => 'required|string|min:2'
|
|
]);
|
|
|
|
Labels::create([
|
|
'id' => Str::random(8),
|
|
'label' => $request->label
|
|
]);
|
|
|
|
Cache::forget('all_labels');
|
|
Cache::forget('labels_count');
|
|
|
|
return redirect()->route('labels.index')
|
|
->with('success', 'Label Created Successfully.');
|
|
}
|
|
|
|
public function show(Labels $label)
|
|
{
|
|
$labels = DB::table('labels_assigned as las')
|
|
->leftJoin('pricings as p', 'las.service_id', 'p.service_id')
|
|
->leftJoin('servers as s', 'las.service_id', 's.id')
|
|
->leftJoin('shared_hosting as sh', 'las.service_id', 'sh.id')
|
|
->leftJoin('reseller_hosting as r', 'las.service_id', 'r.id')
|
|
->leftJoin('domains as d', 'las.service_id', 'd.id')
|
|
->where('las.label_id', $label->id)
|
|
->get(['p.service_type', 'p.service_id', 's.hostname', 'sh.main_domain as shared', 'r.main_domain as reseller', 'd.domain', 'd.extension']);
|
|
|
|
return view('labels.show', compact(['label', 'labels']));
|
|
}
|
|
|
|
public function destroy(Labels $label)
|
|
{
|
|
if ($label->delete()) {
|
|
Cache::forget('labels_count');
|
|
|
|
Labels::deleteLabelAssignedAs($label->id);
|
|
|
|
Cache::forget('all_labels');
|
|
|
|
return redirect()->route('labels.index')
|
|
->with('success', 'Label was deleted Successfully.');
|
|
}
|
|
|
|
return redirect()->route('labels.index')
|
|
->with('error', 'Label was not deleted.');
|
|
}
|
|
}
|