mirror of
				https://github.com/brunofontes/shareit.git
				synced 2025-10-25 07:31:07 -03:00 
			
		
		
		
	Now it shows the username of who is using an item. Item db field 'usedBy' was renamed to 'used_by' to keep consistence.
		
			
				
	
	
		
			125 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			125 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Http\Controllers;
 | |
| 
 | |
| use \App\User;
 | |
| use \App\Item;
 | |
| use \App\Product;
 | |
| use Illuminate\Http\Request;
 | |
| 
 | |
| class UserController extends Controller
 | |
| {
 | |
|     /**
 | |
|      * Display a listing of the resource.
 | |
|      *
 | |
|      * @return \Illuminate\Http\Response
 | |
|      */
 | |
|     public function index()
 | |
|     {
 | |
|         //
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Show the form for creating a new resource.
 | |
|      *
 | |
|      * @return \Illuminate\Http\Response
 | |
|      */
 | |
|     public function create()
 | |
|     {
 | |
|         //
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Store a newly created resource in storage.
 | |
|      *
 | |
|      * @param  \Illuminate\Http\Request  $request
 | |
|      * @return \Illuminate\Http\Response
 | |
|      */
 | |
|     public function store(Request $request)
 | |
|     {
 | |
|         $this->validate($request, ['email' => 'required', 'item_id' => 'required']);
 | |
|         
 | |
|         $userArray = User::where('email', request('email'))->get();
 | |
|         
 | |
|         if (count($userArray) == 0) {
 | |
|             return back()->withErrors("The e-mail address is not registered yet.");
 | |
|         }
 | |
|         
 | |
|         $item = Item::findOrFail(request('item_id'));
 | |
|         if ($item->product->user_id == \Auth::id()) {
 | |
|             User::findOrFail($userArray[0]->id)->items()->syncWithoutDetaching([request('item_id')]);
 | |
|         } else {
 | |
|             return back()->withErrors("You cannot add a user to a product that is not yourse.");
 | |
|         }
 | |
|         return back();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Delete the specified attachment.
 | |
|      *
 | |
|      * @param  int  $id
 | |
|      * @return \Illuminate\Http\Response
 | |
|      */
 | |
|     public function delete(Request $request)
 | |
|     {
 | |
|         $this->validate($request, ['user_id' => 'required', 'item_id' => 'required']);
 | |
|         
 | |
|         $item = Item::findOrFail(request('item_id'));
 | |
| 
 | |
|         if ($item->product->user_id == \Auth::id()) {
 | |
|             $returnItem = User::findOrFail(request('user_id'))->items()->findOrFail(request('item_id'));
 | |
|             $returnItem->used_by = null;
 | |
|             $returnItem->save();
 | |
|             User::findOrFail(request('user_id'))->items()->detach([request('item_id')]);
 | |
|         } else {
 | |
|             return back()->withErrors("You cannot remove a user from a product that is not yourse.");
 | |
|         }
 | |
|         return back();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Display the specified resource.
 | |
|      *
 | |
|      * @param  int  $id
 | |
|      * @return \Illuminate\Http\Response
 | |
|      */
 | |
|     public function show($id)
 | |
|     {
 | |
|         //
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Show the form for editing the specified resource.
 | |
|      *
 | |
|      * @param  int  $id
 | |
|      * @return \Illuminate\Http\Response
 | |
|      */
 | |
|     public function edit($id)
 | |
|     {
 | |
|         //
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Update the specified resource in storage.
 | |
|      *
 | |
|      * @param  \Illuminate\Http\Request  $request
 | |
|      * @param  int  $id
 | |
|      * @return \Illuminate\Http\Response
 | |
|      */
 | |
|     public function update(Request $request, $id)
 | |
|     {
 | |
|         //
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Remove the specified resource from storage.
 | |
|      *
 | |
|      * @param  int  $id
 | |
|      * @return \Illuminate\Http\Response
 | |
|      */
 | |
|     public function destroy($id)
 | |
|     {
 | |
|         //
 | |
|     }
 | |
| }
 |