filter($request->all())->get(); return CustomFieldResource::collection($customFields); } /** * Store a newly created resource in storage. */ public function store(CreateOrUpdateRequest $request) { if (Auth::user()->super_admin) { $namingRule = NamingRule::query()->where("id", $request->group)->first(); if (!in_array($request->group, config("custom-field.groups")) && !$namingRule) { return $this->forbidden("Operation without permission"); } } else { $namingRule = NamingRule::query()->where("company_id", Auth::user()->company_id)->where("id", $request->group)->first(); if (! $namingRule) { return $this->forbidden('Naming rule does not exist'); } } CustomField::query()->updateOrCreate([ 'group' => $request->group, 'key' => $request->key, ], $request->all()); return $this->created(); } public function groups() { return $this->success([ 'data' => config("custom-field.groups") ]); } /** * Display the specified resource. */ public function show(string $id) { $field = CustomField::query()->findOrFail($id); return new CustomFieldResource($field); } /** * Update the specified resource in storage. */ public function update(Request $request, string $id) { // } /** * Remove the specified resource from storage. */ public function destroy(string $id) { // } }