Browse Source

added voucher api

AVMG20 4 years ago
parent
commit
4d0c9deab9

+ 1 - 2
app/Http/Controllers/Admin/VoucherController.php

@@ -176,8 +176,7 @@ class VoucherController extends Controller
                 return '<span class="badge badge-' . $color . '">' . $voucher->getStatus() . '</span>';
             })
             ->editColumn('uses', function (Voucher $voucher) {
-                $userCount = $voucher->users()->count();
-                return "{$userCount} / {$voucher->uses}";
+                return "{$voucher->used} / {$voucher->uses}";
             })
             ->editColumn('credits', function (Voucher $voucher) {
                 return number_format($voucher->credits, 2, '.', '');

+ 134 - 0
app/Http/Controllers/Api/VoucherController.php

@@ -0,0 +1,134 @@
+<?php
+
+namespace App\Http\Controllers\Api;
+
+use App\Http\Controllers\Controller;
+use App\Models\Voucher;
+use Illuminate\Contracts\Pagination\LengthAwarePaginator;
+use Illuminate\Http\Request;
+use Illuminate\Http\Response;
+use Illuminate\Validation\Rule;
+
+class VoucherController extends Controller
+{
+    /**
+     * Display a listing of the resource.
+     *
+     * @return Response
+     */
+    public function index(Request $request)
+    {
+        return Voucher::paginate($request->query('per_page') ?? 50);
+    }
+
+    /**
+     * Show the form for creating a new resource.
+     *
+     * @return Response
+     */
+    public function create()
+    {
+        //
+    }
+
+    /**
+     * Store a newly created resource in storage.
+     *
+     * @param Request $request
+     * @return Response
+     */
+    public function store(Request $request)
+    {
+        $request->validate([
+            'memo'       => 'nullable|string|max:191',
+            'code'       => 'required|string|alpha_dash|max:36|min:4',
+            'uses'       => 'required|numeric|max:2147483647|min:1',
+            'credits'    => 'required|numeric|between:0,99999999',
+            'expires_at' => 'nullable|date_format:d-m-Y|after:today|before:10 years'
+        ]);
+
+        return Voucher::create($request->all());
+    }
+
+    /**
+     * Display the specified resource.
+     *
+     * @param int $id
+     * @return Response
+     */
+    public function show(int $id)
+    {
+        return Voucher::findOrFail($id);
+    }
+
+    /**
+     * Show the form for editing the specified resource.
+     *
+     * @param int $id
+     * @return Response
+     */
+    public function edit($id)
+    {
+        //
+    }
+
+    /**
+     * Update the specified resource in storage.
+     *
+     * @param Request $request
+     * @param int $id
+     * @return Response
+     */
+    public function update(Request $request, int $id)
+    {
+        $voucher = Voucher::findOrFail($id);
+
+        $request->validate([
+            'memo'       => 'nullable|string|max:191',
+            'code'       => 'required|string|alpha_dash|max:36|min:4',
+            'uses'       => 'required|numeric|max:2147483647|min:1',
+            'credits'    => 'required|numeric|between:0,99999999',
+            'expires_at' => 'nullable|date_format:d-m-Y|after:today|before:10 years'
+        ]);
+
+        $voucher->update($request->all());
+
+        return $voucher;
+    }
+
+    /**
+     * Remove the specified resource from storage.
+     *
+     * @param int $id
+     * @return Response
+     */
+    public function destroy(int $id)
+    {
+        $voucher = Voucher::findOrFail($id);
+        $voucher->delete();
+        return $voucher;
+    }
+
+
+    /**
+     * get linked users
+     * @param Request $request
+     * @param Voucher $voucher
+     * @return LengthAwarePaginator
+     */
+    public function users(Request $request, Voucher $voucher){
+        $request->validate([
+            'include' => [
+                'nullable',
+                'string',
+                Rule::in(['discorduser']),
+            ]
+        ]);
+
+        if($request->input('include') == 'discorduser'){
+            return $voucher->users()->with('discordUser')->paginate($request->query('per_page') ?? 50);
+        }
+
+        return $voucher->users()->paginate($request->query('per_page') ?? 50);
+    }
+}

+ 17 - 0
app/Models/Voucher.php

@@ -31,6 +31,23 @@ class Voucher extends Model
         'expires_at'
     ];
 
+    protected $appends = ['used' , 'status'];
+
+    /**
+     * @return int
+     */
+    public function getUsedAttribute()
+    {
+        return $this->users()->count();
+    }
+
+    /**
+     * @return string
+     */
+    public function getStatusAttribute(){
+        return $this->getStatus();
+    }
+
     /**
      *
      */

+ 4 - 0
routes/api.php

@@ -2,6 +2,7 @@
 
 use App\Http\Controllers\Api\ServerController;
 use App\Http\Controllers\Api\UserController;
+use App\Http\Controllers\Api\VoucherController;
 use Illuminate\Support\Facades\Route;
 
 /*
@@ -21,6 +22,9 @@ Route::middleware('api.token')->group(function () {
     Route::patch('/servers/{server}/suspend', [ServerController::class, 'suspend']);
     Route::patch('/servers/{server}/unsuspend', [ServerController::class, 'unSuspend']);
     Route::resource('servers', ServerController::class)->except(['store', 'create', 'edit', 'update']);
+
+//    Route::get('/vouchers/{voucher}/users' , [VoucherController::class , 'users']);
+    Route::resource('vouchers', VoucherController::class)->except('create' , 'edit');
 });