<?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|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 edit(Labels $label) { abort(404); } public function destroy(Labels $label) { $label_id = $label->id; $items = Labels::find($label_id); $items->delete(); Cache::forget('labels_count'); Labels::deleteLabelAssignedAs($label_id); Cache::forget('all_labels'); return redirect()->route('labels.index') ->with('success', 'Label was deleted Successfully.'); } }