Mikroserwisy obsługi paragonów #16
79
paragonik-backend/app/Http/Controllers/ReceiptController.php
Normal file
79
paragonik-backend/app/Http/Controllers/ReceiptController.php
Normal file
@ -0,0 +1,79 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Models\Receipt;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class ReceiptController extends Controller
|
||||
{
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function index()
|
||||
{
|
||||
return response()->json(Receipt::with('receipt_items')->get(), 200);
|
||||
}
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
$receipt = Receipt::create([
|
||||
'payment_date' => $request->payment_date,
|
||||
'payment_amount' => $request->payment_amount,
|
||||
'user_id' => $request->user_id,
|
||||
'store_id' => $request->store_id,
|
||||
]);
|
||||
|
||||
return response()->json($receipt, 201);
|
||||
}
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
$receipt = Receipt::with('receipt_items')->get()->find($id);
|
||||
if(is_null($receipt)){ return response()->json(["message " => "Record not found."], 404);}
|
||||
return response()->json($receipt, 200);
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
$receipt = Receipt::find($id);
|
||||
if(is_null($receipt)){ return response()->json(["message " => "Record not found."], 404);}
|
||||
$receipt->update($request->all());
|
||||
return response()->json($receipt, 200);
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function destroy($id)
|
||||
{
|
||||
$receipt = Receipt::find($id);
|
||||
if(is_null($receipt)){ return response()->json(["message " => "Record not found."], 404);}
|
||||
$receipt->delete();
|
||||
return response()->json(null, 204);
|
||||
}
|
||||
}
|
@ -0,0 +1,80 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
use App\Models\ReceiptItem;
|
||||
|
||||
class ReceiptItemController extends Controller
|
||||
{
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function index()
|
||||
{
|
||||
return response()->json(ReceiptItem::get(), 200);
|
||||
}
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
$receiptItem = ReceiptItem::create([
|
||||
'name' => $request->name,
|
||||
'price' => $request->price,
|
||||
'quantity' => $request->quantity,
|
||||
'receipt_id' => $request->receipt_id,
|
||||
'category_id' => $request->category_id,
|
||||
]);
|
||||
|
||||
return response()->json($receiptItem, 201);
|
||||
}
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
$receiptItem = ReceiptItem::find($id);
|
||||
if(is_null($receiptItem)){ return response()->json(["message " => "Record not found."], 404);}
|
||||
return response()->json($receiptItem, 200);
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
$receiptItem = ReceiptItem::find($id);
|
||||
if(is_null($receiptItem)){ return response()->json(["message " => "Record not found."], 404);}
|
||||
$receiptItem->update($request->all());
|
||||
return response()->json($receiptItem, 200);
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function destroy($id)
|
||||
{
|
||||
$receiptItem = ReceiptItem::find($id);
|
||||
if(is_null($receiptItem)){ return response()->json(["message " => "Record not found."], 404);}
|
||||
$receiptItem->delete();
|
||||
return response()->json(null, 204);
|
||||
}
|
||||
}
|
@ -6,6 +6,8 @@ use Illuminate\Database\Eloquent\Model;
|
||||
|
||||
class Receipt extends Model
|
||||
{
|
||||
protected $fillable = ['id', 'payment_date', 'payment_amount', 'user_id', 'store_id', 'created_at', 'updated_at'];
|
||||
|
||||
public function user()
|
||||
{
|
||||
return $this->belongsTo('App\User');
|
||||
|
@ -7,6 +7,7 @@ use Illuminate\Database\Eloquent\Model;
|
||||
class ReceiptItem extends Model
|
||||
{
|
||||
protected $table = 'receipt_items';
|
||||
protected $fillable = ['id', 'name', 'price', 'quantity' , 'receipt_id', 'category_id', 'created_at', 'updated_at'];
|
||||
|
||||
public function receipts()
|
||||
{
|
||||
|
45
paragonik-backend/app/User.php
Normal file
45
paragonik-backend/app/User.php
Normal file
@ -0,0 +1,45 @@
|
||||
<?php
|
||||
|
||||
namespace App;
|
||||
|
||||
use Illuminate\Notifications\Notifiable;
|
||||
use Illuminate\Contracts\Auth\MustVerifyEmail;
|
||||
use Illuminate\Foundation\Auth\User as Authenticatable;
|
||||
|
||||
class User extends Authenticatable
|
||||
{
|
||||
use Notifiable;
|
||||
|
||||
/**
|
||||
* The attributes that are mass assignable.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $fillable = [
|
||||
'name', 'email', 'password',
|
||||
];
|
||||
|
||||
/**
|
||||
* The attributes that should be hidden for arrays.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $hidden = [
|
||||
'password', 'remember_token',
|
||||
];
|
||||
|
||||
/**
|
||||
* The attributes that should be cast to native types.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $casts = [
|
||||
'email_verified_at' => 'datetime',
|
||||
];
|
||||
|
||||
|
||||
public function receipts()
|
||||
{
|
||||
return $this->hasMany('App\Models\Receipt');
|
||||
}
|
||||
}
|
23
paragonik-backend/routes/api.php
Normal file
23
paragonik-backend/routes/api.php
Normal file
@ -0,0 +1,23 @@
|
||||
<?php
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| API Routes
|
||||
|--------------------------------------------------------------------------
|
||||
|
|
||||
| Here is where you can register API routes for your application. These
|
||||
| routes are loaded by the RouteServiceProvider within a group which
|
||||
| is assigned the "api" middleware group. Enjoy building your API!
|
||||
|
|
||||
*/
|
||||
|
||||
#Route::apiResource('/receipt', 'ReceiptController');
|
||||
|
||||
Route::middleware('auth:api')->get('/user', function (Request $request) {
|
||||
return $request->user();
|
||||
});
|
||||
|
||||
Route::apiResource('receiptItem', 'ReceiptItemController');
|
||||
Route::apiResource('receipt', 'ReceiptController');
|
Loading…
Reference in New Issue
Block a user