Current File : /home/tradevaly/ladybagcollection.com/project/app/Http/Controllers/User/DauthorizeController.php |
<?php
namespace App\Http\Controllers\User;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use App\Models\Generalsetting;
use App\Classes\GeniusMailer;
use App\Models\Deposit;
use App\Models\Currency;
use App\Models\Transaction;
use Auth;
use Session;
use Validator;
use net\authorize\api\contract\v1 as AnetAPI;
use net\authorize\api\controller as AnetController;
use Illuminate\Support\Str;
class DauthorizeController extends Controller
{
public function store(Request $request){
$user = Auth::user();
$settings = Generalsetting::findOrFail(1);
$item_name = "Deposit Via Authorize.net";
$item_number = Str::random(4).time();
$item_amount = $request->amount;
if (Session::has('currency'))
{
$curr = Currency::find(Session::get('currency'));
}
else
{
$curr = Currency::where('is_default','=',1)->first();
}
$validator = Validator::make($request->all(),[
'cardNumber' => 'required',
'cardCode' => 'required',
'amonth' => 'required',
'ayear' => 'required',
]);
if ($validator->passes()) {
/* Create a merchantAuthenticationType object with authentication details retrieved from the constants file */
$merchantAuthentication = new AnetAPI\MerchantAuthenticationType();
$merchantAuthentication->setName($settings->authorize_login_id);
$merchantAuthentication->setTransactionKey($settings->authorize_txn_key);
// Set the transaction's refId
$refId = 'ref' . time();
// Create the payment data for a credit card
$creditCard = new AnetAPI\CreditCardType();
$creditCard->setCardNumber($request->cardNumber);
$year = $request->ayear;
$month = $request->amonth;
$creditCard->setExpirationDate($year.'-'.$month);
$creditCard->setCardCode($request->cardCode);
// Add the payment data to a paymentType object
$paymentOne = new AnetAPI\PaymentType();
$paymentOne->setCreditCard($creditCard);
// Create order information
$order = new AnetAPI\OrderType();
$order->setInvoiceNumber($item_number);
$order->setDescription($item_name);
// Create a TransactionRequestType object and add the previous objects to it
$transactionRequestType = new AnetAPI\TransactionRequestType();
$transactionRequestType->setTransactionType("authCaptureTransaction");
$transactionRequestType->setAmount($item_amount);
$transactionRequestType->setOrder($order);
$transactionRequestType->setPayment($paymentOne);
// Assemble the complete transaction request
$requestt = new AnetAPI\CreateTransactionRequest();
$requestt->setMerchantAuthentication($merchantAuthentication);
$requestt->setRefId($refId);
$requestt->setTransactionRequest($transactionRequestType);
// Create the controller and get the response
$controller = new AnetController\CreateTransactionController($requestt);
if($settings->authorize_mode == 'SANDBOX'){
$response = $controller->executeWithApiResponse(\net\authorize\api\constants\ANetEnvironment::SANDBOX);
}
else {
$response = $controller->executeWithApiResponse(\net\authorize\api\constants\ANetEnvironment::PRODUCTION);
}
if ($response != null) {
// Check to see if the API request was successfully received and acted upon
if ($response->getMessages()->getResultCode() == "Ok") {
// Since the API request was successful, look for a transaction response
// and parse it to display the results of authorizing the card
$tresponse = $response->getTransactionResponse();
if ($tresponse != null && $tresponse->getMessages() != null) {
$user->balance = $user->balance + ($request->amount / $curr->value);
$user->mail_sent = 1;
$user->save();
$deposit = new Deposit;
$deposit->user_id = $user->id;
$deposit->currency = $curr->sign;
$deposit->currency_code = $curr->name;
$deposit->currency_value = $curr->value;
$deposit->amount = $request->amount / $curr->value;
$deposit->method = 'Authorize.net';
$deposit->txnid = $tresponse->getTransId();
$deposit->status = 1;
$deposit->save();
// store in transaction table
if ($deposit->status == 1) {
$transaction = new Transaction;
$transaction->txn_number = Str::random(3).substr(time(), 6,8).Str::random(3);
$transaction->user_id = $deposit->user_id;
$transaction->amount = $deposit->amount;
$transaction->user_id = $deposit->user_id;
$transaction->currency_sign = $deposit->currency;
$transaction->currency_code = $deposit->currency_code;
$transaction->currency_value= $deposit->currency_value;
$transaction->method = $deposit->method;
$transaction->txnid = $deposit->txnid;
$transaction->details = 'Payment Deposit';
$transaction->type = 'plus';
$transaction->save();
}
if($settings->is_smtp == 1)
{
$data = [
'to' => $user->email,
'type' => "wallet_deposit",
'cname' => $user->name,
'damount' => ($deposit->amount * $deposit->currency_value),
'wbalance' => $user->balance,
'oamount' => "",
'aname' => "",
'aemail' => "",
'onumber' => "",
];
$mailer = new GeniusMailer();
$mailer->sendAutoMail($data);
}
else
{
$headers = "From: ".$settings->from_name."<".$settings->from_email.">";
@mail($user->email,'Balance has been added to your account. Your current balance is: $' . $user->balance, $headers);
}
return redirect()->route('user-dashboard')->with('success','Balance has been added to your account.');
} else {
return back()->with('unsuccess', 'Payment Failed.');
}
// Or, print errors if the API request wasn't successful
} else {
return back()->with('unsuccess', 'Payment Failed.');
}
} else {
return back()->with('unsuccess', 'Payment Failed.');
}
}
return back()->with('unsuccess', 'Invalid Payment Details.');
}
}