<?php
namespace App\Http\Controllers\Admin;
use App\Http\Controllers\Controller;
use App\Models\Deposit;
use App\Models\NotificationLog;
use App\Models\Transaction;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Validator;
class ManageUsersController extends Controller
{
public function allUsers()
{
$pageTitle = 'All Users';
$users = $this->userData();
return view('admin.users.list', compact('pageTitle', 'users'));
}
public function activeUsers()
{
$pageTitle = 'Active Users';
$users = $this->userData('active');
return view('admin.users.list', compact('pageTitle', 'users'));
}
public function bannedUsers()
{
$pageTitle = 'Banned Users';
$users = $this->userData('banned');
return view('admin.users.list', compact('pageTitle', 'users'));
}
public function emailUnverifiedUsers()
{
$pageTitle = 'Email Unverified Users';
$users = $this->userData('emailUnverified');
return view('admin.users.list', compact('pageTitle', 'users'));
}
public function emailVerifiedUsers()
{
$pageTitle = 'Email Verified Users';
$users = $this->userData('emailVerified');
return view('admin.users.list', compact('pageTitle', 'users'));
}
public function mobileUnverifiedUsers()
{
$pageTitle = 'Mobile Unverified Users';
$users = $this->userData('mobileUnverified');
return view('admin.users.list', compact('pageTitle', 'users'));
}
public function mobileVerifiedUsers()
{
$pageTitle = 'Mobile Verified Users';
$users = $this->userData('mobileVerified');
return view('admin.users.list', compact('pageTitle', 'users'));
}
protected function userData($scope = null)
{
if ($scope) {
$users = User::$scope();
} else {
$users = User::query();
}
//search
$request = request();
if ($request->search) {
$search = $request->search;
$users = $users->where(function ($user) use ($search) {
$user->where('username', 'like', "%$search%")
->orWhere('email', 'like', "%$search%");
});
}
return $users->orderBy('id', 'desc')->paginate(getPaginate());
}
public function detail($id)
{
$user = User::findOrFail($id);
$pageTitle = 'User Details / @' . $user->username;
$totalDeposit = Deposit::where('user_id', $user->id)->where('status', 1)->sum('amount');
$totalTransaction = Transaction::where('user_id', $user->id)->count();
$countries = json_decode(file_get_contents(resource_path('views/includes/country.json')));
return view('admin.users.detail', compact('pageTitle', 'user', 'totalDeposit', 'totalTransaction', 'countries'));
}
public function update(Request $request, $id)
{
$user = User::findOrFail($id);
$countryData = json_decode(file_get_contents(resource_path('views/includes/country.json')));
$countryArray = (array)$countryData;
$countries = implode(',', array_keys($countryArray));
$countryCode = $request->country;
$country = $countryData->$countryCode->country;
$dialCode = $countryData->$countryCode->dial_code;
$request->validate([
'firstname' => 'required|string|max:40',
'lastname' => 'required|string|max:40',
'email' => 'required|email|string|max:40|unique:users,email,' . $user->id,
'mobile' => 'required|string|max:40|unique:users,mobile,' . $user->id,
'country' => 'required|in:' . $countries,
]);
$user->mobile = $dialCode . $request->mobile;
$user->country_code = $countryCode;
$user->firstname = $request->firstname;
$user->lastname = $request->lastname;
$user->email = $request->email;
$user->address = [
'address' => $request->address,
'city' => $request->city,
'state' => $request->state,
'zip' => $request->zip,
'country' => @$country,
];
$user->ev = $request->ev ? 1 : 0;
$user->sv = $request->sv ? 1 : 0;
$user->ts = $request->ts ? 1 : 0;
if (!$request->kv) {
$user->kv = 0;
} else {
$user->kv = 1;
}
$user->save();
$notify[] = ['success', 'User details has been updated successfully'];
return back()->withNotify($notify);
}
public function login($id)
{
Auth::loginUsingId($id);
return to_route('user.home');
}
public function status(Request $request, $id)
{
$user = User::findOrFail($id);
if ($user->status == 1) {
$request->validate([
'reason' => 'required|string|max:255'
]);
$user->status = 0;
$user->ban_reason = $request->reason;
$notify[] = ['success', 'User banned successfully'];
} else {
$user->status = 1;
$user->ban_reason = null;
$notify[] = ['success', 'User unbanned successfully'];
}
$user->save();
return back()->withNotify($notify);
}
public function showNotificationSingleForm($id)
{
$user = User::findOrFail($id);
$general = gs();
if (!$general->en && !$general->sn) {
$notify[] = ['warning', 'Notification options are disabled currently'];
return to_route('admin.users.detail', $user->id)->withNotify($notify);
}
$pageTitle = 'Send Notification to ' . $user->username;
return view('admin.users.notification_single', compact('pageTitle', 'user'));
}
public function sendNotificationSingle(Request $request, $id)
{
$request->validate([
'message' => 'required|string',
'subject' => 'required|string',
]);
$user = User::findOrFail($id);
notify($user, 'DEFAULT', [
'subject' => $request->subject,
'message' => $request->message,
]);
$notify[] = ['success', 'Notification sent successfully'];
return back()->withNotify($notify);
}
public function showNotificationAllForm()
{
$general = gs();
if (!$general->en && !$general->sn) {
$notify[] = ['warning', 'Notification options are disabled currently'];
return to_route('admin.dashboard')->withNotify($notify);
}
$users = User::where('ev', 1)->where('sv', 1)->where('status', 1)->count();
$pageTitle = 'Notification to Verified Users';
return view('admin.users.notification_all', compact('pageTitle', 'users'));
}
public function sendNotificationAll(Request $request)
{
$validator = Validator::make($request->all(), [
'message' => 'required',
'subject' => 'required',
]);
if ($validator->fails()) {
return response()->json(['error' => $validator->errors()->all()]);
}
$user = User::where('status', 1)->where('ev', 1)->where('sv', 1)->skip($request->skip)->first();
notify($user, 'DEFAULT', [
'subject' => $request->subject,
'message' => $request->message,
]);
return response()->json([
'success' => 'message sent',
'total_sent' => $request->skip + 1,
]);
}
public function notificationLog($id)
{
$user = User::findOrFail($id);
$pageTitle = 'Notifications Sent to ' . $user->username;
$logs = NotificationLog::where('user_id', $id)->with('user')->orderBy('id', 'desc')->paginate(getPaginate());
return view('admin.reports.notification_history', compact('pageTitle', 'logs', 'user'));
}
}