public static function syncProducts($products, $context, $id_lang)
 {
     $date = date('Y-m-d H:i:s');
     $ebay = new EbayRequest();
     // Get errors back
     if (file_exists(dirname(__FILE__) . '/../log/syncError.php')) {
         include dirname(__FILE__) . '/../log/syncError.php';
     }
     $tab_error = array();
     // Up the time limit
     @set_time_limit(3600);
     $product_ids = array_map(array('EbaySynchronizer', 'getIdProduct'), $products);
     $products_configuration = EbayProductConfiguration::getByProductIds($product_ids);
     foreach ($products as $p) {
         $product = new Product((int) $p['id_product'], true, $id_lang);
         // make sure that product exists in the db and has a default category
         if (!Validate::isLoadedObject($product) || !$product->id_category_default) {
             continue;
         }
         $quantity_product = EbaySynchronizer::_getProductQuantity($product, (int) $p['id_product']);
         $ebay_category = EbaySynchronizer::_getEbayCategory($product->id_category_default);
         $variations = EbaySynchronizer::_loadVariations($product, $context, $ebay_category);
         if (!$product->active || isset($products_configuration[$product->id]) && $products_configuration[$product->id]['blacklisted']) {
             // try to stop sale on eBay
             $ebay = EbaySynchronizer::endProductOnEbay($ebay, $context, $id_lang, null, $product->id);
             if (!empty($ebay->error)) {
                 $tab_error = EbaySynchronizer::_updateTabError($ebay->error, str_replace('&', '&', $product->name));
             }
             continue;
         }
         $pictures = EbaySynchronizer::_getPictures($product, $id_lang, $context, $products_configuration);
         // Load basic price
         list($price, $price_original) = EbaySynchronizer::_getPrices($product->id, $ebay_category->getPercent());
         $conditions = $ebay_category->getConditionsValues();
         // Generate array and try insert in database
         $data = array('price' => $price, 'quantity' => $quantity_product, 'categoryId' => $ebay_category->getIdCategoryRef(), 'variations' => $variations, 'pictures' => $pictures['general'], 'picturesMedium' => $pictures['medium'], 'picturesLarge' => $pictures['large'], 'condition' => $conditions[$product->condition], 'shipping' => EbaySynchronizer::_getShippingDetailsForProduct($product));
         $data = array_merge($data, EbaySynchronizer::_getProductData($product));
         // Fix hook update product
         if (Tools::getValue('id_product_attribute')) {
             $id_product_attribute_fix = (int) Tools::getValue('id_product_attribute');
             $key = $product_id . '-' . $id_product_attribute_fix;
             if (isset($data['variations'][$key]['quantity'])) {
                 $data['variations'][$key]['quantity'] = EbaySynchronizer::_fixHookUpdateProduct($context, $product_id, $data['variations'][$key]['quantity']);
             }
         }
         // Price Update
         if (isset($p['noPriceUpdate'])) {
             $data['noPriceUpdate'] = $p['noPriceUpdate'];
         }
         $clean_percent = $ebay_category->getCleanPercent();
         // Save percent and price discount
         if ($clean_percent < 0) {
             $data['price_original'] = round($price_original, 2);
             $data['price_percent'] = round($clean_percent);
         }
         $data['description'] = EbaySynchronizer::_getEbayDescription($product, $id_lang);
         // Export to eBay
         $ebay = EbaySynchronizer::_exportProductToEbay($product, $data, $ebay_category, $ebay, $date, $context, $id_lang);
         if (!empty($ebay->error)) {
             // Check for errors
             $tab_error = EbaySynchronizer::_updateTabError($ebay->error, $data['name']);
         }
     }
     if (count($tab_error)) {
         if (isset($all_error)) {
             $tab_error = array_merge($all_error, $tab_error);
         }
         file_put_contents(dirname(__FILE__) . '/../log/syncError.php', '<?php $all_error = ' . var_export($tab_error, true) . '; ' . ($ebay->itemConditionError ? '$itemConditionError = true; ' : '$itemConditionError = false;') . ' ?>');
     }
 }