function fn_data_feeds_export($datafeed_id, $options = array(), $pattern = '') { static $pattern; if (empty($pattern)) { $pattern = fn_get_pattern_definition('products'); } $params['datafeed_id'] = $datafeed_id; $params['single'] = true; $params['available_fields'] = 'Y'; $params = array_merge($params, $options); $datafeed_data = fn_data_feeds_get_data($params, DESCR_SL); if (empty($pattern) || empty($params['datafeed_id'])) { fn_set_notification('E', __('error'), __('error_exim_no_data_exported')); return false; } if ($datafeed_data['exclude_disabled_products'] == 'Y') { $params['status'] = 'A'; } if (empty($datafeed_data['products']) && empty($datafeed_data['categories'])) { $params['cid'] = 0; $params['subcats'] = 'Y'; $params['skip_view'] = 'Y'; $params['extend'] = array('categories'); list($products, $search) = fn_get_products($params); $pids = array_map(create_function('$product', '$pid = $product["product_id"]; return $pid;'), $products); } else { $pids = array(); if (!empty($datafeed_data['products'])) { $pids = explode(',', $datafeed_data['products']); } if (!empty($datafeed_data['categories'])) { $params['cid'] = explode(',', $datafeed_data['categories']); $params['subcats'] = 'Y'; $params['skip_view'] = 'Y'; $params['extend'] = array('categories'); list($products, $search) = fn_get_products($params); $_pids = array_map(create_function('$product', '$pid = $product["product_id"]; return $pid;'), $products); $pids = array_merge($pids, $_pids); unset($_pids); } $pids = array_unique($pids); } if (empty($pids)) { fn_set_notification('E', __('error'), __('error_exim_no_data_exported')); return false; } $pattern['condition']['conditions']['product_id'] = $pids; $fields = array(); if (!empty($datafeed_data['fields'])) { foreach ($datafeed_data['fields'] as $field) { $fields[$field['field']] = $field['export_field_name']; } } $features = db_get_array('SELECT feature_id, description FROM ?:product_features_descriptions WHERE lang_code = ?s', DESCR_SL); $features_fields = array(); if (!empty($features)) { foreach ($features as $feature) { $features_fields[$feature['description']] = array('process_get' => array('fn_data_feeds_get_product_features', '#key', '#field', '#lang_code'), 'linked' => false); } } $pattern['export_fields'] = array_merge($pattern['export_fields'], $features_fields); $options = $datafeed_data['export_options']; $options['delimiter'] = $datafeed_data['csv_delimiter']; $options['filename'] = $datafeed_data['file_name']; $options['fields_names'] = true; $options['force_header'] = true; $pattern['enclosure'] = !empty($datafeed_data['enclosure']) ? $datafeed_data['enclosure'] : ''; if (!empty($fields)) { if (fn_export($pattern, $fields, $options) == true) { $errors = false; $export_location = empty($params['location']) ? $datafeed_data['export_location'] : $params['location']; if ($export_location == 'S') { if (file_exists(fn_get_files_dir_path() . $datafeed_data['file_name']) && is_dir($datafeed_data['save_dir'])) { fn_rename(fn_get_files_dir_path() . $datafeed_data['file_name'], $datafeed_data['save_dir'] . '/' . $datafeed_data['file_name']); } else { $errors = true; fn_set_notification('E', __('error'), __('check_server_export_settings')); } } elseif ($export_location == 'F') { if (empty($datafeed_data['ftp_url'])) { $errors = true; fn_set_notification('E', __('error'), __('ftp_connection_problem')); } else { preg_match("/[^\\/^\\^:]+/", $datafeed_data['ftp_url'], $matches); $host = $matches[0]; preg_match("/.*:([0-9]+)/", $datafeed_data['ftp_url'], $matches); $port = empty($matches[1]) ? 21 : $matches[1]; preg_match("/[^\\/]+(.*)/", $datafeed_data['ftp_url'], $matches); $url = empty($matches[1]) ? '' : $matches[1]; $conn_id = @ftp_connect($host, $port); $result = @ftp_login($conn_id, $datafeed_data['ftp_user'], $datafeed_data['ftp_pass']); if (!empty($url)) { @ftp_chdir($conn_id, $url); } $filename = fn_get_files_dir_path() . $datafeed_data['file_name']; if ($result) { if (@ftp_put($conn_id, $datafeed_data['file_name'], $filename, FTP_ASCII)) { unlink($filename); } else { $errors = true; fn_set_notification('E', __('error'), __('ftp_connection_problem')); } } else { $errors = true; fn_set_notification('E', __('error'), __('ftp_connection_problem')); } @ftp_close($conn_id); } } if (!$errors) { fn_set_notification('N', __('notice'), __('text_exim_data_exported')); return true; } else { unlink(fn_get_files_dir_path() . $datafeed_data['file_name']); return false; } } else { fn_set_notification('E', __('error'), __('error_exim_no_data_exported')); return false; } } else { fn_set_notification('E', __('error'), __('error_exim_fields_not_selected')); return false; } }
// if ($mode == 'export') { $_suffix = ''; if (!empty($layout_data['cols'])) { $pattern = fn_get_pattern_definition($layout_data['pattern_id'], 'export'); if (empty($pattern)) { fn_set_notification('E', __('error'), __('error_exim_pattern_not_found')); exit; } if (!empty($_SESSION['export_ranges'][$pattern['section']])) { if (empty($pattern['condition']['conditions'])) { $pattern['condition']['conditions'] = array(); } $pattern['condition']['conditions'] = fn_array_merge($pattern['condition']['conditions'], $_SESSION['export_ranges'][$pattern['section']]['data']); } if (fn_export($pattern, $layout_data['cols'], $_REQUEST['export_options']) == true) { fn_set_notification('N', __('notice'), __('text_exim_data_exported')); // Direct download if ($_REQUEST['export_options']['output'] == 'D') { $url = fn_url("exim.get_file?filename=" . $_REQUEST['export_options']['filename'], 'A', 'current'); // Output to screen } elseif ($_REQUEST['export_options']['output'] == 'C') { $url = fn_url("exim.get_file?to_screen=Y&filename=" . $_REQUEST['export_options']['filename'], 'A', 'current'); } if (defined('AJAX_REQUEST') && !empty($url)) { Tygh::$app['ajax']->assign('force_redirection', $url); exit; } $url = empty($url) ? fn_url('exim.export?section=' . $_REQUEST['section']) : $url; return array(CONTROLLER_STATUS_OK, $url); } else {
**************************************************************************** * PLEASE READ THE FULL TEXT OF THE SOFTWARE LICENSE AGREEMENT IN THE * * "copyright.txt" FILE PROVIDED WITH THIS DISTRIBUTION PACKAGE. * ****************************************************************************/ // rus_build_mailru dbazhenov use Tygh\Registry; ini_set('auto_detect_line_endings', true); set_time_limit(3600); fn_define('DB_LIMIT_SELECT_ROW', 30); if (!defined('BOOTSTRAP')) { die('Access denied'); } if ($mode == 'mailru_cron_export') { $addon_settings = Registry::get('addons.rus_tovary_mailru'); $params = $_REQUEST; if ($params['cron_key'] != $addon_settings['cron_key']) { fn_set_notification('E', __('error'), __('yml_export_error_cron_key')); fn_echo(__('yml_export_error_cron_key')); exit; } $layout_data_cols = array('product_id', 'product_code', 'Language', 'product_name', 'category', 'category_descriptions', 'price', 'status', 'amount', 'shipping_freight', 'free_shipping', 'product', 'full_description', 'product_features', 'product_url', 'image_url', 'is_edp'); $options = array('lang_code' => array(DEFAULT_LANGUAGE), 'price_dec_sign_delimiter' => '.', 'delimiter' => 'T', 'output' => 'S'); $pattern = fn_get_pattern_definition('tovary_mailru', 'export'); $options['filename'] = Registry::get('addons.rus_tovary_mailru.cron_filename'); if (fn_export($pattern, $layout_data_cols, $options)) { fn_echo("<br/>Экспорт выполнен успешно"); } else { fn_set_notification('E', __('error'), __('mailru_export_error_cron')); } exit; }