You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

484 lines
22 KiB

<?php
namespace App\Http\Controllers\api\v1\auth;
use App\CentralLogics\CustomerLogic;
use Carbon\CarbonInterval;
use App\CentralLogics\Helpers;
use App\Http\Controllers\Controller;
use App\Models\User;
use GuzzleHttp\Client;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Validator;
use App\CentralLogics\SMS_module;
use App\Models\BusinessSetting;
use Illuminate\Support\Carbon;
use App\Models\WalletTransaction;
use Illuminate\Support\Facades\Mail;
use Illuminate\Support\Facades\DB;
use Firebase\JWT\JWT;
use Illuminate\Support\Facades\Http;
class SocialAuthController extends Controller
{
public function social_register(Request $request)
{
$validator = Validator::make($request->all(), [
'token' => 'required',
'unique_id' => 'required',
'email' => 'required_if:medium,google,facebook|unique:users,email',
'phone' => 'required|unique:users,phone',
'medium' => 'required|in:google,facebook,apple',
]);
if ($validator->fails()) {
return response()->json(['errors' => Helpers::error_processor($validator)], 403);
}
$client = new Client();
$token = $request['token'];
$email = $request['email'];
$unique_id = $request['unique_id'];
try {
if ($request['medium'] == 'google') {
$res = $client->request('GET', 'https://www.googleapis.com/oauth2/v3/tokeninfo?id_token=' . $token);
$data = json_decode($res->getBody()->getContents(), true);
} elseif ($request['medium'] == 'facebook') {
$res = $client->request('GET', 'https://graph.facebook.com/' . $unique_id . '?access_token=' . $token . '&&fields=name,email');
$data = json_decode($res->getBody()->getContents(), true);
} elseif ($request['medium'] == 'apple') {
$user = User::where('temp_token', $unique_id)->first();
$data = [
'email' => $user->email
];
}
} catch (\Exception $e) {
return response()->json(['error' => 'wrong credential.','message'=>$e->getMessage()],403);
}
if($request['medium'] == 'apple'){
$fast_name = implode('@', explode('@', $data['email'], -1));
$last_name = '';
$user = User::where('email', $data['email'])->where('phone', $request->phone)->where('temp_token', $unique_id)->first();
if (!isset($user)) {
//Check Exists Ref Code
$check_duplicate_ref = WalletTransaction::where('reference', $request->phone)->first();
//Check Exists Ref Code Condition
if ($check_duplicate_ref) {
return response()->json(['errors'=>['code'=>'ref_code','message'=>'Referral code already used']]);
} else {
$user = User::where('email', $data['email'])->where('temp_token', $unique_id)->first();
$user->phone = $request->phone;
$user->password = bcrypt($request->phone);
$user->ref_code = Helpers::generate_referer_code();
$user->save();
//Save point to refeer
if ($request->ref_code) {
$checkRefCode = $request->ref_code;
$referar_user = User::where('ref_code', '=', $checkRefCode)->first();
$ref_status = BusinessSetting::where('key', 'ref_earning_status')->first()->value;
if ($ref_status != '1') {
$errors = [];
array_push($errors, ['code' => 'ref_code', 'message' => translate('messages.referer_disable')]);
return response()->json([
'errors' => $errors
], 405);
}
if (!$referar_user) {
$errors = [];
array_push($errors, ['code' => 'ref_code', 'message' => translate('messages.referer_code_not_found')]);
return response()->json([
'errors' => $errors
], 405);
}
$user->ref_by =$referar_user->id;
$user->save();
// $ref_code_exchange_amt = BusinessSetting::where('key', 'ref_earning_exchange_rate')->first()->value;
// $refer_wallet_transaction = CustomerLogic::create_wallet_transaction($referar_user->id, $ref_code_exchange_amt, 'referrer', $user->phone);
// try {
// if (config('mail.status')) {
// Mail::to($referar_user->email)->send(new \App\Mail\AddFundToWallet($refer_wallet_transaction));
// }
// } catch (\Exception $ex) {
// info($ex);
// }
}
}
} else {
return response()->json([
'errors' => [
['code' => 'auth-004', 'message' => translate('messages.email_already_exists')]
]
], 403);
}
$data = [
'phone' => $user->phone,
'password' => $user->phone
];
$customer_verification = BusinessSetting::where('key','customer_verification')->first()->value;
if (auth()->attempt($data)) {
$token = auth()->user()->createToken('RestaurantCustomerAuth')->accessToken;
if(!auth()->user()->status)
{
$errors = [];
array_push($errors, ['code' => 'auth-003', 'message' => translate('messages.your_account_is_blocked')]);
return response()->json([
'errors' => $errors
], 403);
}
if($customer_verification && !auth()->user()->is_phone_verified && env('APP_MODE') != 'demo')
{
// $interval_time = BusinessSetting::where('key', 'otp_interval_time')->first();
// $otp_interval_time= isset($interval_time) ? $interval_time->value : 20;
$otp_interval_time= 60; //seconds
$phone_verification_data= DB::table('phone_verifications')->where('phone', $request['phone'])->first();
if(isset($phone_verification_data) && Carbon::parse($phone_verification_data->updated_at)->DiffInSeconds() < $otp_interval_time){
$time= $otp_interval_time - Carbon::parse($phone_verification_data->updated_at)->DiffInSeconds();
$errors = [];
array_push($errors, ['code' => 'otp', 'message' => translate('messages.please_try_again_after_').$time.' '.translate('messages.seconds')]);
return response()->json([
'errors' => $errors
], 405);
}
$otp = rand(1000, 9999);
DB::table('phone_verifications')->updateOrInsert(['phone' => $request['phone']],
[
'token' => $otp,
'created_at' => now(),
'updated_at' => now(),
]);
$response = SMS_module::send($request['phone'],$otp);
if($response != 'success')
{
$errors = [];
array_push($errors, ['code' => 'otp', 'message' => translate('messages.faield_to_send_sms')]);
return response()->json([
'errors' => $errors
], 403);
}
}
return response()->json(['token' => $token, 'is_phone_verified'=>auth()->user()->is_phone_verified], 200);
} else {
$errors = [];
array_push($errors, ['code' => 'auth-001', 'message' => 'Unauthorized.']);
return response()->json([
'errors' => $errors
], 401);
}
}
if ($request['medium'] != 'apple' && strcmp($email, $data['email']) === 0) {
$name = explode(' ', $data['name']);
if (count($name) > 1) {
$fast_name = implode(" ", array_slice($name, 0, -1));
$last_name = end($name);
} else {
$fast_name = implode(" ", $name);
$last_name = '';
}
$user = User::where('email', $email)->first();
if (isset($user) == false) {
//Check Exists Ref Code
$check_duplicate_ref = WalletTransaction::where('reference', $request->phone)->first();
//Check Exists Ref Code Condition
if ($check_duplicate_ref) {
return response()->json(['errors'=>['code'=>'ref_code','message'=>'Referral code already used']]);
} else {
if(!isset($data['id']) && !isset($data['kid'])){
return response()->json(['error' => 'wrong credential.'],403);
}
$pk = isset($data['id'])?$data['id']:$data['kid'];
$user = User::create([
'f_name' => $fast_name,
'l_name' => $last_name,
'email' => $email,
'phone' => $request->phone,
'password' => bcrypt($pk),
'login_medium' => $request['medium'],
'social_id' => $pk,
]);
$user->ref_code = Helpers::generate_referer_code();
$user->save();
//Save point to refeer
if ($request->ref_code) {
$checkRefCode = $request->ref_code;
$referar_user = User::where('ref_code', '=', $checkRefCode)->first();
$ref_status = BusinessSetting::where('key', 'ref_earning_status')->first()->value;
if ($ref_status != '1') {
$errors = [];
array_push($errors, ['code' => 'ref_code', 'message' => translate('messages.referer_disable')]);
return response()->json([
'errors' => $errors
], 405);
}
if (!$referar_user) {
$errors = [];
array_push($errors, ['code' => 'ref_code', 'message' => translate('messages.referer_code_not_found')]);
return response()->json([
'errors' => $errors
], 405);
}
$user->ref_by =$referar_user->id;
$user->save();
// $ref_code_exchange_amt = BusinessSetting::where('key', 'ref_earning_exchange_rate')->first()->value;
// $refer_wallet_transaction = CustomerLogic::create_wallet_transaction($referar_user->id, $ref_code_exchange_amt, 'referrer', $user->phone);
// try {
// if (config('mail.status')) {
// Mail::to($referar_user->email)->send(new \App\Mail\AddFundToWallet($refer_wallet_transaction));
// }
// } catch (\Exception $ex) {
// info($ex);
// }
}
}
} else {
return response()->json([
'errors' => [
['code' => 'auth-004', 'message' => translate('messages.email_already_exists')]
]
], 403);
}
$data = [
'phone' => $user->phone,
'password' => $user->social_id
];
$customer_verification = BusinessSetting::where('key','customer_verification')->first()->value;
if (auth()->loginUsingId($user->id)) {
$token = auth()->user()->createToken('RestaurantCustomerAuth')->accessToken;
if(!auth()->user()->status)
{
$errors = [];
array_push($errors, ['code' => 'auth-003', 'message' => translate('messages.your_account_is_blocked')]);
return response()->json([
'errors' => $errors
], 403);
}
if($customer_verification && !auth()->user()->is_phone_verified && env('APP_MODE') != 'demo')
{
// $interval_time = BusinessSetting::where('key', 'otp_interval_time')->first();
// $otp_interval_time= isset($interval_time) ? $interval_time->value : 20;
$otp_interval_time= 60; //seconds
$phone_verification_data= DB::table('phone_verifications')->where('phone', $request['phone'])->first();
if(isset($phone_verification_data) && Carbon::parse($phone_verification_data->updated_at)->DiffInSeconds() < $otp_interval_time){
$time= $otp_interval_time - Carbon::parse($phone_verification_data->updated_at)->DiffInSeconds();
$errors = [];
array_push($errors, ['code' => 'otp', 'message' => translate('messages.please_try_again_after_').$time.' '.translate('messages.seconds')]);
return response()->json([
'errors' => $errors
], 405);
}
$otp = rand(1000, 9999);
DB::table('phone_verifications')->updateOrInsert(['phone' => $request['phone']],
[
'token' => $otp,
'created_at' => now(),
'updated_at' => now(),
]);
$response = SMS_module::send($request['phone'],$otp);
if($response != 'success')
{
$errors = [];
array_push($errors, ['code' => 'otp', 'message' => translate('messages.faield_to_send_sms')]);
return response()->json([
'errors' => $errors
], 403);
}
}
return response()->json(['token' => $token, 'is_phone_verified'=>auth()->user()->is_phone_verified], 200);
} else {
$errors = [];
array_push($errors, ['code' => 'auth-001', 'message' => 'Unauthorized.']);
return response()->json([
'errors' => $errors
], 401);
}
}
return response()->json(['error' => translate('messages.email_does_not_match')]);
}
public function social_login(Request $request)
{
$validator = Validator::make($request->all(), [
'token' => 'required',
'unique_id' => 'required',
'email' => 'required_if:medium,google,facebook',
'medium' => 'required|in:google,facebook,apple',
]);
if ($validator->fails()) {
return response()->json(['errors' => Helpers::error_processor($validator)], 403);
}
$client = new Client();
$token = $request['token'];
$email = $request['email'];
$unique_id = $request['unique_id'];
try {
if ($request['medium'] == 'google') {
$res = $client->request('GET', 'https://www.googleapis.com/oauth2/v3/tokeninfo?id_token=' . $token);
$data = json_decode($res->getBody()->getContents(), true);
} elseif ($request['medium'] == 'facebook') {
$res = $client->request('GET', 'https://graph.facebook.com/' . $unique_id . '?access_token=' . $token . '&&fields=name,email');
$data = json_decode($res->getBody()->getContents(), true);
} elseif ($request['medium'] == 'apple') {
$apple_login=\App\Models\BusinessSetting::where(['key'=>'apple_login'])->first();
if($apple_login){
$apple_login = json_decode($apple_login->value)[0];
}
$teamId = $apple_login->team_id;
$keyId = $apple_login->key_id;
$sub = $apple_login->client_id;
$aud = 'https://appleid.apple.com';
$iat = strtotime('now');
$exp = strtotime('+60days');
$keyContent = file_get_contents('storage/app/public/apple-login/'.$apple_login->service_file);
$token = JWT::encode([
'iss' => $teamId,
'iat' => $iat,
'exp' => $exp,
'aud' => $aud,
'sub' => $sub,
], $keyContent, 'ES256', $keyId);
$redirect_uri = $apple_login->redirect_url??'www.example.com/apple-callback';
$res = Http::asForm()->post('https://appleid.apple.com/auth/token', [
'grant_type' => 'authorization_code',
'code' => $unique_id,
'redirect_uri' => $redirect_uri,
'client_id' => $sub,
'client_secret' => $token,
]);
$claims = explode('.', $res['id_token'])[1];
$data = json_decode(base64_decode($claims),true);
}
} catch (\Exception $e) {
return response()->json(['error' => 'wrong credential.','message'=>$e->getMessage()],403);
}
if(!isset($claims)){
if (strcmp($email, $data['email']) != 0 || (!isset($data['id']) && !isset($data['kid']))) {
return response()->json(['error' => translate('messages.email_does_not_match')],403);
}
}
$user = User::where('email', $data['email'])->first();
if($request['medium'] == 'apple'){
try {
if(isset($user) == false )
{
$user = new User();
}
$user->f_name = implode('@', explode('@', $data['email'], -1));
$user->l_name = '';
$user->email = $data['email'];
$user->login_medium = $request['medium'];
$user->temp_token = $unique_id;
$user->save();
} catch (\Throwable $e) {
return response()->json(['error' => 'wrong credential.','message'=>$e->getMessage()],403);
}
}
if(isset($user) == false )
{
return response()->json(['token' => null, 'is_phone_verified'=>0], 200);
}
if($request['medium'] == 'apple' && $user->phone == null)
{
return response()->json(['token' => null, 'is_phone_verified'=>0], 200);
}
$customer_verification = BusinessSetting::where('key','customer_verification')->first()->value;
if (auth()->loginUsingId($user->id)) {
$token = auth()->user()->createToken('RestaurantCustomerAuth')->accessToken;
if(!auth()->user()->status)
{
$errors = [];
array_push($errors, ['code' => 'auth-003', 'message' => translate('messages.your_account_is_blocked')]);
return response()->json([
'errors' => $errors
], 403);
}
if($customer_verification && !auth()->user()->is_phone_verified && env('APP_MODE') != 'demo')
{
// $interval_time = BusinessSetting::where('key', 'otp_interval_time')->first();
// $otp_interval_time= isset($interval_time) ? $interval_time->value : 20;
$otp_interval_time= 60; //seconds
$phone_verification_data= DB::table('phone_verifications')->where('phone', $request['phone'])->first();
if(isset($phone_verification_data) && Carbon::parse($phone_verification_data->updated_at)->DiffInSeconds() < $otp_interval_time){
$time= $otp_interval_time - Carbon::parse($phone_verification_data->updated_at)->DiffInSeconds();
$errors = [];
array_push($errors, ['code' => 'otp', 'message' => translate('messages.please_try_again_after_').$time.' '.translate('messages.seconds')]);
return response()->json([
'errors' => $errors
], 405);
}
$otp = rand(1000, 9999);
DB::table('phone_verifications')->updateOrInsert(['phone' => $user->phone],
[
'token' => $otp,
'otp_hit_count' => 0,
'created_at' => now(),
'updated_at' => now(),
]);
$response = SMS_module::send($user->phone,$otp);
if($response != 'success')
{
$errors = [];
array_push($errors, ['code' => 'otp', 'message' => translate('messages.faield_to_send_sms')]);
return response()->json([
'errors' => $errors
], 403);
}
}
if($user->ref_code == null && isset($user->id)){
$ref_code = Helpers::generate_referer_code($user);
DB::table('users')->where('phone', $user->phone)->update(['ref_code' => $ref_code]);
}
return response()->json(['token' => $token, 'is_phone_verified'=>auth()->user()->is_phone_verified, 'phone'=>$user->phone, 'res'=>$res], 200);
} else {
$errors = [];
array_push($errors, ['code' => 'auth-001', 'message' => 'Unauthorized.']);
return response()->json([
'errors' => $errors
], 401);
}
return response()->json([
'errors'=>[
['code'=>'not-found','message' => translate('messages.user_not_found')]
]
], 404);
}
}