sage pay testing error
- by Phil Jackson
Hi, im trying to test my sage pay integration but to no avail.
Here is my code:
private function init_sagepay(){
    extract( static::$post );
    $settings = global_data::get_settings();
    $strConnectTo = "TTEST";
    $strVirtualDir = "VSPForm-Kit";
    $strYourSiteFQDN = global_data::get_web_root();  
    $strVSPVendorName = $settings->sagepay_vendor;
    $strEncryptionPassword = "z5p************";
    $strCurrency = static::$currency;
    $strVendorEMail = $settings->sagepay_email;
    $strTransactionType = "PAYMENT";
    $strProtocol = "2.23";
    if ( $strConnectTo == "LIVE" ) 
        $strPurchaseURL = "https://live.sagepay.com/gateway/service/vspform-register.vsp"; 
    elseif ( $strConnectTo == "TEST" )
        $strPurchaseURL = "https://test.sagepay.com/gateway/service/vspform-register.vsp";
    elseif( $strConnectTo == 'TTEST' )
        $strPurchaseURL = 'https://test.sagepay.com/Simulator/VSPServerGateway.asp?Service=VendorRegisterTx';
    else
        $strPurchaseURL = "https://test.sagepay.com/Simulator/VSPDirectGateway.asp";
    $details = self::get_member_details();
    $thisOrderDeteails = 'order details...';
    $ThisVendorTxCode = 'fdsdgfd';
    $ThisAmount = $total;
    $ThisCurrency = static::$currency;
    $ThisDescription = "description...";
    $ThisCustomerEmail = $details->email;
    $ThisCustomerName = $details->first_name . " " . $details->last_name;
    $ThisVendorEmail = $strVendorEMail;
    $ThisApplyAVSCV2 = 1;
    $ThisApply3DSecure = 1;
    $ThisDeliveryAddress = $address_line_1 . ", " . $address_line_2 . ", " . $address_line_3 . ", " . $address_line_4 . ", " . $country;
    $ThisDeliveryPostCode = $postcode;
    $address_full = $ThisDeliveryAddress . ' ' . $ThisDeliveryPostCode;
    $ThisBillingAddress = $details->address_line_1 . ", " . $details->address_line_2 . ", " . $details->address_line_3 . ", " . $details->address_line_4 . ", " . $details->country;
    $ThisBillingPostCode = $details->postcode;
    // new 2.22 fields
    $ThisContactNumber = $details->home_number;
    $ThisContactFax = $details->fax_number;
    $ThisAllowGiftAid = '';
    //$ThisApplyAVSCV2 = $_REQUEST[ 'ApplyAVSCV2' ];
    //$ThisApply3DSecure = $_REQUEST[ 'Apply3DSecure' ];
    $ShoppingBasket = array();
    $x = 0;
    foreach( $items as $item ) {
        preg_match( "#^\[([^\]]+)\]\[([^\]]+)\]$#is", $item, $match );
        $item = $match[1];
        $price = $match[2];
        $ShoppingBasket[$x][0] = $item;
        $ShoppingBasket[$x][1] = $price;
        $x++;
    }
    if ( isset( $ShoppingBasket ) ) {
        $ThisShoppingBasket = $ShoppingBasket;
    }else{
        $ThisShoppingBasket = "OFF";  
    }
    //** Build the crypt string plaintext **
    $stuff = "VendorTxCode=" . $ThisVendorTxCode . "&";
    $stuff .= "Amount=" . $ThisAmount . "&";
    $stuff .= "Currency=" . $ThisCurrency . "&";
    $stuff .= "Description=" . $ThisDescription . "&";
    $stuff .= "SuccessURL=" . $strYourSiteFQDN . "completed.php&";
    $stuff .= "FailureURL=" . $strYourSiteFQDN . "notcompleted.php&";
    if ($ThisCustomerEmail) {
      $stuff .= "CustomerEmail=" . $ThisCustomerEmail . "&";
    }
    if ($ThisVendorEmail) {
      $stuff .= "VendorEmail=" . $ThisVendorEmail . "&";
    }
    if ($ThisCustomerName) {
      $stuff .= "CustomerName=" . $ThisCustomerName . "&";
    }
    if ($ThisDeliveryAddress) {
      $stuff .= "DeliveryAddress=" . $ThisDeliveryAddress . "&";
    }
    if ($ThisDeliveryPostCode) {
      $stuff .= "DeliveryPostCode=" . $ThisDeliveryPostCode . "&";
    }
    if ($ThisBillingAddress) {
      $stuff .= "BillingAddress=" . $ThisBillingAddress . "&";
    }
    if ($ThisBillingPostCode) {
      $stuff .= "BillingPostCode=" . $ThisBillingPostCode . "&";
    }
    // new 2.22 fields
    if ($ThisContactNumber) {
      $stuff .= "ContactNumber=" . $ThisContactNumber . "&";
    }
    if ($ThisContactFax) {
      $stuff .= "ContactFax=" . $ThisContactFax . "&";
    }
    if ($ThisAllowGiftAid) {
      $stuff .= "AllowGiftAid=" . $ThisAllowGiftAid . "&";
    }
    if ($ThisApplyAVSCV2) {
      $stuff .= "ApplyAVSCV2=" . $ThisApplyAVSCV2 . "&";
    }
    if ($ThisApply3DSecure) {
      $stuff .= "Apply3DSecure=" . $ThisApply3DSecure . "&";
    }
    //echo $stuff;
    if ($ThisShoppingBasket=="ON") {
      $stuff .= "Basket=3:Sony SV-234 DVD Player:1:£170.20:£29.79:£199.99:£199.99:The Fast and The Furious Region 2 DVD:2:£17.01:£2.98:£19.99:£39.98:Delivery:1:£4.99:----:£4.99:£4.99&";
    }
    $stuff .= "EMailMessage=For an update on the status of your order please email us at $ThisVendorEmail";
    $crypt = self::base64Encode( self::SimpleXor( $stuff,$strEncryptionPassword ) );
    $ThisDate = date('U');
    ob_start();
    ?>
    <form action="<?php echo $strPurchaseURL; ?>" method="post" id="sageForm" name="form1">
        <input TYPE="hidden" name="VPSProtocol" value="<?php echo $strProtocol; ?>">
        <input TYPE="hidden" name="TxType" value="<?php echo $strTransactionType; ?>">
        <input TYPE="hidden" name="Vendor" value="<?php echo $strVSPVendorName; ?>">
        <input TYPE="hidden" name="Crypt" value="<?php echo $crypt; ?>">    
        <input name="sbbutton" type="submit" value="Checkout" class="wpcf7-submit">                  
    </form>     
    <?php
    return ob_get_clean();
}
when using "TEST" im getting an error: 
Status Detail:  5005 : The Vendor configuration is missing or invalid
when using "TTEST" im getting an error:
VPSProtocol=2.23
Status=INVALID
StatusDetail=The VendorTxCode you supplied is an invalid length.  VendorTxCodes should be between 1 to 40 characters long
I cannot seem to figure this out at all. If anyone has any ideas it would be greatfuly appreciated.
EDIT: $stuff echos out:
VendorTxCode=fdsdgfd&Amount=45.60&Currency=GBP&Description=description...&SuccessURL=http://localhost/ecom_framework/&FailureURL=http://localhost/ecom_framework/&[email protected]&[email protected]&CustomerName=Luke Snowden&DeliveryAddress=mansfield, nottinghamshire, mansfield, nottinghamshire, United Kingdom&DeliveryPostCode=ng19 8pw&BillingAddress=mansfield, nottinghamshire, mansfield, nottinghamshire, United Kingdom&BillingPostCode=ng19 8pw&ContactNumber=0165656567&ApplyAVSCV2=1&Apply3DSecure=1&Basket=3:Blue Hat - black :2:£2£:0.00:£4.00:Blue Hat - brown :3:£3£:0.00:£9.00:Blue Hat - grey :4:£4£:0.00:£16.00:Delivery:1:£4.99EMailMessage=For an update on the status of your order please email us at [email protected]