AssetController.php 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  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. $asset = Asset::allowed()->findOrFail($id);
  38. return new AssetResource($asset);
  39. }
  40. /**
  41. * Update the specified resource in storage.
  42. */
  43. public function update(Request $request, string $id)
  44. {
  45. $asset = Asset::allowed()->findOrFail($id);
  46. $asset->update([
  47. ...$request->all(),
  48. 'whitelist' => $request->whitelist ? sprintf(",%s", implode(',', $request->whitelist)) : null,
  49. ]);
  50. return $this->noContent();
  51. }
  52. /**
  53. * Remove the specified resource from storage.
  54. */
  55. public function destroy(string $id)
  56. {
  57. $asset = Asset::allowed()->findOrFail($id);
  58. $asset->delete();
  59. return $this->noContent();
  60. }
  61. }