From ab526ac4a192c6b77533308b583d74a884525f22 Mon Sep 17 00:00:00 2001 From: Thein Lin Kyaw Date: Tue, 10 May 2022 12:04:38 +0630 Subject: [PATCH] paymal payment api for cashier app --- .../api/authenticate_controller.rb | 1 + app/controllers/api/payments_controller.rb | 178 +++++++++++------- config/routes.rb | 1 + 3 files changed, 115 insertions(+), 65 deletions(-) diff --git a/app/controllers/api/authenticate_controller.rb b/app/controllers/api/authenticate_controller.rb index 545735d9..e94d6fd1 100755 --- a/app/controllers/api/authenticate_controller.rb +++ b/app/controllers/api/authenticate_controller.rb @@ -1,4 +1,5 @@ class Api::AuthenticateController < Api::ApiController + skip_before_action :authenticate def create emp_id = params[:emp_id] diff --git a/app/controllers/api/payments_controller.rb b/app/controllers/api/payments_controller.rb index badbddcc..abffafbc 100755 --- a/app/controllers/api/payments_controller.rb +++ b/app/controllers/api/payments_controller.rb @@ -20,15 +20,63 @@ class Api::PaymentsController < Api::ApiController end #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 if params[:account_no] && params[:key] && params[:token] && 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? @paid_amount = sale.grand_total current_shift = ShiftSale.current_shift - @shop =Shop.current_shop - @status,@message,@balance =check_security_code(sale,params) + @shop = Shop.current_shop + @status,@message,@balance = check_security_code(sale,params) sale_items = SaleItem.get_all_sale_items(sale_id) if @status sale_payment = SalePayment.new @@ -36,8 +84,7 @@ class Api::PaymentsController < Api::ApiController if @status && @membership_data["status"] == true sale_payment = SalePayment.new 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 # For Cashier by Zone 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 end - customer = sale.customer + customer = sale.customer - # get member information - rebate = MembershipSetting.find_by_rebate(1) - credit_data = SalePayment.find_by_sale_id_and_payment_method(sale_id,'creditnote') + # get member information + rebate = MembershipSetting.find_by_rebate(1) + credit_data = SalePayment.find_by_sale_id_and_payment_method(sale_id,'creditnote') - if customer.membership_id != nil && rebate && credit_data.nil? - member_info = Customer.get_member_account(customer) + if customer.membership_id != nil && rebate && credit_data.nil? + member_info = Customer.get_member_account(customer) - if member_info["status"] == true - rebate_amount = Customer.get_membership_transactions(customer,sale.receipt_no) - current_balance = SaleAudit.paymal_search(sale_id) - end + if member_info["status"] == true + rebate_amount = Customer.get_membership_transactions(customer,sale.receipt_no) + current_balance = SaleAudit.paymal_search(sale_id) end + end - #orders print out - booking = Booking.find_by_sale_id(sale_id) - if booking.dining_facility_id.to_i>0 - table_id = booking.dining_facility_id - else - table_id = 0 - end + #orders print out + booking = Booking.find_by_sale_id(sale_id) + if booking.dining_facility_id.to_i>0 + table_id = booking.dining_facility_id + else + table_id = 0 + end - latest_order = booking.booking_orders.order("order_id DESC").limit(1).first() - if !latest_order.nil? - latest_order_no = latest_order.order_id - end + latest_order = booking.booking_orders.order("order_id DESC").limit(1).first() + if !latest_order.nil? + latest_order_no = latest_order.order_id + end - booking.booking_orders.each do |order| - # Order.pay_process_order_queue(order.order_id, table_id) - oqs = OrderQueueStation.new - oqs.pay_process_order_queue(order.order_id, table_id) + booking.booking_orders.each do |order| + # Order.pay_process_order_queue(order.order_id, table_id) + oqs = OrderQueueStation.new + oqs.pay_process_order_queue(order.order_id, table_id) - assign_order = AssignedOrderItem.assigned_order_item_by_job(order.order_id) - from = getCloudDomain #get sub domain in cloud mode - ActionCable.server.broadcast "order_queue_station_channel",order: assign_order,from:from - end + assign_order = AssignedOrderItem.assigned_order_item_by_job(order.order_id) + from = getCloudDomain #get sub domain in cloud mode + ActionCable.server.broadcast "order_queue_station_channel",order: assign_order,from:from + end - - #for card sale data - card_data = Array.new - card_sale_trans_ref_no = Sale.getCardSaleTrans(sale_id) - if !card_sale_trans_ref_no.nil? - 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_time = cash_sale_trans.res_time.strftime("%H:%M").to_s - card_no = cash_sale_trans.pan.last(4) - 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}) - end + #for card sale data + card_data = Array.new + card_sale_trans_ref_no = Sale.getCardSaleTrans(sale_id) + if !card_sale_trans_ref_no.nil? + 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_time = cash_sale_trans.res_time.strftime("%H:%M").to_s + card_no = cash_sale_trans.pan.last(4) + 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}) end + end - #card_balance amount for Paymal payment - card_balance_amount,transaction_ref = SaleAudit.getCardBalanceAmount(sale_id) + #card_balance amount for Paymal payment + card_balance_amount, transaction_ref = SaleAudit.getCardBalanceAmount(sale_id) - # get printer info - print_settings=PrintSetting.find_by_unique_code(unique_code) - # Calculate Food and Beverage Total - 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) - other_amount = SaleItem.calculate_other_charges(sale_items) + # get printer info + print_settings=PrintSetting.find_by_unique_code(unique_code) + # Calculate Food and Beverage Total + 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) + other_amount = SaleItem.calculate_other_charges(sale_items) - 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) + 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) 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 @@ -144,6 +190,8 @@ class Api::PaymentsController < Api::ApiController end end + private + def send_account_paymal(amount, account_no, receipt_no) sale = Sale.find_by_receipt_no(receipt_no) @out = [] @@ -152,13 +200,13 @@ class Api::PaymentsController < Api::ApiController @message = "" membership_setting = MembershipSetting.find_by_membership_type("paypar_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 @campaign_type_id = nil url = membership_setting.gateway_url.to_s + member_actions.gateway_url.to_s merchant_uid= member_actions.merchant_account_id 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 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" ) @@ -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]}" sale_audit = SaleAudit.record_audit_for_edit(sale.sale_id,@user.name, @user.name,remark,"PAYBYACCOUNT" ) end - @out = membership_data @status = membership_data["status"] @message = membership_data["message"] @@ -176,7 +223,7 @@ class Api::PaymentsController < Api::ApiController @message = "No gateway url!" end - return @status, @message + return @status, @message, @membership_data end #create paymal payment for cashier app @@ -214,6 +261,7 @@ class Api::PaymentsController < Api::ApiController @message = "Invalid sale_id or card_no" end end + def check_security_code(sale,params) current_shift = ShiftSale.current_shift 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"] # @message = membership_data["message"] if @status - security_code =membership_data["account_data"]["security_code"] - string ="card_no=#{params[:account_no]}passcode=#{membership_data["account_data"]["security_code"]}token=#{params[:token]}" - hash =Digest::SHA256.hexdigest string - if hash ==params[:key] + security_code = membership_data["account_data"]["security_code"] + string = "card_no=#{params[:account_no]}passcode=#{membership_data["account_data"]["security_code"]}token=#{params[:token]}" + hash = Digest::SHA256.hexdigest string + if hash == params[:key] if membership_data["account_data"]["available_balance"].to_i >sale.grand_total @status = true @message = "complete" @@ -257,7 +305,7 @@ class Api::PaymentsController < Api::ApiController end return @status,@message,@balance end - private + def handle_payment(sale_payment) payment_method = params[:payment_method] diff --git a/config/routes.rb b/config/routes.rb index bf4c9cc4..945adc42 100755 --- a/config/routes.rb +++ b/config/routes.rb @@ -132,6 +132,7 @@ scope "(:locale)", locale: /en|mm/ do post "shifts/close" => "shifts#update" post "request_bill" => "bill#request_bill" post "paymal_payment" => "payments#paymal_payment" + post "create_paymal_payment" => "payments#create_paymal_payment" get ":sale_id/void" => "void#overall_void" #API for sync cloud