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
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);
|
|
}
|
|
|
|
}
|
|
|