Пример #1
0
        protected void btnContinue2_Click(object sender, EventArgs e)
        {
            //LoadRates(false);

            //Save current user
            int currentuserkey = 0;
            if (sitetemp.isloggedin())
            {
                //user logged in
                currentuserkey = currentuser.User_key;
            }
            else
            {
                //create new user in db & attach userkey to payment key
                DateTime dttemp = new DateTime(Convert.ToInt32(txtbirthyear.Value), Convert.ToInt32(txtbirthmonth.Value), Convert.ToInt32(txtbirthyear.Value));
                StoredProcedure sp_UpdateSignup1 = Peerfx_DB.SPs.UpdateUsers(0, null, txtfirstnamesender.Text, null, txtlastnamesender.Text, dttemp, Convert.ToInt32(ddlcountryresidence.SelectedValue), txtemailsender.Text, HttpContext.Current.Request.UserHostAddress, 0);
                sp_UpdateSignup1.Execute();
                currentuserkey = Convert.ToInt32(sp_UpdateSignup1.Command.Parameters[9].ParameterValue.ToString());
            }

            Int64 receiverpaymentobject = 0;
            Int64 senderpaymentobject = 0;
            //even if it's not a bank account, will still enter the correct payment object

            //if new recipient, save to database
            if ((pnlexistingreceiver.Visible) && (ddlReceivers.SelectedValue != "0"))
            {
                if (ddlReceivers.SelectedValue == "-1")
                {
                    //passport user
                    receiverpaymentobject = Convert.ToInt64(ddlotherpassportusers.SelectedValue);
                }
                else if (ddlReceivers.SelectedValue == "-2")
                {
                    //top up embee
                    //1st step record the embee payment object
                    string strphone = txtembeephone.Text;
                    strphone = strphone.Replace("-", "").Replace(" ", "");
                    while (strphone.Substring(0, 1) == "0")
                    {
                        strphone = strphone.Substring(1, strphone.Length - 1);
                    }

                    StoredProcedure sp_UpdateEmbeeObject = Peerfx_DB.SPs.UpdateEmbeeCatalogRecordpaymentobject(Convert.ToInt32(ddlembeecatalog.SelectedValue),strphone, 0);
                    sp_UpdateEmbeeObject.Execute();
                    receiverpaymentobject = Convert.ToInt64(sp_UpdateEmbeeObject.Command.Parameters[2].ParameterValue.ToString());
                }
                else
                {
                    receiverpaymentobject = Convert.ToInt64(ddlReceivers.SelectedValue);
                }
            }
            else
            {
                BankAccounts ba = BankAccountEntry1.gettxtfields();
                //new recipient
                receiverpaymentobject = BankAccountEntry1.InsertBankAccount(currentuser.User_key);
                Peerfx_DB.SPs.UpdateRecipients(0, currentuser.User_key, receiverpaymentobject).Execute();
                /*StoredProcedure sp_UpdateBank_account = Peerfx_DB.SPs.UpdateBankAccounts(0, null, Convert.ToInt32(ddlbuycurrency.SelectedValue), null, null, currentuserkey, HttpContext.Current.Request.UserHostAddress, lblconfirmreceiverAccount.Text, lblconfirmreceiverIBAN.Text, lblconfirmreceiverBankCode.Text, lblconfirmreceiverABArouting.Text, txtfirstnamereceiver.Text, txtlastnamereceiver.Text, null, 0);
                sp_UpdateBank_account.Execute();
                int bank_account_key = Convert.ToInt32(sp_UpdateBank_account.Command.Parameters[14].ParameterValue.ToString());
                //Save payment object
                StoredProcedure sp_UpdatePaymentObject = Peerfx_DB.SPs.UpdatePaymentObjects(0, 1, bank_account_key, 0);
                sp_UpdatePaymentObject.Execute();
                receiverpaymentobject = Convert.ToInt64(sp_UpdatePaymentObject.Command.Parameters[3].ParameterValue.ToString());*/
            }

            if (pnlloggedinsender.Visible)
            {
                if (sitetemp.IsUserBalance(Convert.ToInt64(hdsenderpaymentobjectkey.Value)))
                {
                    //user balance
                    senderpaymentobject = Convert.ToInt64(hdsenderpaymentobjectkey.Value);
                }
                else
                {
                    //bank account
                    senderpaymentobject = 0;
                }
            }

            //Confirming quote, create in database
            //Save & get Quote
            StoredProcedure sp_UpdateQuotes = Peerfx_DB.SPs.UpdateQuotes(0, Convert.ToDecimal(txtsell.Value), Convert.ToInt32(ddlsellcurrency.SelectedValue), Convert.ToDecimal(txtbuy.Value), Convert.ToInt32(ddlbuycurrency.SelectedValue), Convert.ToDecimal(lblrate.Text), Convert.ToDecimal(hdservicefee.Value), null, null, 0);
            sp_UpdateQuotes.Execute();
            int quote_key = Convert.ToInt32(sp_UpdateQuotes.Command.Parameters[9].ParameterValue.ToString());

            //Save & get Payment key

            StoredProcedure sp_UpdatePayments = Peerfx_DB.SPs.UpdatePayments(0, quote_key, 0, 0, currentuserkey, lblconfirmreceiverdescription.Text,senderpaymentobject,receiverpaymentobject);
            sp_UpdatePayments.Execute();
            int payment_key = Convert.ToInt32(sp_UpdatePayments.Command.Parameters[3].ParameterValue.ToString());
            lblpaymentnum.Text = payment_key.ToString();
            //update payment status to confirmed
            Peerfx_DB.SPs.UpdatePaymentStatus(payment_key, 2).Execute();

            //Assign proper treasury type
            int treasurytype = 2; //default = cc
            if (chkpremium.Checked)
            {
                treasurytype = 1;
            }
            if (sitetemp.getpaymentobjecttype(receiverpaymentobject) == 7)//receiver is embee
            {
                treasurytype = 1;
            }
            Peerfx_DB.SPs.UpdatePaymentTreasury(payment_key, treasurytype).Execute();

            //Send confirmation email with instructions etc.
            Peerfx.External_APIs.SendGrid sg = new Peerfx.External_APIs.SendGrid();
            sg.Send_Email_Payment_Confirmed(payment_key, currentuser);

            Hashtable hstemp = new Hashtable();
            hstemp.Add("Treasury Type", treasurytype.ToString());
            hstemp.Add("Payment Key", payment_key);
            hstemp.Add("Sell Currency", ddlsellcurrency.SelectedItem.Text);
            hstemp.Add("Sell Amount", txtsell.Text);
            hstemp.Add("Buy Currency", ddlbuycurrency.SelectedItem.Text);
            hstemp.Add("Buy Amount", txtbuy.Text);
            mx.TrackEvent("ExchangeCurrency - Confirmed Payment", currentuser.User_key, hstemp);

            bool isuserbalance = false;
            if (pnlloggedinsender.Visible)
            {
                if (sitetemp.IsUserBalance(Convert.ToInt64(hdsenderpaymentobjectkey.Value)))
                {
                    //send money from user balance to payment object
                    Int64 userbalance_payment_object_key = sitetemp.getpaymentobject_UserBalance(currentuser.User_key,Convert.ToInt32(ddlsellcurrency.SelectedValue));
                    Int64 payment_payment_object_key = sitetemp.getpaymentobject(6,payment_key);
                    Peerfx_DB.SPs.UpdateTransactionsInternal(0, 2, Convert.ToInt32(ddlsellcurrency.SelectedValue), Convert.ToDecimal(txtsell.Value), userbalance_payment_object_key, payment_payment_object_key, sitetemp.get_ipaddress(), currentuser.User_key, "user balance to payment", 0, 1, payment_key).Execute();

                    //instantly convert the payment, because source funding is balance
                    //initiate conversion
                    sitetemp.payment_initiate(payment_key);
                    Response.Redirect("/User/Dashboard.aspx?notification=true");
                }
            }

            if (!isuserbalance)
            {

                //Change tab to bank transfer info
                changetab(2);

                //Status to Awaiting User Deposit
                Peerfx_DB.SPs.UpdatePaymentStatus(payment_key, 11).Execute();
            }

            //populate labels
            updatealreadyconfirmedtab();
        }