Я сохраняю name
, class
, subject
, user_id
в таблице admission
, за исключением payment_status
, а затем после нажатия кнопки оплаты сейчас данные платежей, такие как payment_id
, user_id
, transaction_id
, payment_status
и т. Д. Захвачены в Payments table
.
Теперь, как я могу обновить payment_status
поле в admission
, если payment
успешно в paytm?
public function paynow(Request $request, $slug)
{
$payment_gateway = $request->gateway;
if($payment_gateway=='paytm'){
$order_id = strtolower(str_random(25));
$token = $this->preserveBeforeSave($item,$order_id, $type, $payment_gateway, $other_details);
$data_for_request = $this->handlePaytmRequest( $order_id, $amount );
$paytm_txn_url = 'https://securegw.paytm.in/theia/processTransaction';
$paramList = $data_for_request['paramList'];
$checkSum = $data_for_request['checkSum'];
return view('payments.paytm',compact('paytm_txn_url','token', 'paramList', 'checkSum' ));
}
dd('please wait...');
}
public function handlePaytmRequest( $order_id, $amount ) {
// Load all functions of encdec_paytm.php and config-paytm.php
$this->getAllEncdecFunc();
$this->getConfigPaytmSettings();
$checkSum = "";
$paramList = array();
// Create an array having all required parameters for creating checksum.
$paramList["MID"] = 'ytrytrytrytrty';
$paramList["ORDER_ID"] = $order_id;
$paramList["CUST_ID"] = $order_id;
$paramList["INDUSTRY_TYPE_ID"] = 'Rta109';
$paramList["CHANNEL_ID"] = 'WEB';
$paramList["TXN_AMOUNT"] = '299';
$paramList["WEBSITE"] = 'WEBPROD';
$paramList["CALLBACK_URL"] = url( 'https://www.ravi.com/payments/paytm/paytmCallback' );
$paytm_merchant_key = 'ytgduzyMHCahghghg9LlXnHlZ';
//Here checksum string will return by getChecksumFromArray() function.
$checkSum = getChecksumFromArray( $paramList, $paytm_merchant_key );
return array(
'checkSum' => $checkSum,
'paramList' => $paramList
);
}
public function paytmCallback( Request $request ) {
$order_id = $request['ORDERID'];
$user = Auth::user();
if ( 'TXN_SUCCESS' === $request['STATUS'] ) {
$transaction_id = $request['TXNID'];
$status = $request['STATUS'];
if($this->paymentSuccess($request))
{
}
else {
}
//REDIRECT THE USER BY LOADING A VIEW
return \Redirect()->route('account')->with('danger', 'Your payment was successfull, now you can give exam within 15 days');
} else if( 'TXN_FAILURE' === $request['STATUS'] ){
return \Redirect()->route('account')->with('danger', 'Your payment was failed, kindly try again');
}
}
public function preserveBeforeSave($item, $order_id, $package_type,$payment_method)
{
$payment = new Payment();
$payment->item_id = $item->id;
$payment->item_name = $item->title;
$payment->plan_type = $package_type;
$payment->payment_gateway = $payment_method;
$payment->slug = $order_id;
$payment->cost = $item->cost;
$payment->user_id = $user->id;
$payment->payment_status = PAYMENT_STATUS_PENDING;
$payment->save();
return $payment->slug;
}