Changeset View
Changeset View
Standalone View
Standalone View
src/app/Http/Controllers/API/V4/Admin/WalletsController.php
<?php | <?php | ||||
namespace App\Http\Controllers\API\V4\Admin; | namespace App\Http\Controllers\API\V4\Admin; | ||||
use App\Discount; | use App\Discount; | ||||
use App\Http\Controllers\API\V4\PaymentsController; | use App\Http\Controllers\API\V4\PaymentsController; | ||||
use App\Providers\PaymentProvider; | use App\Providers\PaymentProvider; | ||||
use App\Transaction; | use App\Transaction; | ||||
use App\Wallet; | use App\Wallet; | ||||
use Illuminate\Http\Request; | use Illuminate\Http\Request; | ||||
use Illuminate\Support\Facades\Auth; | |||||
use Illuminate\Support\Facades\DB; | use Illuminate\Support\Facades\DB; | ||||
use Illuminate\Support\Facades\Validator; | use Illuminate\Support\Facades\Validator; | ||||
class WalletsController extends \App\Http\Controllers\API\V4\WalletsController | class WalletsController extends \App\Http\Controllers\API\V4\WalletsController | ||||
{ | { | ||||
/** | /** | ||||
* Return data of the specified wallet. | * Return data of the specified wallet. | ||||
* | * | ||||
* @param string $id A wallet identifier | * @param string $id A wallet identifier | ||||
* | * | ||||
* @return \Illuminate\Http\JsonResponse The response | * @return \Illuminate\Http\JsonResponse The response | ||||
*/ | */ | ||||
public function show($id) | public function show($id) | ||||
{ | { | ||||
$wallet = Wallet::find($id); | $wallet = Wallet::find($id); | ||||
if (empty($wallet)) { | if (empty($wallet) || !Auth::guard()->user()->canRead($wallet)) { | ||||
return $this->errorResponse(404); | return $this->errorResponse(404); | ||||
} | } | ||||
$result = $wallet->toArray(); | $result = $wallet->toArray(); | ||||
$result['discount'] = 0; | $result['discount'] = 0; | ||||
$result['discount_description'] = ''; | $result['discount_description'] = ''; | ||||
if ($wallet->discount) { | if ($wallet->discount) { | ||||
$result['discount'] = $wallet->discount->discount; | $result['discount'] = $wallet->discount->discount; | ||||
$result['discount_description'] = $wallet->discount->description; | $result['discount_description'] = $wallet->discount->description; | ||||
} | } | ||||
$result['mandate'] = PaymentsController::walletMandate($wallet); | $result['mandate'] = PaymentsController::walletMandate($wallet); | ||||
$provider = PaymentProvider::factory($wallet); | $provider = PaymentProvider::factory($wallet); | ||||
$result['provider'] = $provider->name(); | $result['provider'] = $provider->name(); | ||||
$result['providerLink'] = $provider->customerLink($wallet); | $result['providerLink'] = $provider->customerLink($wallet); | ||||
$result['notice'] = $this->getWalletNotice($wallet); // for resellers | |||||
return response()->json($result); | return response()->json($result); | ||||
} | } | ||||
/** | /** | ||||
* Award/penalize a wallet. | * Award/penalize a wallet. | ||||
* | * | ||||
* @param \Illuminate\Http\Request $request The API request. | * @param \Illuminate\Http\Request $request The API request. | ||||
* @param string $id Wallet identifier | * @param string $id Wallet identifier | ||||
* | * | ||||
* @return \Illuminate\Http\JsonResponse The response | * @return \Illuminate\Http\JsonResponse The response | ||||
*/ | */ | ||||
public function oneOff(Request $request, $id) | public function oneOff(Request $request, $id) | ||||
{ | { | ||||
$wallet = Wallet::find($id); | $wallet = Wallet::find($id); | ||||
$user = Auth::guard()->user(); | |||||
if (empty($wallet)) { | if (empty($wallet) || !$user->canRead($wallet)) { | ||||
return $this->errorResponse(404); | return $this->errorResponse(404); | ||||
} | } | ||||
// Check required fields | // Check required fields | ||||
$v = Validator::make( | $v = Validator::make( | ||||
$request->all(), | $request->all(), | ||||
[ | [ | ||||
'amount' => 'required|numeric', | 'amount' => 'required|numeric', | ||||
Show All 19 Lines | public function oneOff(Request $request, $id) | ||||
'object_id' => $wallet->id, | 'object_id' => $wallet->id, | ||||
'object_type' => Wallet::class, | 'object_type' => Wallet::class, | ||||
'type' => $type, | 'type' => $type, | ||||
'amount' => $amount, | 'amount' => $amount, | ||||
'description' => $request->description | 'description' => $request->description | ||||
] | ] | ||||
); | ); | ||||
if ($user->role == 'reseller') { | |||||
if ($user->tenant && ($tenant_wallet = $user->tenant->wallet())) { | |||||
$desc = ($amount > 0 ? 'Awarded' : 'Penalized') . " user {$wallet->owner->email}"; | |||||
$method = $amount > 0 ? 'debit' : 'credit'; | |||||
$tenant_wallet->{$method}(abs($amount), $desc); | |||||
} | |||||
} | |||||
DB::commit(); | DB::commit(); | ||||
$response = [ | $response = [ | ||||
'status' => 'success', | 'status' => 'success', | ||||
'message' => \trans("app.wallet-{$type}-success"), | 'message' => \trans("app.wallet-{$type}-success"), | ||||
'balance' => $wallet->balance | 'balance' => $wallet->balance | ||||
]; | ]; | ||||
return response()->json($response); | return response()->json($response); | ||||
} | } | ||||
/** | /** | ||||
* Update wallet data. | * Update wallet data. | ||||
* | * | ||||
* @param \Illuminate\Http\Request $request The API request. | * @param \Illuminate\Http\Request $request The API request. | ||||
* @param string $id Wallet identifier | * @param string $id Wallet identifier | ||||
* | * | ||||
* @return \Illuminate\Http\JsonResponse The response | * @return \Illuminate\Http\JsonResponse The response | ||||
*/ | */ | ||||
public function update(Request $request, $id) | public function update(Request $request, $id) | ||||
{ | { | ||||
$wallet = Wallet::find($id); | $wallet = Wallet::find($id); | ||||
if (empty($wallet)) { | if (empty($wallet) || !Auth::guard()->user()->canRead($wallet)) { | ||||
return $this->errorResponse(404); | return $this->errorResponse(404); | ||||
} | } | ||||
if (array_key_exists('discount', $request->input())) { | if (array_key_exists('discount', $request->input())) { | ||||
if (empty($request->discount)) { | if (empty($request->discount)) { | ||||
$wallet->discount()->dissociate(); | $wallet->discount()->dissociate(); | ||||
$wallet->save(); | $wallet->save(); | ||||
} elseif ($discount = Discount::find($request->discount)) { | } elseif ($discount = Discount::withEnvTenant()->find($request->discount)) { | ||||
$wallet->discount()->associate($discount); | $wallet->discount()->associate($discount); | ||||
$wallet->save(); | $wallet->save(); | ||||
} | } | ||||
} | } | ||||
$response = $wallet->toArray(); | $response = $wallet->toArray(); | ||||
if ($wallet->discount) { | if ($wallet->discount) { | ||||
Show All 10 Lines |