<?php
namespace App\Http\Controllers\User;
use Carbon\Carbon;
use App\Models\Form;
use App\Models\Post;
use App\Models\User;
use App\Models\Category;
use App\Lib\FormProcessor;
use App\Models\Transaction;
use Illuminate\Http\Request;
use App\Lib\GoogleAuthenticator;
use Illuminate\Support\Facades\DB;
use App\Http\Controllers\Controller;
class UserController extends Controller
{
public function home(Request $request)
{
$pageTitle = 'Dashboard';
$reference = @$_GET['reference'];
if ($reference) {
session()->put('reference', $reference);
}
$posts = Post::where('user_id', auth()->id())->where('type', auth()->user()->type)->where('status', 1)->with('user', 'comments', 'votes', 'bookmarks')->orderBy('id','desc')->paginate(10);
$user = User::where('id',auth()->user()->id)->with('posts.comments')->first();
$categories = Category::where('status',1)->get();
if ($request->ajax()) {
$view = view($this->activeTemplate . 'components.main', compact('posts', 'pageTitle', 'user','categories'))->render();
return response()->json(['html' => $view]);
}
return view($this->activeTemplate . 'user.dashboard', compact('pageTitle','posts','user','categories'));
}
public function depositHistory(Request $request)
{
$pageTitle = 'Deposit History';
$deposits = auth()->user()->deposits();
$user = User::where('id',auth()->user()->id)->with('posts.comments')->first();
if ($request->search) {
$deposits = $deposits->where('trx', $request->search);
}
$deposits = $deposits->with(['gateway','price_plan'])->orderBy('id', 'desc')->paginate(getPaginate());
return view($this->activeTemplate . 'user.deposit_history', compact('pageTitle', 'deposits','user'));
}
public function show2faForm()
{
$general = gs();
$ga = new GoogleAuthenticator();
$user = User::where('id',auth()->user()->id)->with('posts.comments')->first();
$secret = $ga->createSecret();
$qrCodeUrl = $ga->getQRCodeGoogleUrl($user->username . '@' . $general->site_name, $secret);
$pageTitle = '2FA Setting';
return view($this->activeTemplate . 'user.twofactor', compact('pageTitle', 'secret', 'qrCodeUrl','user'));
}
public function create2fa(Request $request)
{
$user = User::where('id',auth()->user()->id)->with('posts.comments')->first();
$this->validate($request, [
'key' => 'required',
'code' => 'required',
]);
$response = verifyG2fa($user, $request->code, $request->key);
if ($response) {
$user->tsc = $request->key;
$user->ts = 1;
$user->save();
$notify[] = ['success', 'Google authenticator activated successfully'];
return back()->withNotify($notify);
} else {
$notify[] = ['error', 'Wrong verification code'];
return back()->withNotify($notify);
}
}
public function disable2fa(Request $request)
{
$this->validate($request, [
'code' => 'required',
]);
$user = auth()->user();
$response = verifyG2fa($user, $request->code);
if ($response) {
$user->tsc = null;
$user->ts = 0;
$user->save();
$notify[] = ['success', 'Two factor authenticator deactivated successfully'];
} else {
$notify[] = ['error', 'Wrong verification code'];
}
return back()->withNotify($notify);
}
public function transactions(Request $request)
{
$pageTitle = 'Transactions';
$remarks = Transaction::distinct('remark')->orderBy('remark')->get('remark');
$transactions = Transaction::where('user_id', auth()->id());
if ($request->search) {
$transactions = $transactions->where('trx', $request->search);
}
if ($request->type) {
$transactions = $transactions->where('trx_type', $request->type);
}
if ($request->remark) {
$transactions = $transactions->where('remark', $request->remark);
}
$transactions = $transactions->orderBy('id', 'desc')->paginate(getPaginate());
return view($this->activeTemplate . 'user.transactions', compact('pageTitle', 'transactions', 'remarks'));
}
public function attachmentDownload($fileHash)
{
$filePath = decrypt($fileHash);
$extension = pathinfo($filePath, PATHINFO_EXTENSION);
$general = gs();
$title = slug($general->site_name) . '- attachments.' . $extension;
$mimetype = mime_content_type($filePath);
header('Content-Disposition: attachment; filename="' . $title);
header("Content-Type: " . $mimetype);
return readfile($filePath);
}
public function userData()
{
$user = auth()->user();
if ($user->reg_step == 1) {
return to_route('user.home');
}
$pageTitle = 'User Data';
return view($this->activeTemplate . 'user.user_data', compact('pageTitle', 'user'));
}
public function userDataSubmit(Request $request)
{
$user = auth()->user();
if ($user->reg_step == 1) {
return to_route('user.home');
}
$request->validate([
'firstname' => 'required',
'lastname' => 'required',
]);
$user->firstname = $request->firstname;
$user->lastname = $request->lastname;
$user->address = [
'country' => @$user->address->country,
'address' => $request->address,
'state' => $request->state,
'zip' => $request->zip,
'city' => $request->city,
];
$user->reg_step = 1;
$user->save();
$notify[] = ['success', 'Registration process completed successfully'];
return to_route('user.home')->withNotify($notify);
}
}