Current File : /home/getxxhzo/app.genicards.com/app/Http/Controllers/API/AuthAPIController.php
<?php

namespace App\Http\Controllers\API;

use App\Http\Controllers\AppBaseController;
use App\Models\Role;
use App\Models\User;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use App\Mail\ForgetPasswordMail;
use App\Repositories\UserRepository;
use Carbon\Carbon;
use Auth;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Mail;
use Illuminate\Support\Str;

class AuthAPIController extends AppBaseController
{
    public UserRepository $userRepo;

    /**
     * UserController constructor.
     */
    public function __construct(UserRepository $userRepository)
    {
        $this->userRepo = $userRepository;
    }

    public function login(Request $request): JsonResponse
    {
        $email = $request->get('email');
        $password = $request->get('password');

        if (empty($email) or empty($password)) {
            return $this->sendError(__('Username and password required.'), 422);
        }
        $user = User::whereRaw('lower(email) = ?', [$email])->first();

        if (empty($user)) {
            return $this->sendError(__('Invalid username or password.'), 422);
        }

        if (!Hash::check($password, $user->password)) {
            return $this->sendError(__('Invalid username or password.'), 422);
        }

        if (!$user->email_verified_at) {
            return $this->sendError(__('Email not verified. Please verify your email before logging in.'), 422);
        }

        $token = $user->createToken('token')->plainTextToken;
        $user->last_name = $user->last_name ?? '';


        if ($user->hasRole(Role::ROLE_SUPER_ADMIN)) {
            $data = [
                'token' => $token,
                'user_id' => $user->id,
                'role' => 'Super Admin',
            ];
        }   elseif ($user->hasRole(Role::ROLE_ADMIN)) {
            $data = [
                'token' => $token,
                'user_id' => $user->id,
                'role' => 'Admin',
            ];
        } elseif ($user->hasRole(Role::ROLE_USER)){
            $data = [
                'token' => $token,
                'user_id' => $user->id,
                'role' => 'User',
            ];
        } else {
            return $this->sendError(__('Invalid username or password.'), 422);
        }

        return $this->sendResponse($data, __('Logged in successfully.'));
    }

    public function logout(): JsonResponse
    {
        auth()->user()->tokens()->where('id', Auth::user()->currentAccessToken()->id)->delete();

        return $this->sendSuccess(__('Logout successfully.'));
    }

    public function sendPasswordResetLinkEmail(Request $request): JsonResponse
    {
        $request->validate(['email' => 'required|email', 'url_domain' => 'required']);

        $data['user'] = User::whereEmail($request->email)->first();

        if (! $data['user']) {
            return $this->sendError(__('We can\'t find user with this email address.'));
        }

        $data['token'] = encrypt($data['user']->email.' '.$data['user']->id);
        $data['url'] = $request->url_domain.'//nfcdemo.com/createNewPassword?token='.$data['token'].'&email='.$request->email.'&apn=com.example.infyvcards_flutter';

        Mail::to($data['user']->email)
            ->send(new ForgetPasswordMail('emails.forget_password',
                'Reset Password Notification',
                $data));

        $user = DB::table('password_reset_tokens')->where('email', $request->email)->first();

        if ($user) {
            DB::table('password_reset_tokens')->where('email', $user->email)->update([
                'email' => $request->email,
                'token' => $data['token'],
                'created_at' => Carbon::now(),
            ]);
        } else {
            DB::table('password_reset_tokens')->insert([
                'email' => $request->email,
                'token' => $data['token'],
                'created_at' => Carbon::now(),
            ]);
        }

        return $this->sendSuccess(__('We have e-mailed your password reset link!'));
    }

    public function resetPassword(Request $request)
    {
        $passwordToken = DB::table('password_reset_tokens')->where('token', $request->token)->first();


        if (empty($passwordToken)) {
            return $this->sendError('Invalid or expired password reset token.');
        }

        $user = User::where('email', $passwordToken->email)->first();
        $user->update([
            'password' => Hash::make($request->password),
            'remember_token' => Str::random(60),
        ]);

        DB::table('password_reset_tokens')->where('token', $request->token)->delete();

        return $this->sendSuccess('Password updated successfully.');
    }

    public function changePassword(Request $request): JsonResponse
    {
        $user = User::where('email', $request->email)->first();

        if (!$user) {
            return $this->sendError(__('Email not found.'));
        }

        if ($request->has('old_password') && !Hash::check($request->old_password, $user->password)) {
            return $this->sendError(__('Please enter correct old password'));
        }

        $user->password = Hash::make($request->password);
        $user->save();

        return $this->sendSuccess(__('Password updated successfully'));
    }

    public function userDelete(User $user)
    {
        $tenant_id = getLogInTenantId();
        $userData = User::where('tenant_id', $tenant_id)->where('id', $user->id)->first();

        if ($userData && !$userData->hasRole(Role::ROLE_SUPER_ADMIN)) {
            $result = $this->userRepo->userDataDelete($userData);

            if ($result) {
                return $this->sendSuccess(__('User deleted successfully'));
            }
        }

        return $this->sendError('Error deleting user.');
    }
}