🔓 Разрешить n8n переходы без Telegram ID

 Что сделано:
- app/page.tsx: Проверка source/utm_source параметров (n8n, chat, from_n8n)
- app/plans/page.tsx: Аналогичная проверка для 3-step flow
- app/api/create-user/route.ts: Разрешение создания без telegramId если source=n8n

🔓 ИСКЛЮЧЕНИЯ для n8n:
- ?source=n8n
- ?utm_source=n8n
- ?utm_source=chat
- ?from_n8n=true

🎯 ЛОГИКА:
1. Переход через Telegram Mini App → требуется tgUser.id 
2. Переход из n8n (прямая ссылка) → НЕ требуется, генерируется временный ID 
3. Переход из браузера напрямую → блокируется 

💡 Для временных ID используется Date.now() но только если fromN8n=true
This commit is contained in:
Umbrix Dev
2026-02-09 07:17:01 +03:00
parent 4c6bfcf17e
commit 5677b48227
3 changed files with 33 additions and 11 deletions

View File

@@ -29,7 +29,8 @@ export async function POST(request: NextRequest) {
telegramUsername, telegramUsername,
firstName, firstName,
lastName, lastName,
referrerId referrerId,
source // Источник перехода (n8n, chat и т.д.)
} = await request.json(); } = await request.json();
logger.debug('📥 Received data:', { logger.debug('📥 Received data:', {
@@ -40,11 +41,15 @@ export async function POST(request: NextRequest) {
telegramUsername, telegramUsername,
firstName, firstName,
lastName, lastName,
referrerId referrerId,
source
}); });
// ⚠️ ВАЛИДАЦИЯ: telegramId обязателен! // 🔓 ИСКЛЮЧЕНИЕ: Разрешаем n8n переходы даже без telegramId
if (!telegramId) { const fromN8n = source === 'n8n' || source === 'chat';
// ⚠️ ВАЛИДАЦИЯ: telegramId обязателен (кроме n8n переходов)
if (!telegramId && !fromN8n) {
logger.error('❌ VALIDATION FAILED: No telegramId provided'); logger.error('❌ VALIDATION FAILED: No telegramId provided');
return NextResponse.json( return NextResponse.json(
{ {

View File

@@ -213,24 +213,32 @@ export default function Home() {
fullData: tgUser fullData: tgUser
}); });
// ⚠️ ВАЖНО: Если Telegram не передал данные - НЕ создаем trial! // 🔓 ИСКЛЮЧЕНИЕ: Разрешаем создание для n8n переходов (когда есть source или utm параметры)
if (!tgUser?.id) { const source = urlParams.get('source') || urlParams.get('utm_source');
const fromN8n = source === 'n8n' || source === 'chat' || urlParams.has('from_n8n');
// ⚠️ ВАЖНО: Если Telegram не передал данные И это не n8n переход - блокируем!
if (!tgUser?.id && !fromN8n) {
console.error('❌ TRIAL BLOCKED: No Telegram user data!'); console.error('❌ TRIAL BLOCKED: No Telegram user data!');
showToastNotification('❌ Откройте приложение через Telegram бота'); showToastNotification('❌ Откройте приложение через Telegram бота');
setIsLoading(false); setIsLoading(false);
return; return;
} }
// Для n8n переходов генерируем временный ID
const userId = tgUser?.id || Date.now();
// Создаем trial подписку через API // Создаем trial подписку через API
const response = await fetch('/api/create-user', { const response = await fetch('/api/create-user', {
method: 'POST', method: 'POST',
headers: { 'Content-Type': 'application/json' }, headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({ body: JSON.stringify({
planType: 'trial', planType: 'trial',
telegramId: tgUser.id, // Теперь 100% есть telegramId: userId, // Telegram ID или временный для n8n
telegramUsername: tgUser?.username || undefined, telegramUsername: tgUser?.username || undefined,
firstName: tgUser?.first_name || undefined, firstName: tgUser?.first_name || undefined,
referrerId: referrerId || undefined, referrerId: referrerId || undefined,
source: fromN8n ? (source || 'n8n') : undefined, // Помечаем n8n переходы
}), }),
}); });

View File

@@ -188,24 +188,33 @@ export default function PlansNew() {
} : null } : null
}); });
// ⚠️ ВАЖНО: Если Telegram не передал user.id - блокируем создание // 🔓 ИСКЛЮЧЕНИЕ: Проверяем переход из n8n
if (!user?.id) { const urlParams = new URLSearchParams(window.location.search);
const source = urlParams.get('source') || urlParams.get('utm_source');
const fromN8n = source === 'n8n' || source === 'chat' || urlParams.has('from_n8n');
// ⚠️ ВАЖНО: Если Telegram не передал user.id И это не n8n переход - блокируем
if (!user?.id && !fromN8n) {
console.error('❌ USER CREATION BLOCKED: No Telegram user ID!'); console.error('❌ USER CREATION BLOCKED: No Telegram user ID!');
alert('❌ Откройте приложение через Telegram бота\n\nПриложение должно быть открыто в Telegram Mini App, а не в браузере.'); alert('❌ Откройте приложение через Telegram бота\n\nПриложение должно быть открыто в Telegram Mini App, а не в браузере.');
setStep('plan'); setStep('plan');
setIsCreatingUser(false); setIsCreatingUser(false);
return; return;
} }
// Для n8n переходов генерируем временный ID
const userId = user?.id || Date.now();
const requestBody = { const requestBody = {
planType, planType,
period, period,
locationIds, locationIds,
telegramId: user.id, // Теперь 100% есть telegramId: userId, // Telegram ID или временный для n8n
telegramUsername: user?.username || null, telegramUsername: user?.username || null,
firstName: user?.first_name || null, firstName: user?.first_name || null,
lastName: user?.last_name || null, lastName: user?.last_name || null,
referrerId: referrerId || null, // Добавляем referrerId referrerId: referrerId || null,
source: fromN8n ? (source || 'n8n') : null, // Помечаем n8n переходы
}; };
console.log('📤 REQUEST BODY:', requestBody); console.log('📤 REQUEST BODY:', requestBody);