paymal payment api for cashier app
This commit is contained in:
@@ -1,4 +1,5 @@
|
|||||||
class Api::AuthenticateController < Api::ApiController
|
class Api::AuthenticateController < Api::ApiController
|
||||||
|
skip_before_action :authenticate
|
||||||
|
|
||||||
def create
|
def create
|
||||||
emp_id = params[:emp_id]
|
emp_id = params[:emp_id]
|
||||||
|
|||||||
@@ -20,15 +20,63 @@ class Api::PaymentsController < Api::ApiController
|
|||||||
end
|
end
|
||||||
|
|
||||||
#create paymal payment for cashier app
|
#create paymal payment for cashier app
|
||||||
|
def create_paymal_payment
|
||||||
|
if params[:sale_id] && params[:account_no]
|
||||||
|
sale = Sale.find_by_sale_id(params[:sale_id])
|
||||||
|
if !sale.nil?
|
||||||
|
if sale.sale_status == "new"
|
||||||
|
if !params[:account_no].empty?
|
||||||
|
@status, @message = send_account_paymal(sale.grand_total, params[:account_no], sale.receipt_no)
|
||||||
|
if @status
|
||||||
|
sale_payment = SalePayment.new
|
||||||
|
status, @sale, @membership_data = sale_payment.process_payment(sale, current_login_employee, sale.grand_total, "paymal",params[:account_no])
|
||||||
|
|
||||||
|
if status == true && @membership_data["status"] == true
|
||||||
|
sale_payment = SalePayment.new
|
||||||
|
status = sale_payment.process_payment(sale, current_login_employee, 0, "cash")
|
||||||
|
#card_balance amount for Paymal payment
|
||||||
|
card_balance_amount = SaleAudit.getCardBalanceAmount(params[:sale_id])
|
||||||
|
|
||||||
|
render json: JSON.generate({:status => true, :balance_amount => card_balance_amount,:receipt_no => sale.receipt_no, :message => "Payment successful."})
|
||||||
|
else
|
||||||
|
if @membership_data
|
||||||
|
if @membership_data["card_balance_amount"] != "null"
|
||||||
|
render json: JSON.generate({:status => false, :balance_amount => @membership_data["card_balance_amount"], :error_message => @membership_data["message"]})
|
||||||
|
else
|
||||||
|
render json: JSON.generate({:status => false, :error_message => @membership_data["message"]})
|
||||||
|
end
|
||||||
|
else
|
||||||
|
render json: JSON.generate({:status => false, :error_message => "Payment failed!"})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
else
|
||||||
|
render json: JSON.generate({:status => false, :error_message => @message})
|
||||||
|
end
|
||||||
|
else
|
||||||
|
render json: JSON.generate({:status => false, :error_message => "Card No is required!"})
|
||||||
|
end
|
||||||
|
else
|
||||||
|
render json: JSON.generate({:status => false, :error_message => "Already paid for '#{params[:sale_id]}'!"})
|
||||||
|
end
|
||||||
|
else
|
||||||
|
render json: JSON.generate({:status => false, :error_message => "There is no sale for '#{params[:sale_id]}'!"})
|
||||||
|
end
|
||||||
|
else
|
||||||
|
render json: JSON.generate({:status => false, :error_message => "Parameters missing! #{params[:sale_id]} #{params[:account_no]}"})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
#create paymal payment for online order app
|
||||||
def paymal_payment
|
def paymal_payment
|
||||||
if params[:account_no] && params[:key] && params[:token] && params[:sale_id]
|
if params[:account_no] && params[:key] && params[:token] && params[:sale_id]
|
||||||
sale = Sale.find_by_sale_id(params[:sale_id])
|
sale = Sale.find_by_sale_id(params[:sale_id])
|
||||||
sale_id=sale.sale_id
|
sale_id = sale.sale_id
|
||||||
|
|
||||||
if !sale.nil?
|
if !sale.nil?
|
||||||
@paid_amount = sale.grand_total
|
@paid_amount = sale.grand_total
|
||||||
current_shift = ShiftSale.current_shift
|
current_shift = ShiftSale.current_shift
|
||||||
@shop =Shop.current_shop
|
@shop = Shop.current_shop
|
||||||
@status,@message,@balance =check_security_code(sale,params)
|
@status,@message,@balance = check_security_code(sale,params)
|
||||||
sale_items = SaleItem.get_all_sale_items(sale_id)
|
sale_items = SaleItem.get_all_sale_items(sale_id)
|
||||||
if @status
|
if @status
|
||||||
sale_payment = SalePayment.new
|
sale_payment = SalePayment.new
|
||||||
@@ -36,8 +84,7 @@ class Api::PaymentsController < Api::ApiController
|
|||||||
if @status && @membership_data["status"] == true
|
if @status && @membership_data["status"] == true
|
||||||
sale_payment = SalePayment.new
|
sale_payment = SalePayment.new
|
||||||
status = sale_payment.process_payment(sale, @user, 0, "cash")
|
status = sale_payment.process_payment(sale, @user, 0, "cash")
|
||||||
#card_balance amount for Paymal payment
|
|
||||||
card_balance_amount, transaction_ref = SaleAudit.getCardBalanceAmount(params[:sale_id])
|
|
||||||
rebate_amount = nil
|
rebate_amount = nil
|
||||||
# For Cashier by Zone
|
# For Cashier by Zone
|
||||||
bookings = Booking.find_by_sale_id(sale_id)
|
bookings = Booking.find_by_sale_id(sale_id)
|
||||||
@@ -67,70 +114,69 @@ class Api::PaymentsController < Api::ApiController
|
|||||||
unique_code = PrintSetting.where("unique_code REGEXP ?", "receipt.*bill.*pdf").first.unique_code
|
unique_code = PrintSetting.where("unique_code REGEXP ?", "receipt.*bill.*pdf").first.unique_code
|
||||||
end
|
end
|
||||||
|
|
||||||
customer = sale.customer
|
customer = sale.customer
|
||||||
|
|
||||||
# get member information
|
# get member information
|
||||||
rebate = MembershipSetting.find_by_rebate(1)
|
rebate = MembershipSetting.find_by_rebate(1)
|
||||||
credit_data = SalePayment.find_by_sale_id_and_payment_method(sale_id,'creditnote')
|
credit_data = SalePayment.find_by_sale_id_and_payment_method(sale_id,'creditnote')
|
||||||
|
|
||||||
if customer.membership_id != nil && rebate && credit_data.nil?
|
if customer.membership_id != nil && rebate && credit_data.nil?
|
||||||
member_info = Customer.get_member_account(customer)
|
member_info = Customer.get_member_account(customer)
|
||||||
|
|
||||||
if member_info["status"] == true
|
if member_info["status"] == true
|
||||||
rebate_amount = Customer.get_membership_transactions(customer,sale.receipt_no)
|
rebate_amount = Customer.get_membership_transactions(customer,sale.receipt_no)
|
||||||
current_balance = SaleAudit.paymal_search(sale_id)
|
current_balance = SaleAudit.paymal_search(sale_id)
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
#orders print out
|
#orders print out
|
||||||
booking = Booking.find_by_sale_id(sale_id)
|
booking = Booking.find_by_sale_id(sale_id)
|
||||||
if booking.dining_facility_id.to_i>0
|
if booking.dining_facility_id.to_i>0
|
||||||
table_id = booking.dining_facility_id
|
table_id = booking.dining_facility_id
|
||||||
else
|
else
|
||||||
table_id = 0
|
table_id = 0
|
||||||
end
|
end
|
||||||
|
|
||||||
latest_order = booking.booking_orders.order("order_id DESC").limit(1).first()
|
latest_order = booking.booking_orders.order("order_id DESC").limit(1).first()
|
||||||
if !latest_order.nil?
|
if !latest_order.nil?
|
||||||
latest_order_no = latest_order.order_id
|
latest_order_no = latest_order.order_id
|
||||||
end
|
end
|
||||||
|
|
||||||
booking.booking_orders.each do |order|
|
booking.booking_orders.each do |order|
|
||||||
# Order.pay_process_order_queue(order.order_id, table_id)
|
# Order.pay_process_order_queue(order.order_id, table_id)
|
||||||
oqs = OrderQueueStation.new
|
oqs = OrderQueueStation.new
|
||||||
oqs.pay_process_order_queue(order.order_id, table_id)
|
oqs.pay_process_order_queue(order.order_id, table_id)
|
||||||
|
|
||||||
assign_order = AssignedOrderItem.assigned_order_item_by_job(order.order_id)
|
assign_order = AssignedOrderItem.assigned_order_item_by_job(order.order_id)
|
||||||
from = getCloudDomain #get sub domain in cloud mode
|
from = getCloudDomain #get sub domain in cloud mode
|
||||||
ActionCable.server.broadcast "order_queue_station_channel",order: assign_order,from:from
|
ActionCable.server.broadcast "order_queue_station_channel",order: assign_order,from:from
|
||||||
end
|
end
|
||||||
|
|
||||||
|
#for card sale data
|
||||||
#for card sale data
|
card_data = Array.new
|
||||||
card_data = Array.new
|
card_sale_trans_ref_no = Sale.getCardSaleTrans(sale_id)
|
||||||
card_sale_trans_ref_no = Sale.getCardSaleTrans(sale_id)
|
if !card_sale_trans_ref_no.nil?
|
||||||
if !card_sale_trans_ref_no.nil?
|
card_sale_trans_ref_no.each do |cash_sale_trans|
|
||||||
card_sale_trans_ref_no.each do |cash_sale_trans|
|
card_res_date = cash_sale_trans.res_date.strftime("%Y-%m-%d").to_s
|
||||||
card_res_date = cash_sale_trans.res_date.strftime("%Y-%m-%d").to_s
|
card_res_time = cash_sale_trans.res_time.strftime("%H:%M").to_s
|
||||||
card_res_time = cash_sale_trans.res_time.strftime("%H:%M").to_s
|
card_no = cash_sale_trans.pan.last(4)
|
||||||
card_no = cash_sale_trans.pan.last(4)
|
card_no = card_no.rjust(19,"**** **** **** ")
|
||||||
card_no = card_no.rjust(19,"**** **** **** ")
|
card_data.push({'res_date' => card_res_date, 'res_time' => card_res_time, 'batch_no' => cash_sale_trans.batch_no, 'trace' => cash_sale_trans.trace, 'pan' => card_no, 'app' => cash_sale_trans.app, 'tid' => cash_sale_trans.terminal_id, 'app_code' => cash_sale_trans.app_code, 'ref_no' => cash_sale_trans.ref_no, 'mid' => cash_sale_trans.merchant_id})
|
||||||
card_data.push({'res_date' => card_res_date, 'res_time' => card_res_time, 'batch_no' => cash_sale_trans.batch_no, 'trace' => cash_sale_trans.trace, 'pan' => card_no, 'app' => cash_sale_trans.app, 'tid' => cash_sale_trans.terminal_id, 'app_code' => cash_sale_trans.app_code, 'ref_no' => cash_sale_trans.ref_no, 'mid' => cash_sale_trans.merchant_id})
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
#card_balance amount for Paymal payment
|
#card_balance amount for Paymal payment
|
||||||
card_balance_amount,transaction_ref = SaleAudit.getCardBalanceAmount(sale_id)
|
card_balance_amount, transaction_ref = SaleAudit.getCardBalanceAmount(sale_id)
|
||||||
|
|
||||||
# get printer info
|
# get printer info
|
||||||
print_settings=PrintSetting.find_by_unique_code(unique_code)
|
print_settings=PrintSetting.find_by_unique_code(unique_code)
|
||||||
# Calculate Food and Beverage Total
|
# Calculate Food and Beverage Total
|
||||||
item_price_by_accounts = SaleItem.calculate_price_by_accounts(sale.sale_items)
|
item_price_by_accounts = SaleItem.calculate_price_by_accounts(sale.sale_items)
|
||||||
discount_price_by_accounts = SaleItem.get_discount_price_by_accounts(sale.sale_items)
|
discount_price_by_accounts = SaleItem.get_discount_price_by_accounts(sale.sale_items)
|
||||||
other_amount = SaleItem.calculate_other_charges(sale_items)
|
other_amount = SaleItem.calculate_other_charges(sale_items)
|
||||||
|
|
||||||
printer = Printer::ReceiptPrinter.new(print_settings)
|
printer = Printer::ReceiptPrinter.new(print_settings)
|
||||||
filename, sale_receipt_no, printer_name = printer.print_receipt_bill(print_settings, false, nil, cashier_terminal,sale_items,sale,params[:account_no], item_price_by_accounts, discount_price_by_accounts, member_info,rebate_amount,@shop, 'paid',current_balance,card_data,other_amount,latest_order_no,card_balance_amount,nil,transaction_ref)
|
filename, sale_receipt_no, printer_name = printer.print_receipt_bill(print_settings, false, nil, cashier_terminal,sale_items,sale,params[:account_no], item_price_by_accounts, discount_price_by_accounts, member_info,rebate_amount,@shop, 'paid',current_balance,card_data,other_amount,latest_order_no,card_balance_amount,nil,transaction_ref)
|
||||||
render json: JSON.generate({:status => true, :balance_amount => card_balance_amount,:receipt_no => sale.receipt_no,:order_no => latest_order_no, :message => "complete", :paid_amount => sale.grand_total})
|
render json: JSON.generate({:status => true, :balance_amount => card_balance_amount,:receipt_no => sale.receipt_no,:order_no => latest_order_no, :message => "complete", :paid_amount => sale.grand_total})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -144,6 +190,8 @@ class Api::PaymentsController < Api::ApiController
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
def send_account_paymal(amount, account_no, receipt_no)
|
def send_account_paymal(amount, account_no, receipt_no)
|
||||||
sale = Sale.find_by_receipt_no(receipt_no)
|
sale = Sale.find_by_receipt_no(receipt_no)
|
||||||
@out = []
|
@out = []
|
||||||
@@ -152,13 +200,13 @@ class Api::PaymentsController < Api::ApiController
|
|||||||
@message = ""
|
@message = ""
|
||||||
membership_setting = MembershipSetting.find_by_membership_type("paypar_url")
|
membership_setting = MembershipSetting.find_by_membership_type("paypar_url")
|
||||||
if membership_setting.gateway_url
|
if membership_setting.gateway_url
|
||||||
member_actions =MembershipAction.find_by_membership_type("get_account_balance")
|
member_actions = MembershipAction.find_by_membership_type("get_account_balance")
|
||||||
if member_actions.gateway_url
|
if member_actions.gateway_url
|
||||||
@campaign_type_id = nil
|
@campaign_type_id = nil
|
||||||
url = membership_setting.gateway_url.to_s + member_actions.gateway_url.to_s
|
url = membership_setting.gateway_url.to_s + member_actions.gateway_url.to_s
|
||||||
merchant_uid= member_actions.merchant_account_id
|
merchant_uid= member_actions.merchant_account_id
|
||||||
auth_token = member_actions.auth_token.to_s
|
auth_token = member_actions.auth_token.to_s
|
||||||
membership_data = SalePayment.get_paypar_account_data(url,membership_setting.auth_token,merchant_uid,auth_token,account_no,amount,receipt_no)
|
@membership_data = SalePayment.get_paypar_account_data(url,membership_setting.auth_token,merchant_uid,auth_token,account_no,amount,receipt_no)
|
||||||
if membership_data["status"]==true
|
if membership_data["status"]==true
|
||||||
remark = "Payment by account no Receipt No #{sale.receipt_no} | Sale ID #{sale.sale_id} | Transaction ref: #{membership_data[:transaction_ref]} | Reload amount #{membership_data[:reload_amount]} | Old Balance Amount #{membership_data[:old_balance_amount]} | DateTime : #{membership_data[:date]}"
|
remark = "Payment by account no Receipt No #{sale.receipt_no} | Sale ID #{sale.sale_id} | Transaction ref: #{membership_data[:transaction_ref]} | Reload amount #{membership_data[:reload_amount]} | Old Balance Amount #{membership_data[:old_balance_amount]} | DateTime : #{membership_data[:date]}"
|
||||||
sale_audit = SaleAudit.record_audit_for_edit(sale.sale_id,@user.name, @user.name,remark,"PAYBYACCOUNT" )
|
sale_audit = SaleAudit.record_audit_for_edit(sale.sale_id,@user.name, @user.name,remark,"PAYBYACCOUNT" )
|
||||||
@@ -166,7 +214,6 @@ class Api::PaymentsController < Api::ApiController
|
|||||||
remark = "Payment by account no Receipt No #{sale.receipt_no} | Sale ID #{sale.sale_id} | Remark : #{membership_data[:message]}"
|
remark = "Payment by account no Receipt No #{sale.receipt_no} | Sale ID #{sale.sale_id} | Remark : #{membership_data[:message]}"
|
||||||
sale_audit = SaleAudit.record_audit_for_edit(sale.sale_id,@user.name, @user.name,remark,"PAYBYACCOUNT" )
|
sale_audit = SaleAudit.record_audit_for_edit(sale.sale_id,@user.name, @user.name,remark,"PAYBYACCOUNT" )
|
||||||
end
|
end
|
||||||
@out = membership_data
|
|
||||||
|
|
||||||
@status = membership_data["status"]
|
@status = membership_data["status"]
|
||||||
@message = membership_data["message"]
|
@message = membership_data["message"]
|
||||||
@@ -176,7 +223,7 @@ class Api::PaymentsController < Api::ApiController
|
|||||||
@message = "No gateway url!"
|
@message = "No gateway url!"
|
||||||
end
|
end
|
||||||
|
|
||||||
return @status, @message
|
return @status, @message, @membership_data
|
||||||
end
|
end
|
||||||
|
|
||||||
#create paymal payment for cashier app
|
#create paymal payment for cashier app
|
||||||
@@ -214,6 +261,7 @@ class Api::PaymentsController < Api::ApiController
|
|||||||
@message = "Invalid sale_id or card_no"
|
@message = "Invalid sale_id or card_no"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def check_security_code(sale,params)
|
def check_security_code(sale,params)
|
||||||
current_shift = ShiftSale.current_shift
|
current_shift = ShiftSale.current_shift
|
||||||
membership_setting = MembershipSetting.find_by_membership_type_and_shop_code("paypar_url",Shop.current_shop.shop_code)
|
membership_setting = MembershipSetting.find_by_membership_type_and_shop_code("paypar_url",Shop.current_shop.shop_code)
|
||||||
@@ -227,10 +275,10 @@ class Api::PaymentsController < Api::ApiController
|
|||||||
@status = membership_data["status"]
|
@status = membership_data["status"]
|
||||||
# @message = membership_data["message"]
|
# @message = membership_data["message"]
|
||||||
if @status
|
if @status
|
||||||
security_code =membership_data["account_data"]["security_code"]
|
security_code = membership_data["account_data"]["security_code"]
|
||||||
string ="card_no=#{params[:account_no]}passcode=#{membership_data["account_data"]["security_code"]}token=#{params[:token]}"
|
string = "card_no=#{params[:account_no]}passcode=#{membership_data["account_data"]["security_code"]}token=#{params[:token]}"
|
||||||
hash =Digest::SHA256.hexdigest string
|
hash = Digest::SHA256.hexdigest string
|
||||||
if hash ==params[:key]
|
if hash == params[:key]
|
||||||
if membership_data["account_data"]["available_balance"].to_i >sale.grand_total
|
if membership_data["account_data"]["available_balance"].to_i >sale.grand_total
|
||||||
@status = true
|
@status = true
|
||||||
@message = "complete"
|
@message = "complete"
|
||||||
@@ -257,7 +305,7 @@ class Api::PaymentsController < Api::ApiController
|
|||||||
end
|
end
|
||||||
return @status,@message,@balance
|
return @status,@message,@balance
|
||||||
end
|
end
|
||||||
private
|
|
||||||
def handle_payment(sale_payment)
|
def handle_payment(sale_payment)
|
||||||
|
|
||||||
payment_method = params[:payment_method]
|
payment_method = params[:payment_method]
|
||||||
|
|||||||
@@ -132,6 +132,7 @@ scope "(:locale)", locale: /en|mm/ do
|
|||||||
post "shifts/close" => "shifts#update"
|
post "shifts/close" => "shifts#update"
|
||||||
post "request_bill" => "bill#request_bill"
|
post "request_bill" => "bill#request_bill"
|
||||||
post "paymal_payment" => "payments#paymal_payment"
|
post "paymal_payment" => "payments#paymal_payment"
|
||||||
|
post "create_paymal_payment" => "payments#create_paymal_payment"
|
||||||
get ":sale_id/void" => "void#overall_void"
|
get ":sale_id/void" => "void#overall_void"
|
||||||
|
|
||||||
#API for sync cloud
|
#API for sync cloud
|
||||||
|
|||||||
Reference in New Issue
Block a user