Current File : /home/tradevaly/ladybagcollection.com/project/app/Http/Controllers/User/RazorpayController.php |
<?php
namespace App\Http\Controllers\User;
use Razorpay\Api\Api;
use App\Classes\GeniusMailer;
use App\Models\Generalsetting;
use App\Models\Subscription;
use App\Models\User;
use App\Models\UserSubscription;
use Auth;
use Carbon\Carbon;
use Config;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Redirect;
use Illuminate\Support\Facades\Session;
use App\Http\Controllers\Controller;
use App\Models\Currency;
use Illuminate\Support\Str;
class RazorpayController extends Controller
{
public function __construct()
{
$rdata = Generalsetting::findOrFail(1);
$this->keyId = $rdata->razorpay_key;
$this->keySecret = $rdata->razorpay_secret;
$this->api = new Api($this->keyId, $this->keySecret);
$this->displayCurrency = 'INR';
}
public function store(Request $request){
$this->validate($request, [
'shop_name' => 'unique:users',
],[
'shop_name.unique' => 'This shop name has already been taken.'
]);
if (Session::has('currency'))
{
$curr = Currency::find(Session::get('currency'));
}
else
{
$curr = Currency::where('is_default','=',1)->first();
}
if($curr->name != "INR")
{
return redirect()->back()->with('unsuccess','Please Select INR Currency For Razorpay.');
}
$user = Auth::user();
$subs = Subscription::findOrFail($request->subs_id);
$settings = Generalsetting::findOrFail(1);
$paypal_email = $settings->paypal_business;
$return_url = action('User\PaypalController@payreturn');
$cancel_url = action('User\PaypalController@paycancle');
$notify_url = action('User\RazorpayController@notify');
$item_name = $subs->title." Plan";
$item_number = Str::random(4).time();
$item_amount = round($subs->price * $curr->value,2);
$orderData = [
'receipt' => $item_number,
'amount' => $item_amount * 100, // 2000 rupees in paise
'currency' => 'INR',
'payment_capture' => 1 // auto capture
];
$razorpayOrder = $this->api->order->create($orderData);
$razorpayOrderId = $razorpayOrder['id'];
session(['razorpay_order_id'=> $razorpayOrderId]);
// Redirect to paypal IPN
$sub = new UserSubscription;
$sub->user_id = $user->id;
$sub->subscription_id = $subs->id;
$sub->title = $subs->title;
$sub->currency = $subs->currency;
$sub->currency_code = $subs->currency_code;
$sub->price = $subs->price;
$sub->days = $subs->days;
$sub->allowed_products = $subs->allowed_products;
$sub->details = $subs->details;
$sub->method = 'Razorpay';
$sub->save();
$displayAmount = $amount = $orderData['amount'];
if ($this->displayCurrency !== 'INR')
{
$url = "https://api.fixer.io/latest?symbols=$this->displayCurrency&base=INR";
$exchange = json_decode(file_get_contents($url), true);
$displayAmount = $exchange['rates'][$this->displayCurrency] * $amount / 100;
}
$checkout = 'automatic';
if (isset($_GET['checkout']) and in_array($_GET['checkout'], ['automatic', 'manual'], true))
{
$checkout = $_GET['checkout'];
}
$data = [
"key" => $this->keyId,
"amount" => $amount,
"name" => $item_name,
"description" => $item_name,
"prefill" => [
"name" => Auth::user()->name,
"email" => Auth::user()->email,
"contact" => Auth::user()->phone,
],
"notes" => [
"address" => Auth::user()->address,
"merchant_order_id" => $item_number,
],
"theme" => [
"color" => "{{$settings->colors}}"
],
"order_id" => $razorpayOrderId,
];
if ($this->displayCurrency !== 'INR')
{
$data['display_currency'] = $this->displayCurrency;
$data['display_amount'] = $displayAmount;
}
$json = json_encode($data);
$displayCurrency = $this->displayCurrency;
Session::put('item_number',$sub->user_id);
return view( 'front.razorpay-checkout', compact( 'data','displayCurrency','json','notify_url' ) );
}
public function notify(Request $request){
$success = true;
$error = "Payment Failed";
if (empty($_POST['razorpay_payment_id']) === false)
{
try
{
$attributes = array(
'razorpay_order_id' => session('razorpay_order_id'),
'razorpay_payment_id' => $_POST['razorpay_payment_id'],
'razorpay_signature' => $_POST['razorpay_signature']
);
$this->api->utility->verifyPaymentSignature($attributes);
}
catch(SignatureVerificationError $e)
{
$success = false;
$error = 'Razorpay Error : ' . $e->getMessage();
}
}
if ($success === true)
{
$razorpayOrder = $this->api->order->fetch(session('razorpay_order_id'));
$order_id = $razorpayOrder['receipt'];
$transaction_id = $_POST['razorpay_payment_id'];
$order = UserSubscription::where('user_id','=',Session::get('item_number'))
->orderBy('created_at','desc')->first();
$user = User::findOrFail($order->user_id);
$package = $user->subscribes()->where('status',1)->orderBy('id','desc')->first();
$subs = Subscription::findOrFail($order->subscription_id);
$settings = Generalsetting::findOrFail(1);
$today = Carbon::now()->format('Y-m-d');
$date = date('Y-m-d', strtotime($today.' + '.$subs->days.' days'));
$input = $request->all();
$user->is_vendor = 2;
if(!empty($package))
{
if($package->subscription_id == $request->subs_id)
{
$newday = strtotime($today);
$lastday = strtotime($user->date);
$secs = $lastday-$newday;
$days = $secs / 86400;
$total = $days+$subs->days;
$user->date = date('Y-m-d', strtotime($today.' + '.$total.' days'));
}
else
{
$user->date = date('Y-m-d', strtotime($today.' + '.$subs->days.' days'));
}
}
else
{
$user->date = date('Y-m-d', strtotime($today.' + '.$subs->days.' days'));
}
$user->mail_sent = 1;
$user->update($input);
$data['txnid'] = $transaction_id;
$data['status'] = 1;
$order->update($data);
if($settings->is_smtp == 1)
{
$maildata = [
'to' => $user->email,
'type' => "vendor_accept",
'cname' => $user->name,
'oamount' => "",
'aname' => "",
'aemail' => "",
'onumber' => '',
];
$mailer = new GeniusMailer();
$mailer->sendAutoMail($maildata);
}
else
{
$headers = "From: ".$settings->from_name."<".$settings->from_email.">";
mail($user->email,'Your Vendor Account Activated','Your Vendor Account Activated Successfully. Please Login to your account and build your own shop.',$headers);
}
return redirect()->route('user-dashboard')->with('success','Vendor Account Activated Successfully');
return redirect()->route('payment.return');
}else{
$razorpayOrder = $this->api->order->fetch(session('razorpay_order_id'));
$order_id = $razorpayOrder['receipt'];
$payment = UserSubscription::where('user_id','=',$order_id)
->orderBy('created_at','desc')->first();
$payment->delete();
}
}
}