public function UpdateBillingAddress($data, $form) { $member = Member::currentUser(); $isConID = $member->ISContactID; //Get InfusionSoft Api $creditCardType = Controller::curr()->getISCreditCardType($data['CreditCardType']); $app = Controller::curr()->getInfusionSoftApi(); if (!isset($data['CreditCardNumber']) || $data['CreditCardNumber'] != $data['CreditCardNumberCopy'] && !is_numeric($data['CreditCardNumber'])) { Controller::curr()->setMessage('Error', 'The credit card is invalid!'); return Controller::curr()->redirect(Controller::curr()->Link('#tabs-2')); } if ($data['CreditCardNumber'] == $data['CreditCardNumberCopy']) { $cardNumber = $data['CreditCardNumberCur']; } else { $cardNumber = $data['CreditCardNumber']; } // Validate credit card $card = array('CardType' => $creditCardType, 'ContactId' => $isConID, 'CardNumber' => $cardNumber, 'ExpirationMonth' => sprintf("%02s", $data['ExpiryMonth']), 'ExpirationYear' => $data['ExpiryYear'], 'CVV2' => $data['CreditCardCVV']); $result = $app->validateCard($card); if ($result['Valid'] != 'true') { Controller::curr()->setMessage('Error', 'The credit card is invalid!'); return Controller::curr()->redirect(Controller::curr()->Link('#tabs-2')); } // Get country text from code $country = Geoip::countryCode2name($data['Country']); if ($data['CreditCardNumber'] == $data['CreditCardNumberCopy']) { //Get the credit card $creditCard = CreditCard::get()->filter(array('CreditCardNumber' => $data['CreditCardNumberCur'], 'MemberID' => $member->ID))->First(); //Update the credit card on InfusionSoft $ccData = array('FirstName' => $data['FirstName'], 'LastName' => $data['LastName'], 'BillAddress1' => $data['StreetAddress1'], 'BillAddress2' => $data['StreetAddress2'], 'BillCity' => $data['City'], 'BillState' => $data['State'], 'BillZip' => $data['PostalCode'], 'BillCountry' => $country, 'CardType' => $creditCardType, 'NameOnCard' => $data['NameOnCard'], 'CVV2' => $data['CreditCardCVV'], 'ExpirationMonth' => sprintf("%02s", $data['ExpiryMonth']), 'ExpirationYear' => $data['ExpiryYear']); $app->dsUpdate("CreditCard", $creditCard->ISCCID, $ccData); //Update the credit card on site $creditCard->CreditCardType = $data['CreditCardType']; $creditCard->NameOnCard = $data['NameOnCard']; $creditCard->CreditCardCVV = $data['CreditCardCVV']; $creditCard->ExpiryMonth = $data['ExpiryMonth']; $creditCard->ExpiryYear = $data['ExpiryYear']; $creditCard->Company = $data['Company']; $creditCard->StreetAddress1 = $data['StreetAddress1']; $creditCard->StreetAddress2 = $data['StreetAddress2']; $creditCard->City = $data['City']; $creditCard->State = $data['State']; $creditCard->PostalCode = $data['PostalCode']; $creditCard->Country = $data['Country']; $creditCard->Current = 1; $creditCard->write(); } else { //Find if the credit card exist $creditCard = CreditCard::get()->filter(array('CreditCardNumber' => $data['CreditCardNumber'], 'MemberID' => $member->ID))->First(); if ($creditCard) { //Get current credit card, un-mark it as current Controller::curr()->unsetCurrentCreditCard($member->ID); $ccID = $creditCard->ISCCID; //Update the credit card on InfusionSoft $ccData = array('FirstName' => $data['FirstName'], 'LastName' => $data['LastName'], 'BillAddress1' => $data['StreetAddress1'], 'BillAddress2' => $data['StreetAddress2'], 'BillCity' => $data['City'], 'BillState' => $data['State'], 'BillZip' => $data['PostalCode'], 'BillCountry' => $country, 'CardType' => $creditCardType, 'NameOnCard' => $data['NameOnCard'], 'CVV2' => $data['CreditCardCVV'], 'ExpirationMonth' => sprintf("%02s", $data['ExpiryMonth']), 'ExpirationYear' => $data['ExpiryYear']); $app->dsUpdate("CreditCard", $ccID, $ccData); //Update the credit card on site $creditCard->CreditCardType = $data['CreditCardType']; $creditCard->NameOnCard = $data['NameOnCard']; $creditCard->CreditCardCVV = $data['CreditCardCVV']; $creditCard->ExpiryMonth = $data['ExpiryMonth']; $creditCard->ExpiryYear = $data['ExpiryYear']; $creditCard->Company = $data['Company']; $creditCard->StreetAddress1 = $data['StreetAddress1']; $creditCard->StreetAddress2 = $data['StreetAddress2']; $creditCard->City = $data['City']; $creditCard->State = $data['State']; $creditCard->PostalCode = $data['PostalCode']; $creditCard->Country = $data['Country']; $creditCard->Current = 1; $creditCard->write(); } else { // Add the credit card on InfusionSoft $ccData = array('ContactId' => $isConID, 'FirstName' => $data['FirstName'], 'LastName' => $data['LastName'], 'BillAddress1' => $data['StreetAddress1'], 'BillAddress2' => $data['StreetAddress2'], 'BillCity' => $data['City'], 'BillState' => $data['State'], 'BillZip' => $data['PostalCode'], 'BillCountry' => $country, 'CardType' => $creditCardType, 'NameOnCard' => $data['NameOnCard'], 'CardNumber' => $data['CreditCardNumber'], 'CVV2' => $data['CreditCardCVV'], 'ExpirationMonth' => sprintf("%02s", $data['ExpiryMonth']), 'ExpirationYear' => $data['ExpiryYear']); $ccID = $app->dsAdd("CreditCard", $ccData); //Get current credit card un-mark it as current Controller::curr()->unsetCurrentCreditCard($member->ID); // Store Credit card on site and mark it as current $newCreditCard = new CreditCard(); $newCreditCard->CreditCardType = $data['CreditCardType']; $newCreditCard->CreditCardNumber = $data['CreditCardNumber']; $newCreditCard->NameOnCard = $data['NameOnCard']; $newCreditCard->CreditCardCVV = $data['CreditCardCVV']; $newCreditCard->ExpiryMonth = $data['ExpiryMonth']; $newCreditCard->ExpiryYear = $data['ExpiryYear']; $newCreditCard->Company = $data['Company']; $newCreditCard->StreetAddress1 = $data['StreetAddress1']; $newCreditCard->StreetAddress2 = $data['StreetAddress2']; $newCreditCard->City = $data['City']; $newCreditCard->State = $data['State']; $newCreditCard->PostalCode = $data['PostalCode']; $newCreditCard->Country = $data['Country']; $newCreditCard->Current = 1; $newCreditCard->ISCCID = $ccID; $newCreditCard->MemberID = $member->ID; $newCreditCard->write(); } //Update the user active Infusionsoft subscription Credit Card $subscription = Subscription::get()->filter(array('MemberID' => $member->ID, 'Status' => 1))->first(); if ($subscription) { $subData = array('CC1' => $ccID); $app->dsUpdate("RecurringOrder", $subscription->SubscriptionID, $subData); } } //Update Member $member->FirstName = $data['FirstName']; $member->Surname = $data['LastName']; $member->write(); // Update billing address on InfusionSoft $conDat = array('FirstName' => $data['FirstName'], 'LastName' => $data['LastName'], 'Company' => $data['Company'], 'StreetAddress1' => $data['StreetAddress1'], 'StreetAddress2' => $data['StreetAddress2'], 'City' => $data['City'], 'State' => $data['State'], 'PostalCode' => $data['PostalCode'], 'Country' => $country); $conID = $app->updateCon($isConID, $conDat); Controller::curr()->setMessage('Success', 'Credit Card and Billing Address successfully updated.'); return Controller::curr()->redirect(Controller::curr()->Link('#tabs-2')); }
/** * @param string $cardId credit card id obtained from a previous create API call. * @return string */ public function getCreditCard($cardId) { return CreditCard::get($cardId, $this->contextFactory->createContext()); }
public function getSSCreditCardId2($memberId, $ssMemberId, $date) { $mysqli = $this->getDbConnection(); $result = $mysqli->query("SELECT * FROM jos_aw_creditcard WHERE creditcard_userid = {$memberId} AND DATE(creditcard_date) = '{$date}'"); if ($result->num_rows) { $obj = $result->fetch_object(); $cardNumber = $obj->creditcard_number; $mysqli->close(); if ($cardNumber) { $creditCard = CreditCard::get()->filter(array('CreditCardNumber' => $cardNumber, 'MemberID' => $ssMemberId))->first(); if ($creditCard) { return $creditCard->ID; } } } $mysqli->close(); return false; }
public function updateCreditCard($data, $form) { $member = Member::get()->byID($data['MemberID']); $isConID = $member->ISContactID; // Get the Page controller $Pg_Ctrl = new Page_Controller(); //Get InfusionSoft Api $creditCardType = $Pg_Ctrl->getISCreditCardType($data['CreditCardType']); $app = $Pg_Ctrl->getInfusionSoftApi(); // Validate credit card $card = array('CardType' => $creditCardType, 'ContactId' => $isConID, 'CardNumber' => $data['CreditCardNumber'], 'ExpirationMonth' => sprintf("%02s", $data['ExpiryMonth']), 'ExpirationYear' => $data['ExpiryYear'], 'CVV2' => $data['CreditCardCVV']); $result = $app->validateCard($card); if ($result['Valid'] != 'true') { $form->sessionMessage("The credit card details are invalid!", 'bad'); return $this->edit(Controller::curr()->getRequest()); } //Update the credit card on InfusionSoft $country = Geoip::countryCode2name($data['Country']); $ccData = array('BillAddress1' => $data['StreetAddress1'], 'BillAddress2' => $data['StreetAddress2'], 'BillCity' => $data['City'], 'BillState' => $data['State'], 'BillZip' => $data['PostalCode'], 'BillCountry' => $country, 'CardType' => $creditCardType, 'NameOnCard' => $data['NameOnCard'], 'CVV2' => $data['CreditCardCVV'], 'ExpirationMonth' => sprintf("%02s", $data['ExpiryMonth']), 'ExpirationYear' => $data['ExpiryYear']); $app->dsUpdate("CreditCard", $data['ISCCID'], $ccData); if (isset($data['Current'])) { // Update billing address on InfusionSoft $conDat = array('Company' => $data['Company'], 'StreetAddress1' => $data['StreetAddress1'], 'StreetAddress2' => $data['StreetAddress2'], 'City' => $data['City'], 'State' => $data['State'], 'PostalCode' => $data['PostalCode'], 'Country' => $country); $conID = $app->updateCon($isConID, $conDat); } //Get the credit card $creditCard = CreditCard::get()->filter(array('CreditCardNumber' => $data['CreditCardNumber']))->First(); //Unset the current card if (isset($data['Current']) && !$creditCard->Current) { $Pg_Ctrl->unsetCurrentCreditCard($member->ID); } //Update the credit card on site $creditCard->CreditCardType = $data['CreditCardType']; $creditCard->NameOnCard = $data['NameOnCard']; $creditCard->CreditCardCVV = $data['CreditCardCVV']; $creditCard->ExpiryMonth = $data['ExpiryMonth']; $creditCard->ExpiryYear = $data['ExpiryYear']; $creditCard->Company = $data['Company']; $creditCard->StreetAddress1 = $data['StreetAddress1']; $creditCard->StreetAddress2 = $data['StreetAddress2']; $creditCard->City = $data['City']; $creditCard->State = $data['State']; $creditCard->PostalCode = $data['PostalCode']; $creditCard->Country = $data['Country']; if (isset($data['Current']) && !$creditCard->Current) { $creditCard->Current = 1; } if (isset($data['UsedForTrial'])) { $creditCard->UsedForTrial = 1; } $creditCard->write(); $form->sessionMessage("Credit Card and Billing Address successfully updated.", 'good'); $randomNumber = rand(); return $this->getController()->redirect("admin/manage-data/CreditCard/EditForm/field/CreditCard/item/{$creditCard->ID}/edit?rand={$randomNumber}"); }