🔓 Разрешить 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:
@@ -29,7 +29,8 @@ export async function POST(request: NextRequest) {
|
||||
telegramUsername,
|
||||
firstName,
|
||||
lastName,
|
||||
referrerId
|
||||
referrerId,
|
||||
source // Источник перехода (n8n, chat и т.д.)
|
||||
} = await request.json();
|
||||
|
||||
logger.debug('📥 Received data:', {
|
||||
@@ -40,11 +41,15 @@ export async function POST(request: NextRequest) {
|
||||
telegramUsername,
|
||||
firstName,
|
||||
lastName,
|
||||
referrerId
|
||||
referrerId,
|
||||
source
|
||||
});
|
||||
|
||||
// ⚠️ ВАЛИДАЦИЯ: telegramId обязателен!
|
||||
if (!telegramId) {
|
||||
// 🔓 ИСКЛЮЧЕНИЕ: Разрешаем n8n переходы даже без telegramId
|
||||
const fromN8n = source === 'n8n' || source === 'chat';
|
||||
|
||||
// ⚠️ ВАЛИДАЦИЯ: telegramId обязателен (кроме n8n переходов)
|
||||
if (!telegramId && !fromN8n) {
|
||||
logger.error('❌ VALIDATION FAILED: No telegramId provided');
|
||||
return NextResponse.json(
|
||||
{
|
||||
|
||||
14
app/page.tsx
14
app/page.tsx
@@ -213,24 +213,32 @@ export default function Home() {
|
||||
fullData: tgUser
|
||||
});
|
||||
|
||||
// ⚠️ ВАЖНО: Если Telegram не передал данные - НЕ создаем trial!
|
||||
if (!tgUser?.id) {
|
||||
// 🔓 ИСКЛЮЧЕНИЕ: Разрешаем создание для n8n переходов (когда есть source или utm параметры)
|
||||
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!');
|
||||
showToastNotification('❌ Откройте приложение через Telegram бота');
|
||||
setIsLoading(false);
|
||||
return;
|
||||
}
|
||||
|
||||
// Для n8n переходов генерируем временный ID
|
||||
const userId = tgUser?.id || Date.now();
|
||||
|
||||
// Создаем trial подписку через API
|
||||
const response = await fetch('/api/create-user', {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
body: JSON.stringify({
|
||||
planType: 'trial',
|
||||
telegramId: tgUser.id, // Теперь 100% есть
|
||||
telegramId: userId, // Telegram ID или временный для n8n
|
||||
telegramUsername: tgUser?.username || undefined,
|
||||
firstName: tgUser?.first_name || undefined,
|
||||
referrerId: referrerId || undefined,
|
||||
source: fromN8n ? (source || 'n8n') : undefined, // Помечаем n8n переходы
|
||||
}),
|
||||
});
|
||||
|
||||
|
||||
@@ -188,24 +188,33 @@ export default function PlansNew() {
|
||||
} : null
|
||||
});
|
||||
|
||||
// ⚠️ ВАЖНО: Если Telegram не передал user.id - блокируем создание
|
||||
if (!user?.id) {
|
||||
// 🔓 ИСКЛЮЧЕНИЕ: Проверяем переход из n8n
|
||||
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!');
|
||||
alert('❌ Откройте приложение через Telegram бота\n\nПриложение должно быть открыто в Telegram Mini App, а не в браузере.');
|
||||
setStep('plan');
|
||||
setIsCreatingUser(false);
|
||||
return;
|
||||
}
|
||||
|
||||
// Для n8n переходов генерируем временный ID
|
||||
const userId = user?.id || Date.now();
|
||||
|
||||
const requestBody = {
|
||||
planType,
|
||||
period,
|
||||
locationIds,
|
||||
telegramId: user.id, // Теперь 100% есть
|
||||
telegramId: userId, // Telegram ID или временный для n8n
|
||||
telegramUsername: user?.username || null,
|
||||
firstName: user?.first_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);
|
||||
|
||||
Reference in New Issue
Block a user