Current File : /home/tradevaly/ladybagcollection.com/project/app/Http/Controllers/User/PaypalController.php
<?php

namespace App\Http\Controllers\User;


use App\Classes\GeniusMailer;
use App\Models\Generalsetting;
use App\Models\Subscription;
use App\Models\User;
use App\Models\UserSubscription;
use Auth;
use Redirect;
use Carbon\Carbon;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Session;
use PayPal\Api\Amount;
use PayPal\Api\Item;
use PayPal\Api\ItemList;
use PayPal\Api\Payer;
use PayPal\Api\Payment;
use PayPal\Api\PaymentExecution;
use PayPal\Api\RedirectUrls;
use PayPal\Api\Transaction;
use PayPal\Auth\OAuthTokenCredential;
use PayPal\Rest\ApiContext;
use App\Http\Controllers\Controller;
use App\Models\Currency;
use Illuminate\Support\Str;

class PaypalController extends Controller
{
    private $_api_context;
    public function __construct()
    {
        $gs = Generalsetting::find(1);
        $paypal_conf = \Config::get('paypal');
        $paypal_conf['client_id'] = $gs->paypal_client_id;
        $paypal_conf['secret'] = $gs->paypal_client_secret;
        $paypal_conf['settings']['mode'] = $gs->paypal_sandbox_check == 1 ? 'sandbox' : 'live';
        $this->_api_context = new ApiContext(new OAuthTokenCredential(
            $paypal_conf['client_id'],
            $paypal_conf['secret'])
        );
        $this->_api_context->setConfig($paypal_conf['settings']);
    }


    public function store(Request $request){
        if (Session::has('currency')) 
        {
            $curr = Currency::find(Session::get('currency'));
        }
        else
        {
            $curr = Currency::where('is_default','=',1)->first();
        }
        
       
        $available_currency = ['USD','EUR'];
            
        if(!in_array($curr->name,$available_currency))
        {
        return redirect()->back()->with('unsuccess','Please Select USD Currency For Paypal.');
        }

        $this->validate($request, [
                'shop_name'   => 'unique:users',
            ],[ 
                'shop_name.unique' => 'This shop name has already been taken.'
            ]);

         $user = Auth::user();
         $subs = Subscription::findOrFail($request->subs_id);

         $sub['user_id'] = $user->id;
         $sub['subscription_id'] = $subs->id;
         $sub['title'] = $subs->title;
         $sub['currency'] = $curr->sign;
         $sub['currency_code'] = $curr->name;
         $sub['price'] = $subs->price;
         $sub['days'] = $subs->days;
         $sub['allowed_products'] = $subs->allowed_products;
         $sub['details'] = $subs->details;
         $sub['method'] = 'Paypal';     
    
        $order['item_name'] = $subs->title." Plan";
        $order['item_number'] = Str::random(4).time();
        $order['item_amount'] = round($subs->price * $curr->value,2);
        $cancel_url = action('User\PaypalController@paycancle');
        $notify_url = action('User\PaypalController@notify');
    
        $payer = new Payer();
        $payer->setPaymentMethod('paypal');
        $item_1 = new Item();
        $item_1->setName($order['item_name']) /** item name **/
            ->setCurrency($curr->name)
            ->setQuantity(1)
            ->setPrice($order['item_amount']); /** unit price **/
        $item_list = new ItemList();
        $item_list->setItems(array($item_1));
        $amount = new Amount();
        $amount->setCurrency($curr->name)
            ->setTotal($order['item_amount']);
        $transaction = new Transaction();
        $transaction->setAmount($amount)
            ->setItemList($item_list)
            ->setDescription($order['item_name'].' Via Paypal');
        $redirect_urls = new RedirectUrls();
        $redirect_urls->setReturnUrl($notify_url) /** Specify return URL **/
            ->setCancelUrl($cancel_url);
        $payment = new Payment();
        $payment->setIntent('Sale')
            ->setPayer($payer)
            ->setRedirectUrls($redirect_urls)
            ->setTransactions(array($transaction));
        /** dd($payment->create($this->_api_context));exit; **/
        try {
            $payment->create($this->_api_context);
        } catch (\PayPal\Exception\PPConnectionException $ex) {
            return redirect()->back()->with('unsuccess',$ex->getMessage());
        }
        foreach ($payment->getLinks() as $link) {
            if ($link->getRel() == 'approval_url') {
                $redirect_url = $link->getHref();
                    break;
            }
        }
        /** add payment ID to session **/
        Session::put('paypal_data',$sub);
        Session::put('paypal_payment_id', $payment->getId());
        if (isset($redirect_url)) {
            /** redirect to paypal **/
            return Redirect::away($redirect_url);
        }
        return redirect()->back()->with('unsuccess','Unknown error occurred');
     }


     public function paycancle(){
         return redirect()->back()->with('unsuccess','Payment Cancelled.');
     }

     public function payreturn(){
         return redirect()->route('user-dashboard')->with('success','Vendor Account Activated Successfully');
     }


     public function notify(Request $request){

        $paypal_data = Session::get('paypal_data');
        $success_url = action('User\PaypalController@payreturn');
        $cancel_url = action('User\PaypalController@paycancle');
        $input = $request->all();

        /** Get the payment ID before session clear **/
        $payment_id = Session::get('paypal_payment_id');
        /** clear the session payment ID **/
        if (empty( $input['PayerID']) || empty( $input['token'])) {
            return redirect($cancel_url);
        } 
        $payment = Payment::get($payment_id, $this->_api_context);
        $execution = new PaymentExecution();
        $execution->setPayerId($input['PayerID']);
        /**Execute the payment **/
        $result = $payment->execute($execution, $this->_api_context);
        if ($result->getState() == 'approved') {
            $resp = json_decode($payment, true);

                    $order = new UserSubscription;
                    $order->user_id = $paypal_data['user_id'];
                    $order->subscription_id = $paypal_data['subscription_id'];
                    $order->title = $paypal_data['title'];
                    $order->currency = $paypal_data['currency'];
                    $order->currency_code = $paypal_data['currency_code'];
                    $order->price = $paypal_data['price'];
                    $order->days = $paypal_data['days'];
                    $order->allowed_products = $paypal_data['allowed_products'];
                    $order->details = $paypal_data['details'];
                    $order->method = $paypal_data['method'];
                    $order->txnid = $resp['transactions'][0]['related_resources'][0]['sale']['id'];
                    $order->status = 1;

                    $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');
                    $user->is_vendor = 2;
                    if(!empty($package))
                    {
                        if($package->subscription_id == $order->subscription_id)
                        {
                            $newday = strtotime($today);
                            $lastday = strtotime($user->date);
                            $secs = $lastday-$newday;
                            $days = $secs / 86400;
                            $total = $days+$subs->days;
                            $inputs['date'] = date('Y-m-d', strtotime($today.' + '.$total.' days'));
                        }
                        else
                        {
                            $inputs['date'] = date('Y-m-d', strtotime($today.' + '.$subs->days.' days'));
                        }
                    }
                    else
                    {
                        
                        $inputs['date'] = date('Y-m-d', strtotime($today.' + '.$subs->days.' days'));

                    }

        $inputs['mail_sent'] = 1;
        $user->update($inputs);
                   $order->save();

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


        Session::forget('payment_id');
        Session::forget('molly_data');
        Session::forget('user_data');
        Session::forget('order_data');



            return redirect($success_url);
        }
        else {
            return redirect($cancel_url);
        }

}

}