daddyrabbit Posted December 16, 2004 Posted December 16, 2004 Here is my viaklix code: <?php /* $Id: viaklix.php,v 0.1 2003/10/26 apodigm osCommerce, Open Source E-Commerce Solutions http://www.oscommerce.com Released under the GNU General Public License */ class viaklix { var $code, $title, $description, $enabled; // class constructor function viaklix() { global $order; $this->code = 'viaklix'; $this->title = MODULE_PAYMENT_VIAKLIX_TEXT_TITLE; $this->description = MODULE_PAYMENT_VIAKLIX_TEXT_DESCRIPTION; // BOF: WebMakers.com Added: Free Payments and Shipping //uncomment if you are using WebMakers Free Payments module //if ( tep_get_free_charger($this->code) ) { // $this->enabled = ((MODULE_PAYMENT_VIAKLIX_STATUS == 'True') ? true : false); //} // EOF: WebMakers.com Added: Free Payments and Shipping $this->sort_order = MODULE_PAYMENT_VIAKLIX_SORT_ORDER; $this->enabled = ((MODULE_PAYMENT_VIAKLIX_STATUS == 'True') ? true : false); if ((int)MODULE_PAYMENT_VIAKLIX_ORDER_STATUS_ID > 0) { $this->order_status = MODULE_PAYMENT_VIAKLIX_ORDER_STATUS_ID; } if (is_object($order)) $this->update_status(); $this->form_action_url = 'https://www2.viaKLIX.com/process.asp'; } // class methods function update_status() { global $order; if ( ($this->enabled == true) && ((int)MODULE_PAYMENT_VIAKLIX_ZONE > 0) ) { $check_flag = false; $check_query = tep_db_query("select zone_id from " . TABLE_ZONES_TO_GEO_ZONES . " where geo_zone_id = '" . MODULE_PAYMENT_VIAKLIX_ZONE . "' and zone_country_id = '" . $order->billing['country']['id'] . "' order by zone_id"); while ($check = tep_db_fetch_array($check_query)) { if ($check['zone_id'] < 1) { $check_flag = true; break; } elseif ($check['zone_id'] == $order->billing['zone_id']) { $check_flag = true; break; } } if ($check_flag == false) { $this->enabled = false; } } } function javascript_validation() { $js = ' if (payment_value == "' . $this->code . '") {' . "\n" . ' var cc_owner = document.checkout_payment.viaklix_cc_owner.value;' . "\n" . ' var cc_number = document.checkout_payment.viaklix_cc_number.value;' . "\n" . ' var cvv_number = document.checkout_payment.viaklix_cvv_number.value;' . "\n" . ' if (cc_owner == "" || cc_owner.length < ' . CC_OWNER_MIN_LENGTH . ') {' . "\n" . ' error_message = error_message + "' . MODULE_PAYMENT_VIAKLIX_TEXT_JS_CC_OWNER . '";' . "\n" . ' error = 1;' . "\n" . ' }' . "\n" . ' if (cc_number == "" || cc_number.length < ' . CC_NUMBER_MIN_LENGTH . ') {' . "\n" . ' error_message = error_message + "' . MODULE_PAYMENT_VIAKLIX_TEXT_JS_CC_NUMBER . '";' . "\n" . ' error = 1;' . "\n" . ' }' . "\n" . ' if (cvv_number == "" || cvv_number.length < ' . CVV_NUMBER_MIN_LENGTH . ') {' . "\n" . ' error_message = error_message + "' . MODULE_PAYMENT_VIAKLIX_TEXT_JS_CVV_NUMBER . '";' . "\n" . ' error = 1;' . "\n" . ' }' . "\n" . ' if (cvv_number.length > ' . CVV_NUMBER_MAX_LENGTH . ') {' . "\n" . ' error_message = error_message + "' . MODULE_PAYMENT_VIAKLIX_TEXT_JS_MAX_CVV_NUMBER . '";' . "\n" . ' error = 1;' . "\n" . ' }' . "\n" . ' }' . "\n"; return $js; } function selection() { global $order; for ($i=1; $i < 13; $i++) { $expires_month[] = array('id' => sprintf('%02d', $i), 'text' => strftime('%B',mktime(0,0,0,$i,1,2000))); } $today = getdate(); for ($i=$today['year']; $i < $today['year']+10; $i++) { $expires_year[] = array('id' => strftime('%y',mktime(0,0,0,1,1,$i)), 'text' => strftime('%Y',mktime(0,0,0,1,1,$i))); } $indicators[] = array('id'=>'Present','text'=>'Present'); $indicators[] = array('id'=>'Not Present','text'=>'Not Present'); $indicators[] = array('id'=>'Bypassed','text'=>'Missing'); $indicators[] = array('id'=>'Illegible','text'=>'Illegible'); $selection = array('id' => $this->code, 'module' => $this->title, 'fields' => array(array('title' => MODULE_PAYMENT_VIAKLIX_TEXT_CREDIT_CARD_OWNER, 'field' => tep_draw_input_field('viaklix_cc_owner', $order->billing['firstname'] . ' ' . $order->billing['lastname'])), array('title' => MODULE_PAYMENT_VIAKLIX_TEXT_CREDIT_CARD_NUMBER, 'field' => tep_draw_input_field('viaklix_cc_number')), array('title' => MODULE_PAYMENT_VIAKLIX_TEXT_CVV_NUMBER. ' ' .'<a href="java script:popupWindow(\'' . tep_href_link(FILENAME_POPUP_CVV, '', 'SSL') . '\')">' . TEXT_CVV_LINK . '</a>', 'field' => tep_draw_input_field('viaklix_cvv_number')), array('title' => MODULE_PAYMENT_VIAKLIX_TEXT_CVV_INDICATOR, 'field' => tep_draw_pull_down_menu('viaklix_cvv_indicator', $indicators)), array('title' => MODULE_PAYMENT_VIAKLIX_TEXT_CREDIT_CARD_EXPIRES, 'field' => tep_draw_pull_down_menu('viaklix_cc_expires_month', $expires_month) . ' ' . tep_draw_pull_down_menu('viaklix_cc_expires_year', $expires_year)))); return $selection; } function pre_confirmation_check() { global $HTTP_POST_VARS; include(DIR_WS_CLASSES . 'cc_validation.php'); $cc_validation = new cc_validation(); $result = $cc_validation->validate($HTTP_POST_VARS['viaklix_cc_number'], $HTTP_POST_VARS['viaklix_cc_expires_month'], $HTTP_POST_VARS['viaklix_cc_expires_year']); $error = ''; switch ($result) { case -1: $error = sprintf(TEXT_CCVAL_ERROR_UNKNOWN_CARD, substr($cc_validation->cc_number, 0, 4)); break; case -2: case -3: case -4: $error = TEXT_CCVAL_ERROR_INVALID_DATE; break; case false: $error = TEXT_CCVAL_ERROR_INVALID_NUMBER; break; } if ( ($result == false) || ($result < 1) ) { $payment_error_return = 'payment_error=' . $this->code . '&error=' . urlencode($error) . '&viaklix_cc_owner=' . urlencode($HTTP_POST_VARS['viaklix_cc_owner']) . '&viaklix_cc_expires_month=' . $HTTP_POST_VARS['viaklix_cc_expires_month'] . '&viaklix_cc_expires_year=' . $HTTP_POST_VARS['viaklix_cc_expires_year'] . '&viaklix_cvv_number=' . $HTTP_POST_VARS['viaklix_cvv_number']. '&viaklix_cvv_indicator=' . $HTTP_POST_VARS['viaklix_cvv_indicator']; tep_redirect(tep_href_link(FILENAME_CHECKOUT_PAYMENT, $payment_error_return, 'SSL', true, false)); } $this->cc_card_type = $cc_validation->cc_type; $this->cc_card_number = $cc_validation->cc_number; $this->cc_expiry_month = $cc_validation->cc_expiry_month; $this->cc_expiry_year = $cc_validation->cc_expiry_year; } function confirmation() { global $HTTP_POST_VARS; $confirmation = array('title' => $this->title . ': ' . $this->cc_card_type, 'fields' => array(array('title' => MODULE_PAYMENT_VIAKLIX_TEXT_CREDIT_CARD_OWNER, 'field' => $HTTP_POST_VARS['viaklix_cc_owner']), array('title' => MODULE_PAYMENT_VIAKLIX_TEXT_CREDIT_CARD_NUMBER, 'field' => substr($this->cc_card_number, 0, 4) . str_repeat('X', (strlen($this->cc_card_number) - 8)) . substr($this->cc_card_number, -4)), array('title' => MODULE_PAYMENT_VIAKLIX_TEXT_CVV_NUMBER, 'field' => $HTTP_POST_VARS['viaklix_cvv_number']), array('title' => MODULE_PAYMENT_VIAKLIX_TEXT_CVV_INDICATOR, 'field' => $HTTP_POST_VARS['viaklix_cvv_indicator']), array('title' => MODULE_PAYMENT_VIAKLIX_TEXT_CREDIT_CARD_EXPIRES, 'field' => strftime('%B, %Y', mktime(0,0,0,$HTTP_POST_VARS['viaklix_cc_expires_month'], 1, '20' . $HTTP_POST_VARS['viaklix_cc_expires_year']))))); return $confirmation; } function process_button() { global $HTTP_POST_VARS, $order, $currencies, $currency,$customer_id; $process_button_string = tep_draw_hidden_field('ssl_merchant_id', MODULE_PAYMENT_VIAKLIX_MERCHANT_ID) . tep_draw_hidden_field('ssl_user_id', MODULE_PAYMENT_VIAKLIX_USER_ID) . tep_draw_hidden_field('ssl_pin',MODULE_PAYMENT_VIAKLIX_PIN). tep_draw_hidden_field('ssl_amount', number_format($order->info['total'] * $currencies->get_value('USD'), 2, '.','')) . tep_draw_hidden_field('ssl_salestax', number_format($order->info['tax'] * $currencies->get_value('USD'), 2, '.','')) . tep_draw_hidden_field('ssl_show_form','FALSE'). tep_draw_hidden_field('ssl_receipt_link_method','POST'). tep_draw_hidden_field('ssl_card_number', $HTTP_POST_VARS['viaklix_cc_number']) . tep_draw_hidden_field('ssl_transaction_type','SALE'). tep_draw_hidden_field('ssl_exp_date', $HTTP_POST_VARS['viaklix_cc_expires_month']. $HTTP_POST_VARS['viaklix_cc_expires_year']) . tep_draw_hidden_field('ssl_cvv2', $HTTP_POST_VARS['viaklix_cvv_indicator']) . tep_draw_hidden_field('ssl_cvv2cvc2', $HTTP_POST_VARS['viaklix_cvv_number']) . tep_draw_hidden_field('ssl_customer_code', $customer_id) . tep_draw_hidden_field('ssl_company', $order->billing['company']) . tep_draw_hidden_field('ssl_first_name', $order->billing['firstname']) . tep_draw_hidden_field('ssl_last_name', $order->billing['lastname']) . tep_draw_hidden_field('ssl_avs_address', $order->billing['street_address']) . tep_draw_hidden_field('ssl_city', $order->billing['city']) . tep_draw_hidden_field('ssl_state', $order->billing['state']) . tep_draw_hidden_field('ssl_avs_zip', $order->billing['postcode']) . tep_draw_hidden_field('ssl_country', $order->billing['country']['title']) . tep_draw_hidden_field('ssl_phone', $order->customer['telephone']) . tep_draw_hidden_field('ssl_email', $order->customer['email_address']) . tep_draw_hidden_field('ssl_ship_to_first_name', $order->delivery['firstname']) . tep_draw_hidden_field('ssl_ship_to_last_name', $order->delivery['lastname']) . tep_draw_hidden_field('ssl_ship_to_address', $order->delivery['street_address']) . tep_draw_hidden_field('ssl_ship_to_city', $order->delivery['city']) . tep_draw_hidden_field('ssl_ship_to_state', $order->delivery['state']) . tep_draw_hidden_field('ssl_ship_to_zip', $order->delivery['postcode']) . tep_draw_hidden_field('ssl_ship_to_country', $order->delivery['country']['title']) . tep_draw_hidden_field('ssl_result_format', 'HTML') . tep_draw_hidden_field('ssl_receipt_apprvl_method', 'REDG') . tep_draw_hidden_field('ssl_receipt_decl_method', 'REDG') . tep_draw_hidden_field('ssl_receipt_apprvl_get_url', tep_href_link(FILENAME_CHECKOUT_PROCESS, '', 'SSL', true)) . tep_draw_hidden_field('ssl_receipt_decl_get_url', tep_href_link(FILENAME_CHECKOUT_PAYMENT, 'payment_error=' . $this->code . '&viaklix_cc_owner=' . urlencode($HTTP_POST_VARS['viaklix_cc_owner']) . '&passedvars=coming' , 'SSL', true)); if (MODULE_PAYMENT_VIAKLIX_TESTMODE == 'Test') $process_button_string .= tep_draw_hidden_field('ssl_test_mode', 'TRUE'); $process_button_string .= tep_draw_hidden_field(tep_session_name(), tep_session_id()); return $process_button_string; } function before_process() { return false; } function after_process() { return false; } function get_error() { global $HTTP_GET_VARS; $error = array('title' => VIAKLIX_ERROR_HEADING, 'error' => ((isset($HTTP_GET_VARS['ssl_result_message'])) ? stripslashes(urldecode($HTTP_GET_VARS['ssl_result_message'])) .' '. VIAKLIX_ERROR_MESSAGE : VIAKLIX_ERROR_MESSAGE)); return $error; } function check() { if (!isset($this->_check)) { $check_query = tep_db_query("select configuration_value from " . TABLE_CONFIGURATION . " where configuration_key = 'MODULE_PAYMENT_VIAKLIX_STATUS'"); $this->_check = tep_db_num_rows($check_query); } return $this->_check; } function install() { tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, set_function, date_added) values ('Enable viaKLIX Module', 'MODULE_PAYMENT_VIAKLIX_STATUS', 'True', 'Do you want to accept viaKLIX payments?', '6', '1', 'tep_cfg_select_option(array(\'True\', \'False\'), ', now())"); tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Merchant Number', 'MODULE_PAYMENT_VIAKLIX_MERCHANT_ID', '99999', 'The account number used for the viaKLIX service', '6', '2', now())"); tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('User ID', 'MODULE_PAYMENT_VIAKLIX_USER_ID', '99999', 'The user ID for the viaKLIX service', '6', '3', now())"); tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('User PIN', 'MODULE_PAYMENT_VIAKLIX_PIN', '0', 'The user PIN for the viaKLIX service', '6', '4', now())"); tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, set_function, date_added) values ('Transaction Mode', 'MODULE_PAYMENT_VIAKLIX_TESTMODE', 'Test', 'Transaction mode used for processing orders', '6', '0', 'tep_cfg_select_option(array(\'Test\', \'Production\'), ', now())"); tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Sort order of display.', 'MODULE_PAYMENT_VIAKLIX_SORT_ORDER', '0', 'Sort order of display. Lowest is displayed first.', '6', '0', now())"); tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, use_function, set_function, date_added) values ('Payment Zone', 'MODULE_PAYMENT_VIAKLIX_ZONE', '0', 'If a zone is selected, only enable this payment method for that zone.', '6', '2', 'tep_get_zone_class_title', 'tep_cfg_pull_down_zone_classes(', now())"); tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, set_function, use_function, date_added) values ('Set Order Status', 'MODULE_PAYMENT_VIAKLIX_ORDER_STATUS_ID', '0', 'Set the status of orders made with this payment module to this value', '6', '0', 'tep_cfg_pull_down_order_statuses(', 'tep_get_order_status_name', now())"); } function remove() { tep_db_query("delete from " . TABLE_CONFIGURATION . " where configuration_key in ('" . implode("', '", $this->keys()) . "')"); } function keys() { return array('MODULE_PAYMENT_VIAKLIX_STATUS', 'MODULE_PAYMENT_VIAKLIX_MERCHANT_ID', 'MODULE_PAYMENT_VIAKLIX_USER_ID', 'MODULE_PAYMENT_VIAKLIX_PIN', 'MODULE_PAYMENT_VIAKLIX_TESTMODE','MODULE_PAYMENT_VIAKLIX_ZONE', 'MODULE_PAYMENT_VIAKLIX_ORDER_STATUS_ID', 'MODULE_PAYMENT_VIAKLIX_SORT_ORDER'); } } ?> I am at a loss...I have no file named popup_cvv... Quote Learning is not attained by chance, it must be sought for with ardor and attended to with diligence.
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.