From 2c2ccf88767ea75f34eac628a342ead301883a48 Mon Sep 17 00:00:00 2001 From: Bivekich Date: Tue, 8 Jul 2025 13:25:46 +0300 Subject: [PATCH] =?UTF-8?q?=D0=9E=D0=B1=D0=BD=D0=BE=D0=B2=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=D1=8B=20=D0=BB=D0=BE=D0=B3=D0=B8=D0=BA=D0=B0=20=D1=80?= =?UTF-8?q?=D0=B0=D0=B1=D0=BE=D1=82=D1=8B=20=D1=81=20=D0=BF=D0=B0=D1=80?= =?UTF-8?q?=D0=B0=D0=BC=D0=B5=D1=82=D1=80=D0=BE=D0=BC=20SSD=20=D0=B2=20?= =?UTF-8?q?=D0=BA=D0=BB=D0=B0=D1=81=D1=81=D0=B5=20LaximoService=20=D0=B8?= =?UTF-8?q?=20=D1=80=D0=B5=D0=B7=D0=BE=D0=BB=D0=B2=D0=B5=D1=80=D0=B0=D1=85?= =?UTF-8?q?.=20=D0=A2=D0=B5=D0=BF=D0=B5=D1=80=D1=8C=20SSD=20=D0=B8=D1=81?= =?UTF-8?q?=D0=BF=D0=BE=D0=BB=D1=8C=D0=B7=D1=83=D0=B5=D1=82=D1=81=D1=8F=20?= =?UTF-8?q?=D0=B4=D0=BB=D1=8F=20=D0=BF=D0=BE=D0=BB=D1=83=D1=87=D0=B5=D0=BD?= =?UTF-8?q?=D0=B8=D1=8F=20=D1=83=D0=B7=D0=BB=D0=BE=D0=B2=20=D0=B2=20=D0=BA?= =?UTF-8?q?=D0=B0=D1=82=D0=B5=D0=B3=D0=BE=D1=80=D0=B8=D1=8F=D1=85,=20?= =?UTF-8?q?=D1=87=D1=82=D0=BE=20=D1=83=D0=BB=D1=83=D1=87=D1=88=D0=B0=D0=B5?= =?UTF-8?q?=D1=82=20=D0=BE=D0=B1=D1=80=D0=B0=D0=B1=D0=BE=D1=82=D0=BA=D1=83?= =?UTF-8?q?=20=D0=B7=D0=B0=D0=BF=D1=80=D0=BE=D1=81=D0=BE=D0=B2=20=D0=BA=20?= =?UTF-8?q?API.=20=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D0=B5=D0=BD=D0=BE?= =?UTF-8?q?=20=D0=B8=D0=B7=D0=B2=D0=BB=D0=B5=D1=87=D0=B5=D0=BD=D0=B8=D0=B5?= =?UTF-8?q?=20SSD=20=D1=83=D0=B7=D0=BB=D0=B0=20=D0=B8=20=D1=81=D0=BE=D0=BE?= =?UTF-8?q?=D1=82=D0=B2=D0=B5=D1=82=D1=81=D1=82=D0=B2=D1=83=D1=8E=D1=89?= =?UTF-8?q?=D0=B8=D0=B5=20=D0=B8=D0=B7=D0=BC=D0=B5=D0=BD=D0=B5=D0=BD=D0=B8?= =?UTF-8?q?=D1=8F=20=D0=B2=20=D0=BB=D0=BE=D0=B3=D0=B0=D1=85=20=D0=B4=D0=BB?= =?UTF-8?q?=D1=8F=20=D0=BF=D0=BE=D0=B2=D1=8B=D1=88=D0=B5=D0=BD=D0=B8=D1=8F?= =?UTF-8?q?=20=D0=B8=D0=BD=D1=84=D0=BE=D1=80=D0=BC=D0=B0=D1=82=D0=B8=D0=B2?= =?UTF-8?q?=D0=BD=D0=BE=D1=81=D1=82=D0=B8.=20=D0=AD=D1=82=D0=BE=20=D0=BF?= =?UTF-8?q?=D0=BE=D0=B2=D1=8B=D1=88=D0=B0=D0=B5=D1=82=20=D0=BD=D0=B0=D0=B4?= =?UTF-8?q?=D0=B5=D0=B6=D0=BD=D0=BE=D1=81=D1=82=D1=8C=20=D0=B2=D0=B7=D0=B0?= =?UTF-8?q?=D0=B8=D0=BC=D0=BE=D0=B4=D0=B5=D0=B9=D1=81=D1=82=D0=B2=D0=B8?= =?UTF-8?q?=D1=8F=20=D1=81=20API=20=D0=B8=20=D1=83=D0=BB=D1=83=D1=87=D1=88?= =?UTF-8?q?=D0=B0=D0=B5=D1=82=20=D1=81=D1=82=D1=80=D1=83=D0=BA=D1=82=D1=83?= =?UTF-8?q?=D1=80=D1=83=20=D0=B4=D0=B0=D0=BD=D0=BD=D1=8B=D1=85.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/lib/graphql/resolvers.ts | 40 +++++++++++++++++++++++++----------- src/lib/laximo-service.ts | 28 +++++++++++++++++++------ 2 files changed, 50 insertions(+), 18 deletions(-) diff --git a/src/lib/graphql/resolvers.ts b/src/lib/graphql/resolvers.ts index 20e2f78..c3a359f 100644 --- a/src/lib/graphql/resolvers.ts +++ b/src/lib/graphql/resolvers.ts @@ -1831,22 +1831,38 @@ export const resolvers = { if (categoryId) { console.log('🔧 Поиск узлов в категории:', categoryId) - // Для обычных категорий НЕ используем SSD - он нужен только для быстрых групп + // ИСПРАВЛЕНИЕ: Разные каталоги поддерживают разные параметры для ListUnits try { - console.log('🔧 Пробуем ListUnits БЕЗ SSD для обычной категории...') - result = await laximoService.getListUnits(catalogCode, vehicleId, undefined, categoryId) + console.log('🔧 Пробуем ListUnits с SSD для категории...') + result = await laximoService.getListUnits(catalogCode, vehicleId, ssd, categoryId) console.log('✅ Получено узлов в категории:', result.length) } catch (error: any) { - console.log('⚠️ Ошибка ListUnits без SSD:', error.message) + console.log('⚠️ Ошибка ListUnits с SSD:', error.message) - // Если и без SSD не работает, пробуем получить категории вместо узлов - try { - console.log('🔧 Пробуем получить подкатегории...') - result = await laximoService.getListCategories(catalogCode, vehicleId, undefined) - // Фильтруем только подкатегории данной категории, если есть parent-child связи - console.log('✅ Получено подкатегорий:', result.length) - } catch (categoriesError: any) { - console.log('⚠️ Ошибка получения подкатегорий:', categoriesError.message) + // Если ошибка E_INVALIDPARAMETER:ssd - значит данная категория/каталог не поддерживает SSD + if (error.message.includes('E_INVALIDPARAMETER:ssd')) { + console.log('🔧 Каталог/категория не поддерживает SSD, пробуем без SSD...') + try { + result = await laximoService.getListUnits(catalogCode, vehicleId, undefined, categoryId) + console.log('✅ Получено узлов в категории (без SSD):', result.length) + } catch (noSsdError: any) { + console.log('⚠️ Ошибка ListUnits без SSD:', noSsdError.message) + + // Если и без SSD не работает, значит данная категория не содержит узлов + // Возвращаем пустой массив вместо ошибки + console.log('🔧 Категория не содержит узлов, возвращаем пустой результат') + result = [] + } + } else { + // Для других ошибок также пробуем без SSD + try { + console.log('🔧 Пробуем ListUnits без SSD для обычной категории...') + result = await laximoService.getListUnits(catalogCode, vehicleId, undefined, categoryId) + console.log('✅ Получено узлов в категории (без SSD):', result.length) + } catch (noSsdError: any) { + console.log('⚠️ Ошибка ListUnits без SSD:', noSsdError.message) + result = [] + } } } } else { diff --git a/src/lib/laximo-service.ts b/src/lib/laximo-service.ts index 23af7af..f13dc0e 100644 --- a/src/lib/laximo-service.ts +++ b/src/lib/laximo-service.ts @@ -131,6 +131,7 @@ export interface LaximoQuickGroup { code?: string imageurl?: string largeimageurl?: string + ssd?: string // ИСПРАВЛЕНИЕ: Добавляем поле SSD для узлов } export interface LaximoQuickDetail { @@ -1107,17 +1108,29 @@ class LaximoService { command += `|VehicleId=${vehicleId}` } - // 🎯 ИСПРАВЛЕНИЕ: Для категорий каталога НЕ используем SSD - // SSD используется только для QuickGroup'ов, но не для категорий + // 🎯 ИСПРАВЛЕНИЕ: Для категорий каталога требуется SSD согласно API Laximo + // Без SSD API возвращает ошибку E_INVALIDPARAMETER:ssd if (categoryId) { - // Если указана категория, НЕ добавляем SSD - показываем ВСЕ узлы категории command += `|CategoryId=${categoryId}` - console.log('🔧 Режим "От производителя": используем CategoryId БЕЗ SSD для получения всех узлов категории') + // SSD обязателен для ListUnits даже с CategoryId + if (ssd && ssd.trim() !== '') { + const escapedSsd = this.escapeSsdForXML(ssd) + command += `|ssd=${escapedSsd}` + console.log('🔧 Режим "От производителя": используем CategoryId с SSD') + } else { + // Если SSD отсутствует, используем пустой SSD + command += `|ssd=` + console.log('🔧 Режим "От производителя": используем CategoryId с пустым SSD') + } } else if (ssd && ssd.trim() !== '') { - // SSD добавляем только если НЕТ CategoryId (для QuickGroup'ов) + // SSD добавляем для QuickGroup'ов const escapedSsd = this.escapeSsdForXML(ssd) command += `|ssd=${escapedSsd}` console.log('🔧 Режим "Общие": используем SSD для получения узлов автомобиля') + } else { + // Всегда добавляем SSD параметр, даже если он пустой + command += `|ssd=` + console.log('🔧 Добавляем пустой SSD параметр') } const hmac = this.createHMAC(command) @@ -1194,6 +1207,7 @@ class LaximoService { const code = this.extractAttribute(attributes, 'code') const imageurl = this.extractAttribute(attributes, 'imageurl') const largeimageurl = this.extractAttribute(attributes, 'largeimageurl') + const ssd = this.extractAttribute(attributes, 'ssd') // ИСПРАВЛЕНИЕ: Извлекаем SSD узла const hasDetails = this.extractAttribute(attributes, 'hasdetails') === 'true' if (unitid && name) { @@ -1203,7 +1217,8 @@ class LaximoService { link: hasDetails, code: code || undefined, imageurl: imageurl || undefined, - largeimageurl: largeimageurl || undefined + largeimageurl: largeimageurl || undefined, + ssd: ssd || undefined // ИСПРАВЛЕНИЕ: Добавляем SSD узла для дальнейшего использования } console.log('📦 Найден узел каталога:', { @@ -1211,6 +1226,7 @@ class LaximoService { name, code, imageurl: imageurl ? imageurl.substring(0, 50) + '...' : 'отсутствует', + ssd: ssd ? `${ssd.substring(0, 50)}...` : 'отсутствует', // ИСПРАВЛЕНИЕ: Показываем SSD узла hasDetails }) groups.push(group)