AssetController.php 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. <?php
  2. namespace App\Http\Controllers\API;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\API\Asset\CreateOrUpdateRequest;
  5. use App\Http\Resources\API\AssetResource;
  6. use App\Models\Asset;
  7. use Illuminate\Http\Request;
  8. use Illuminate\Support\Facades\Auth;
  9. class AssetController extends Controller
  10. {
  11. /**
  12. * Display a listing of the resource.
  13. */
  14. public function index(Request $request)
  15. {
  16. $assets = Asset::allowed()->filter($request->all())->get();
  17. return AssetResource::collection($assets);
  18. }
  19. /**
  20. * Store a newly created resource in storage.
  21. */
  22. public function store(CreateOrUpdateRequest $request)
  23. {
  24. Asset::create([
  25. ...$request->all(),
  26. 'company_id' => Auth::user()->company_id,
  27. 'whitelist' => $request->whitelist ? sprintf(",%s", implode(',', $request->whitelist)) : null,
  28. 'created_by' => Auth::id(),
  29. ]);
  30. return $this->created();
  31. }
  32. /**
  33. * Display the specified resource.
  34. */
  35. public function show(string $id)
  36. {
  37. //
  38. }
  39. /**
  40. * Update the specified resource in storage.
  41. */
  42. public function update(Request $request, string $id)
  43. {
  44. $asset = Asset::allowed()->findOrFail($id);
  45. $asset->update([
  46. ...$request->all(),
  47. 'whitelist' => $request->whitelist ? sprintf(",%s", implode(',', $request->whitelist)) : null,
  48. ]);
  49. return $this->noContent();
  50. }
  51. /**
  52. * Remove the specified resource from storage.
  53. */
  54. public function destroy(string $id)
  55. {
  56. $asset = Asset::allowed()->findOrFail($id);
  57. $asset->delete();
  58. return $this->noContent();
  59. }
  60. }